-
-
Notifications
You must be signed in to change notification settings - Fork 88
/
index.d.ts
76 lines (70 loc) · 4.24 KB
/
index.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
/** uibuilder standard object definitions
* Used by code editors & typescript to validate data.
*/
/// <reference types="node" />
/// <reference types="node-red" />
/// <reference types="node-red__editor-client" />
import { Node } from 'node-red';
// See globals.d.ts for the global definitions
// The globals file can't contain anything else
// declare global {
// var RED:any;
// }
/**
* @typedef {object} uibNode Local copy of the node instance config + other info
* @property {String} id Unique identifier for this instance
* @property {String} type What type of node is this an instance of? (uibuilder)
* @property {String} name Descriptive name, only used by Editor
* @property {String} topic msg.topic overrides incoming msg.topic
* @property {String} url The url path (and folder path) to be used by this instance
* @property {boolean} fwdInMessages Forward input msgs to output #1?
* @property {boolean} allowScripts Allow scripts to be sent to front-end via msg? WARNING: can be a security issue.
* @property {boolean} allowStyles Allow CSS to be sent to the front-end via msg? WARNING: can be a security issue.
* @property {boolean} copyIndex Copy index.(html|js|css) files from templates if they don't exist?
* @property {boolean} showfolder Provide a folder index web page?
* @property {boolean} useSecurity Use uibuilder's built-in security features?
* @property {boolean} tokenAutoExtend Extend token life when msg's received from client?
* @property {Number} sessionLength Lifespan of token (in seconds)
* @property {String} jwtSecret Seed string for encryption of JWT
* @property {String} customFolder Name of the fs path used to hold custom files & folders for THIS INSTANCE
* @property {Number} ioClientsCount How many Socket clients connected to this instance?
* @property {Number} rcvMsgCount How many msg's received since last reset or redeploy?
* @property {Object} ioChannels The channel names for Socket.IO
* @property {String} ioChannels.control SIO Control channel name 'uiBuilderControl'
* @property {String} ioChannels.client SIO Client channel name 'uiBuilderClient'
* @property {String} ioChannels.server SIO Server channel name 'uiBuilder'
* @property {String} ioNamespace Make sure each node instance uses a separate Socket.IO namespace
* @property {Function} send Send a Node-RED msg to an output port
* @property {Function=} done Dummy done function for pre-Node-RED 1.0 servers
* @property {Function=} on Event handler
* @property {Function=} removeListener Event handling
* z, wires
*/
export interface uibNode extends Node {}
/** The standard msg.auth object used by uibuilder security. See uibuilder docs for details.
* typedef {Object} _auth The standard auth object used by uibuilder security. See docs for details.
* Note that any other data may be passed from your front-end code in the _auth.info object.
* _auth.info.error, _auth.info.validJwt, _auth.info.message, _auth.info.warning
* @param id Required. A unique user identifier.
* @param password Required for login only.
* @param jwt Required if logged in. Needed for ongoing session validation and management.
* @param sessionExpiry Required if logged in. Milliseconds since 1970. Needed for ongoing session validation and management.
* @param userValidated Required after user validation. Whether the input ID (and optional additional data from the _auth object) validated correctly or not.
* @param info Optional metadata about the user.
*/
export interface MsgAuth {
/** Required. A unique user identifier. */
id: string;
/** Required for login only. */
password: string | undefined;
/** Required if logged in. Needed for ongoing session validation and management. */
jwt: string | undefined;
/** Required if logged in. Milliseconds since 1970. Needed for ongoing session validation and management. */
sessionExpiry: string | undefined;
/** Required after user validation. Whether the input ID (and optional additional data from the _auth object) validated correctly or not. */
userValidated: string | undefined;
/** Optional. Any other data may be passed from your front-end code in the _auth.info object.
* @examples _auth.info.error, _auth.info.validJwt, _auth.info.message, _auth.info.warning
*/
info: string | undefined;
}