-
Notifications
You must be signed in to change notification settings - Fork 1.3k
/
Copy pathoptions.d.ts
246 lines (220 loc) · 13.2 KB
/
options.d.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
import * as http from 'http';
import * as https from 'https';
import { MimosOptions } from '@hapi/mimos';
import { PluginSpecificConfiguration } from '../plugin';
import { ReqRefDefaults } from '../request';
import { RouteOptions } from '../route';
import { CacheProvider, ServerOptionsCache } from './cache';
import { SameSitePolicy } from './state';
import { Validation } from './validation';
export interface ServerOptionsCompression {
minBytes: number;
}
/**
* Empty interface to allow for custom augmentation.
*/
export interface ServerOptionsApp {
}
/**
* The server options control the behavior of the server object. Note that the options object is deeply cloned
* (with the exception of listener which is shallowly copied) and should not contain any values that are unsafe to perform deep copy on.
* All options are optionals.
* [See docs](https://github.com/hapijs/hapi/blob/master/API.md#-server-options)
*/
export interface ServerOptions<V extends Validation.Compiler | null> {
/**
* @default '0.0.0.0' (all available network interfaces).
* Sets the hostname or IP address the server will listen on. If not configured, defaults to host if present, otherwise to all available network interfaces. Set to '127.0.0.1' or 'localhost' to
* restrict the server to only those coming from the same host.
* [See docs](https://github.com/hapijs/hapi/blob/master/API.md#-serveroptionsaddress)
*/
address?: string | undefined;
/**
* @default {}.
* Provides application-specific configuration which can later be accessed via server.settings.app. The framework does not interact with this object. It is simply a reference made available
* anywhere a server reference is provided. Note the difference between server.settings.app which is used to store static configuration values and server.app which is meant for storing run-time
* state.
* [See docs](https://github.com/hapijs/hapi/blob/master/API.md#-serveroptionsapp)
*/
app?: ServerOptionsApp | undefined;
/**
* @default true.
* Used to disable the automatic initialization of the listener. When false, indicates that the listener will be started manually outside the framework.
* Cannot be set to true along with a port value.
* [See docs](https://github.com/hapijs/hapi/blob/master/API.md#-serveroptionsautolisten)
*/
autoListen?: boolean | undefined;
/**
* @default { engine: require('@hapi/catbox-memory' }.
* Sets up server-side caching providers. Every server includes a default cache for storing application state. By default, a simple memory-based cache is created which has limited capacity and
* capabilities. hapi uses catbox for its cache implementation which includes support for common storage solutions (e.g. Redis, MongoDB, Memcached, Riak, among others). Caching is only utilized
* if methods and plugins explicitly store their state in the cache. The server cache configuration only defines the storage container itself. The configuration can be assigned one or more
* (array):
* * a class or prototype function (usually obtained by calling require() on a catbox strategy such as require('@hapi/catbox-redis')). A new catbox client will be created internally using this
* function.
* * a configuration object with the following:
* * * engine - a class, a prototype function, or a catbox engine object.
* * * name - an identifier used later when provisioning or configuring caching for server methods or plugins. Each cache name must be unique. A single item may omit the name option which defines
* the default cache. If every cache includes a name, a default memory cache is provisioned as well.
* * * shared - if true, allows multiple cache users to share the same segment (e.g. multiple methods using the same cache storage container). Default to false.
* * * partition - (optional) string used to isolate cached data. Defaults to 'hapi-cache'.
* * * other options passed to the catbox strategy used. Other options are only passed to catbox when engine above is a class or function and ignored if engine is a catbox engine object).
* [See docs](https://github.com/hapijs/hapi/blob/master/API.md#-serveroptionscache)
*/
cache?: CacheProvider | ServerOptionsCache | ServerOptionsCache[] | undefined;
/**
* @default { minBytes: 1024 }.
* Defines server handling of content encoding requests. If false, response content encoding is disabled and no compression is performed by the server.
*/
compression?: boolean | ServerOptionsCompression | undefined;
/**
* @default { request: ['implementation'] }.
* Determines which logged events are sent to the console. This should only be used for development and does not affect which events are actually logged internally and recorded. Set to false to
* disable all console logging, or to an object with:
* * log - a string array of server log tags to be displayed via console.error() when the events are logged via server.log() as well as internally generated server logs. Defaults to no output.
* * request - a string array of request log tags to be displayed via console.error() when the events are logged via request.log() as well as internally generated request logs. For example, to
* display all errors, set the option to ['error']. To turn off all console debug messages set it to false. To display all request logs, set it to '*'. Defaults to uncaught errors thrown in
* external code (these errors are handled automatically and result in an Internal Server Error response) or runtime errors due to developer error. For example, to display all errors, set the log
* or request to ['error']. To turn off all output set the log or request to false. To display all server logs, set the log or request to '*'. To disable all debug information, set debug to
* false.
*/
debug?: false | {
log?: string | string[] | false | undefined;
request?: string | string[] | false | undefined;
} | undefined;
/**
* @default the operating system hostname and if not available, to 'localhost'.
* The public hostname or IP address. Used to set server.info.host and server.info.uri and as address is none provided.
*/
host?: string | undefined;
info?: {
/**
* @default false.
* If true, the request.info.remoteAddress and request.info.remotePort are populated when the request is received which can consume more resource (but is ok if the information is needed,
* especially for aborted requests). When false, the fields are only populated upon demand (but will be undefined if accessed after the request is aborted).
*/
remote?: boolean | undefined;
} | undefined;
/**
* @default none.
* An optional node HTTP (or HTTPS) http.Server object (or an object with a compatible interface).
* If the listener needs to be manually started, set autoListen to false.
* If the listener uses TLS, set tls to true.
*/
listener?: http.Server | undefined;
/**
* @default { sampleInterval: 0 }.
* Server excessive load handling limits where:
* * sampleInterval - the frequency of sampling in milliseconds. When set to 0, the other load options are ignored. Defaults to 0 (no sampling).
* * maxHeapUsedBytes - maximum V8 heap size over which incoming requests are rejected with an HTTP Server Timeout (503) response. Defaults to 0 (no limit).
* * maxRssBytes - maximum process RSS size over which incoming requests are rejected with an HTTP Server Timeout (503) response. Defaults to 0 (no limit).
* * maxEventLoopDelay - maximum event loop delay duration in milliseconds over which incoming requests are rejected with an HTTP Server Timeout (503) response. Defaults to 0 (no limit).
*/
load?: {
/** the frequency of sampling in milliseconds. When set to 0, the other load options are ignored. Defaults to 0 (no sampling). */
sampleInterval?: number | undefined;
/** maximum V8 heap size over which incoming requests are rejected with an HTTP Server Timeout (503) response. Defaults to 0 (no limit). */
maxHeapUsedBytes?: number | undefined;
/**
* maximum process RSS size over which incoming requests are rejected with an HTTP Server Timeout (503) response. Defaults to 0 (no limit).
*/
maxRssBytes?: number | undefined;
/**
* maximum event loop delay duration in milliseconds over which incoming requests are rejected with an HTTP Server Timeout (503) response.
* Defaults to 0 (no limit).
*/
maxEventLoopDelay?: number | undefined;
} | undefined;
/**
* @default none.
* Options passed to the mimos module when generating the mime database used by the server (and accessed via server.mime):
* * override - an object hash that is merged into the built in mime information specified here. Each key value pair represents a single mime object. Each override value must contain:
* * key - the lower-cased mime-type string (e.g. 'application/javascript').
* * value - an object following the specifications outlined here. Additional values include:
* * * type - specify the type value of result objects, defaults to key.
* * * predicate - method with signature function(mime) when this mime type is found in the database, this function will execute to allows customizations.
* [See docs](https://github.com/hapijs/hapi/blob/master/API.md#-serveroptionsmime)
*/
mime?: MimosOptions | undefined;
/**
* @default { cleanStop: true }
* Defines server handling of server operations.
*/
operations?: {
/**
* @default true
* If true, the server keeps track of open connections and properly closes them when the server is stopped.
* [See docs](https://github.com/hapijs/hapi/blob/master/API.md#-serveroptionsoperations)
*/
cleanStop?: boolean;
}
/**
* @default {}.
* Plugin-specific configuration which can later be accessed via server.settings.plugins. plugins is an object where each key is a plugin name and the value is the configuration. Note the
* difference between server.settings.plugins which is used to store static configuration values and server.plugins which is meant for storing run-time state.
*/
plugins?: PluginSpecificConfiguration | undefined;
/**
* @default 0 (an ephemeral port).
* The TCP port the server will listen to. Defaults the next available port when the server is started (and assigned to server.info.port).
* If port is a string containing a '/' character, it is used as a UNIX domain socket path. If it starts with '\.\pipe', it is used as a Windows named pipe.
*/
port?: number | string | undefined;
/**
* @default { isCaseSensitive: true, stripTrailingSlash: false }.
* Controls how incoming request URIs are matched against the routing table:
* * isCaseSensitive - determines whether the paths '/example' and '/EXAMPLE' are considered different resources. Defaults to true.
* * stripTrailingSlash - removes trailing slashes on incoming paths. Defaults to false.
*/
router?: {
isCaseSensitive?: boolean | undefined;
stripTrailingSlash?: boolean | undefined;
} | undefined;
/**
* @default none.
* A route options object used as the default configuration for every route.
*/
routes?: RouteOptions<ReqRefDefaults, V> | undefined;
/**
* Default value:
* {
* strictHeader: true,
* ignoreErrors: false,
* isSecure: true,
* isHttpOnly: true,
* isSameSite: 'Strict',
* encoding: 'none'
* }
* Sets the default configuration for every state (cookie) set explicitly via server.state() or implicitly (without definition) using the state configuration object.
*/
// TODO I am not sure if I need to use all the server.state() definition (like the default value) OR only the options below. The v16 use "any" here.
// state?: ServerStateCookieOptions;
state?: {
strictHeader?: boolean | undefined;
ignoreErrors?: boolean | undefined;
isSecure?: boolean | undefined;
isHttpOnly?: boolean | undefined;
isSameSite?: SameSitePolicy | undefined;
encoding?: 'none' | 'base64' | 'base64json' | 'form' | 'iron' | undefined;
} | undefined;
/**
* @default none.
* Used to create an HTTPS connection. The tls object is passed unchanged to the node HTTPS server as described in the node HTTPS documentation.
*/
tls?: boolean | https.ServerOptions | undefined;
/**
* @default constructed from runtime server information.
* The full public URI without the path (e.g. 'http://example.com:8080'). If present, used as the server server.info.uri, otherwise constructed from the server settings.
*/
uri?: string | undefined;
/**
* Query parameter configuration.
*/
query?: {
/**
* the method must return an object where each key is a parameter and matching value is the parameter value.
* If the method throws, the error is used as the response or returned when `request.setUrl` is called.
*/
parser(raw: Record<string, string>): Record<string, any>;
} | undefined;
}