-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathstardust-config.d.ts
117 lines (113 loc) · 2.32 KB
/
stardust-config.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
export interface Config {
/**
* The URL of the database to connect to.
*/
databaseUrl: string;
/**
* The public URL of your Stardust instance. Use this if you want to display site metadata.
*/
metadataUrl?: string;
docker: DockerConfig;
auth: AuthConfig;
session?: SessionConfig;
}
export interface DockerConfig {
/**
* The type of connection to use to connect to the Docker daemon.
* @default "socket"
*/
type?: "http" | "socket";
/**
* The path to the Docker socket to connect to, if using a socket connection.
* @default "/var/run/docker.sock"
*/
socket?: string;
/**
* The host to connect to, if using an HTTP connection.
*/
host?: string;
/**
* The port for the docker host, if using an HTTP connection.
*/
port?: number;
/**
* The Docker network used for connecting to containers
*/
network: string;
}
export interface AuthConfig {
/**
* The JWT secret used to sign tokens.
**/
secret: string;
/**
* Cloudflare turnstile configuration. Leave `undefined` to disable turnstile.
**/
turnstile?: TurnstileConfig;
/**
* Credentials configuration. Leave `undefined` to disable user/password signups, or as `{}` to enable.
**/
credentials?: {
/**
* Whether to allow user signups.
* @default false
**/
signups?: boolean;
};
/**
* OAuth configuration. Leave `undefined` to disable OAuth signups.
**/
oauth?: {
/**
* The OAuth providers to enable.
**/
providers: {
/**
* the provider name
**/
[key: string]: {
/**
* The client ID for the OAuth provider.
**/
clientId: string;
/**
* The client secret for the OAuth provider.
**/
clientSecret: string;
/**
* The OAuth provider's issuer, if applicable.
**/
issuer?: string;
};
};
};
}
export interface SessionConfig {
/**
* The amount of time to keep an inactive session alive for, in minutes.
* @default 1440
*/
keepaliveDuration?: number;
/**
* Dns servers for the container to use
* @default system default
*/
dnsServers?: string[];
/**
* Session per user usage limit configuration
*/
usageLimits?: {
instance?: number;
user?: number;
};
}
export interface TurnstileConfig {
/**
* The Turnstile secret key, used by the backend
*/
secret: string;
/**
* The Turnstile site key, used by the frontend
*/
siteKey: string;
}