uWebSockets.js/docs/index.d.ts

197 lines
11 KiB
TypeScript
Raw Normal View History

2019-02-10 22:06:30 +00:00
/* Under construction, lots of things to add */
/** Native type representing a raw uSockets struct us_listen_socket. */
export interface us_listen_socket {
2019-02-10 22:06:30 +00:00
}
2019-03-03 07:15:48 +00:00
/** Recognized string types, things C++ can read and understand as strings */
export type RecognizedString = string | ArrayBuffer | Uint8Array | Int8Array | Uint16Array | Int16Array | Uint32Array | Int32Array | Float32Array | Float64Array;
2019-03-03 07:15:48 +00:00
2019-02-13 03:13:35 +00:00
/** A WebSocket connection that is valid from open to close event */
export interface WebSocket {
2019-02-13 03:13:35 +00:00
/** Sends a message. Make sure to check getBufferedAmount() before sending. Returns true for success, false for built up backpressure that will drain when time is given. */
send(message: RecognizedString, isBinary?: boolean, compress?: boolean) : boolean;
2019-02-13 03:13:35 +00:00
/** Returns the bytes buffered in backpressure. */
getBufferedAmount() : number;
/** Gracefully closes this WebSocket. Immediately calls close handler. */
end(code?: number, shortMessage?: RecognizedString) : WebSocket;
2019-02-13 03:13:35 +00:00
/** Forcefully closes this WebSocket */
2019-02-13 03:13:35 +00:00
close() : WebSocket;
/** Subscribe to a topic in MQTT syntax */
2019-03-03 07:15:48 +00:00
subscribe(topic: RecognizedString) : WebSocket;
2019-02-13 03:13:35 +00:00
2019-10-09 13:24:56 +00:00
/** Unsubscribe from a topic. Returns true on success, if the WebSocket was subscribed. */
unsubscribe(topic: RecognizedString) : boolean;
2019-02-13 03:13:35 +00:00
2019-10-09 13:24:56 +00:00
/** Publish a message to a topic in MQTT syntax */
publish(topic: RecognizedString, message: RecognizedString, isBinary?: boolean, compress?: boolean) : WebSocket;
2019-03-03 07:15:48 +00:00
2020-01-10 18:02:51 +00:00
/** See HttpResponse.cork */
cork(cb: () => void) : void;
2019-03-03 07:15:48 +00:00
/** Returns the remote IP address */
getRemoteAddress() : ArrayBuffer;
/** Arbitrary user data may be attached to this object */
[key: string]: any;
2019-02-13 03:13:35 +00:00
}
2019-02-10 22:06:30 +00:00
/** An HttpResponse is valid until either onAborted callback or any of the .end/.tryEnd calls succeed. You may attach user data to this object. */
export interface HttpResponse {
2019-02-13 03:13:35 +00:00
/** Writes the HTTP status message such as "200 OK". */
2019-03-03 07:15:48 +00:00
writeStatus(status: RecognizedString) : HttpResponse;
2019-02-13 03:13:35 +00:00
/** Writes key and value to HTTP response. */
2019-03-03 07:15:48 +00:00
writeHeader(key: RecognizedString, value: RecognizedString) : HttpResponse;
2019-02-13 03:13:35 +00:00
/** Enters or continues chunked encoding mode. Writes part of the response. End with zero length write. */
2019-03-03 07:15:48 +00:00
write(chunk: RecognizedString) : HttpResponse;
2019-02-10 22:06:30 +00:00
/** Ends this response by copying the contents of body. */
end(body?: RecognizedString) : HttpResponse;
2019-02-10 22:06:30 +00:00
/** Ends this response, or tries to, by streaming appropriately sized chunks of body. Use in conjunction with onWritable. Returns tuple [ok, hasResponded].*/
2019-03-03 07:15:48 +00:00
tryEnd(fullBodyOrChunk: RecognizedString, totalSize: number) : [boolean, boolean];
2019-02-13 03:13:35 +00:00
/** Immediately force closes the connection. */
close() : HttpResponse;
/** Returns the global byte write offset for this response. Use with onWritable. */
getWriteOffset() : number;
/** Registers a handler for writable events. Continue failed write attempts in here.
* You MUST return true for success, false for failure.
* Writing nothing is always success, so by default you must return true.
*/
onWritable(handler: (offset: number) => boolean) : HttpResponse;
2019-02-13 03:13:35 +00:00
/** Every HttpResponse MUST have an attached abort handler IF you do not respond
* to it immediately inside of the callback. Returning from an Http request handler
* without attaching (by calling onAborted) an abort handler is ill-use and will termiante.
* When this event emits, the response has been aborted and may not be used. */
2019-10-17 01:39:55 +00:00
onAborted(handler: () => void) : HttpResponse;
2019-02-13 03:13:35 +00:00
/** Handler for reading data from POST and such requests. You MUST copy the data of chunk if isLast is not true. We Neuter ArrayBuffers on return, making it zero length.*/
onData(handler: (chunk: ArrayBuffer, isLast: boolean) => void) : HttpResponse;
2019-03-03 07:15:48 +00:00
/** Returns the remote IP address */
getRemoteAddress() : ArrayBuffer;
2019-12-21 19:46:31 +00:00
/** Corking a response is a performance improvement in both CPU and network, as you ready the IO system for writing multiple chunks at once.
* By default, you're corked in the immediately executing top portion of the route handler. In all other cases, such as when returning from
* await, or when being called back from an async database request or anything that isn't directly executing in the route handler, you'll want
* to cork before calling writeStatus, writeHeader or just write. Corking takes a callback in which you execute the writeHeader, writeStatus and
* such calls, in one atomic IO operation. This is important, not only for TCP but definitely for TLS where each write would otherwise result
* in one TLS block being sent off, each with one send syscall.
*
* Example usage:
*
* res.cork(() => {
* res.writeStatus("200 OK").writeHeader("Some", "Value").write("Hello world!");
* });
*/
cork(cb: () => void) : void;
/** Arbitrary user data may be attached to this object */
[key: string]: any;
2019-02-10 22:06:30 +00:00
}
/** An HttpRequest is stack allocated and only accessible during the callback invocation. */
export interface HttpRequest {
2019-02-13 03:13:35 +00:00
/** Returns the lowercased header value or empty string. */
2019-03-03 07:15:48 +00:00
getHeader(lowerCaseKey: RecognizedString) : string;
2019-02-13 03:13:35 +00:00
/** Returns the parsed parameter at index. Corresponds to route. */
getParameter(index: number) : string;
/** Returns the URL including initial /slash */
getUrl() : string;
/** Returns the HTTP method, useful for "any" routes. */
getMethod() : string;
/** Returns the part of URL after ? sign or empty string. */
getQuery() : string;
2019-03-10 11:52:42 +00:00
/** Loops over all headers. */
forEach(cb: (key: string, value: string) => void) : void;
2019-12-21 19:46:31 +00:00
/** Setting yield to true is to say that this route handler did not handle the route, causing the router to continue looking for a matching route handler, or fail. */
setYield(yield: boolean) : HttpRequest;
2019-02-13 03:13:35 +00:00
}
/** A structure holding settings and handlers for a WebSocket route handler. */
export interface WebSocketBehavior {
2019-02-13 03:13:35 +00:00
/** Maximum length of received message. */
maxPayloadLength?: number;
/** Maximum amount of seconds that may pass without sending or getting a message. */
idleTimeout?: number;
/** 0 = no compression, 1 = shared compressor, 2 = dedicated compressor. See C++ project. */
2019-03-03 07:15:48 +00:00
compression?: CompressOptions;
2019-10-09 13:24:56 +00:00
/** Maximum length of allowed backpressure per socket when publishing messages. Slow receivers, WebSockets, will be disconnected if needed. */
maxBackpressure?: number;
2019-02-13 03:13:35 +00:00
/** Handler for new WebSocket connection. WebSocket is valid from open to close, no errors. */
open?: (ws: WebSocket, req: HttpRequest) => void;
/** Handler for a WebSocket message. */
message?: (ws: WebSocket, message: ArrayBuffer, isBinary: boolean) => void;
/** Handler for when WebSocket backpressure drains. Check ws.getBufferedAmount(). */
drain?: (ws: WebSocket) => void;
/** Handler for close event, no matter if error, timeout or graceful close. You may not use WebSocket after this event. */
close?: (ws: WebSocket, code: number, message: ArrayBuffer) => void;
}
/** Options used when constructing an app. */
export interface AppOptions {
2019-03-03 07:15:48 +00:00
key_file_name?: RecognizedString;
cert_file_name?: RecognizedString;
passphrase?: RecognizedString;
dh_params_file_name?: RecognizedString;
2019-03-10 13:13:06 +00:00
/** This translates to SSL_MODE_RELEASE_BUFFERS */
ssl_prefer_low_memory_usage?: boolean;
2019-02-10 22:06:30 +00:00
}
/** TemplatedApp is either an SSL or non-SSL app. */
export interface TemplatedApp {
2019-02-10 22:06:30 +00:00
/** Listens to hostname & port. Callback hands either false or a listen socket. */
2019-03-03 07:15:48 +00:00
listen(host: RecognizedString, port: number, cb: (listenSocket: us_listen_socket) => void): TemplatedApp;
2019-02-10 22:06:30 +00:00
/** Listens to port. Callback hands either false or a listen socket. */
listen(port: number, cb: (listenSocket: any) => void): TemplatedApp;
/** Registers an HTTP GET handler matching specified URL pattern. */
2019-03-03 07:15:48 +00:00
get(pattern: RecognizedString, handler: (res: HttpResponse, req: HttpRequest) => void) : TemplatedApp;
2019-02-10 22:06:30 +00:00
/** Registers an HTTP POST handler matching specified URL pattern. */
2019-03-03 07:15:48 +00:00
post(pattern: RecognizedString, handler: (res: HttpResponse, req: HttpRequest) => void) : TemplatedApp;
2019-02-13 03:13:35 +00:00
/** Registers an HTTP OPTIONS handler matching specified URL pattern. */
2019-03-03 07:15:48 +00:00
options(pattern: RecognizedString, handler: (res: HttpResponse, req: HttpRequest) => void) : TemplatedApp;
2019-02-13 03:13:35 +00:00
/** Registers an HTTP DELETE handler matching specified URL pattern. */
2019-03-03 07:15:48 +00:00
del(pattern: RecognizedString, handler: (res: HttpResponse, req: HttpRequest) => void) : TemplatedApp;
2019-02-13 03:13:35 +00:00
/** Registers an HTTP PATCH handler matching specified URL pattern. */
2019-03-03 07:15:48 +00:00
patch(pattern: RecognizedString, handler: (res: HttpResponse, req: HttpRequest) => void) : TemplatedApp;
2019-02-13 03:13:35 +00:00
/** Registers an HTTP PUT handler matching specified URL pattern. */
2019-03-03 07:15:48 +00:00
put(pattern: RecognizedString, handler: (res: HttpResponse, req: HttpRequest) => void) : TemplatedApp;
2019-02-13 03:13:35 +00:00
/** Registers an HTTP HEAD handler matching specified URL pattern. */
2019-03-03 07:15:48 +00:00
head(pattern: RecognizedString, handler: (res: HttpResponse, req: HttpRequest) => void) : TemplatedApp;
2019-02-13 03:13:35 +00:00
/** Registers an HTTP CONNECT handler matching specified URL pattern. */
2019-03-03 07:15:48 +00:00
connect(pattern: RecognizedString, handler: (res: HttpResponse, req: HttpRequest) => void) : TemplatedApp;
2019-02-13 03:13:35 +00:00
/** Registers an HTTP TRACE handler matching specified URL pattern. */
2019-03-03 07:15:48 +00:00
trace(pattern: RecognizedString, handler: (res: HttpResponse, req: HttpRequest) => void) : TemplatedApp;
2019-02-13 03:13:35 +00:00
/** Registers an HTTP handler matching specified URL pattern on any HTTP method. */
2019-03-03 07:15:48 +00:00
any(pattern: RecognizedString, handler: (res: HttpResponse, req: HttpRequest) => void) : TemplatedApp;
2019-02-13 03:13:35 +00:00
/** Registers a handler matching specified URL pattern where WebSocket upgrade requests are caught. */
2019-03-03 07:15:48 +00:00
ws(pattern: RecognizedString, behavior: WebSocketBehavior) : TemplatedApp;
2019-10-17 00:29:12 +00:00
/** Publishes a message under topic, for all WebSockets under this app. See WebSocket.publish. */
publish(topic: RecognizedString, message: RecognizedString, isBinary?: boolean, compress?: boolean) : TemplatedApp;
2019-02-10 22:06:30 +00:00
}
/** Constructs a non-SSL app */
2019-06-08 16:46:22 +00:00
export function App(options?: AppOptions): TemplatedApp;
2019-02-10 22:06:30 +00:00
/** Constructs an SSL app */
export function SSLApp(options: AppOptions): TemplatedApp;
2019-02-13 03:13:35 +00:00
/** Closes a uSockets listen socket. */
export function us_listen_socket_close(listenSocket: us_listen_socket): void;
2019-02-21 19:03:43 +00:00
/** WebSocket compression options */
2019-11-18 18:37:30 +00:00
export type CompressOptions = number;
/** No compression (always a good idea) */
export var DISABLED: CompressOptions;
/** Zero memory overhead compression (recommended) */
export var SHARED_COMPRESSOR: CompressOptions;
/** Sliding dedicated compress window, requires lots of memory per socket */
export var DEDICATED_COMPRESSOR: CompressOptions;