A suite to track Project Diva score statistics and ratings / D4DJ event data.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
projectdivar/server/node_modules/ngrok/ngrok.d.ts

123 lines
3.2 KiB

5 years ago
import { CoreOptions, Request, RequestAPI, RequiredUriUrl } from 'request';
/**
* Creates a ngrok tunnel.
* E.g:
* const url = await ngrok.connect(); // https://757c1652.ngrok.io -> http://localhost:80
* const url = await ngrok.connect(9090); // https://757c1652.ngrok.io -> http://localhost:9090
* const url = await ngrok.connect({ proto: 'tcp', addr: 22 }); // tcp://0.tcp.ngrok.io:48590
*
* @param options Optional. Port number or options.
*/
export function connect(options?: number | INgrokOptions): Promise<string>;
/**
* Stops a tunnel, or all of them if no URL is passed.
*
* /!\ ngrok and all opened tunnels will be killed when the node process is done.
*
* /!\ Note on HTTP tunnels: by default bind_tls is true, so whenever you use http proto two tunnels are created:
* http and https. If you disconnect https tunnel, http tunnel remains open.
* You might want to close them both by passing http-version url, or simply by disconnecting all in one,
* with ngrok.disconnect().
*
* @param url The URL of the specific tunnel to disconnect -- if not passed, kills them all.
*/
export function disconnect(url?: string): Promise<void>;
/**
* Kills the ngrok process.
*/
export function kill(): Promise<void>;
/**
* Gets the ngrok client URL.
*/
export function getUrl(): string;
/**
* Gets the ngrok client API.
*/
export function getApi(): RequestAPI<Request, CoreOptions, RequiredUriUrl>;
/**
* You can create basic http-https-tcp tunnel without authtoken.
* For custom subdomains and more you should obtain authtoken by signing up at ngrok.com.
* E.g:
* await ngrok.authtoken(token);
* // or
* const url = await ngrok.connect({ authtoken: token, ... });
*
* @param token
*/
export function authtoken(token: string): Promise<void>;
interface INgrokOptions {
/**
* Other "custom", indirectly-supported ngrok process options.
*
* @see {@link https://ngrok.com/docs}
*/
[customOption: string]: any;
/**
* The tunnel type to put in place.
*
* @default 'http'
*/
proto?: 'http' | 'tcp' | 'tls';
/**
* Port or network address to redirect traffic on.
*
* @default opts.port || opts.host || 80
*/
addr?: string | number;
/**
* HTTP Basic authentication for tunnel.
*
* @default opts.httpauth
*/
auth?: string;
/**
* Reserved tunnel name (e.g. https://alex.ngrok.io)
*/
subdomain?: string;
/**
* Your authtoken from ngrok.com
*/
authtoken?: string;
/**
* One of ngrok regions.
* Note: region used in first tunnel will be used for all next tunnels too.
*
* @default 'us'
*/
region?: 'us' | 'eu' | 'au' | 'ap';
/**
* Custom path for ngrok config file.
*/
configPath?: string;
/**
* Custom binary path, eg for prod in electron
*/
binPath?: (defaultPath: string) => string;
/**
* Callback called when ngrok logs an event.
*/
onLogEvent?: (logEventMessage: string) => any;
/**
* Callback called when session status is changed.
* When connection is lost, ngrok will keep trying to reconnect.
*/
onStatusChange?: (status: 'connected' | 'closed') => any;
}