@openclaw-caribbean/server 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (41) hide show
  1. package/dist/api.d.ts +43 -0
  2. package/dist/api.d.ts.map +1 -0
  3. package/dist/api.js +354 -0
  4. package/dist/api.js.map +1 -0
  5. package/dist/auth.d.ts +8 -0
  6. package/dist/auth.d.ts.map +1 -0
  7. package/dist/auth.js +15 -0
  8. package/dist/auth.js.map +1 -0
  9. package/dist/cli.d.ts +3 -0
  10. package/dist/cli.d.ts.map +1 -0
  11. package/dist/cli.js +242 -0
  12. package/dist/cli.js.map +1 -0
  13. package/dist/database.d.ts +34 -0
  14. package/dist/database.d.ts.map +1 -0
  15. package/dist/database.js +236 -0
  16. package/dist/database.js.map +1 -0
  17. package/dist/index.d.ts +44 -0
  18. package/dist/index.d.ts.map +1 -0
  19. package/dist/index.js +100 -0
  20. package/dist/index.js.map +1 -0
  21. package/dist/node-manager.d.ts +16 -0
  22. package/dist/node-manager.d.ts.map +1 -0
  23. package/dist/node-manager.js +70 -0
  24. package/dist/node-manager.js.map +1 -0
  25. package/dist/web/android-chrome-192x192.png +0 -0
  26. package/dist/web/android-chrome-512x512.png +0 -0
  27. package/dist/web/apple-touch-icon.png +0 -0
  28. package/dist/web/assets/index-BeNjTVfM.css +1 -0
  29. package/dist/web/assets/index-nlzc5Vy-.js +217 -0
  30. package/dist/web/favicon-16x16.png +0 -0
  31. package/dist/web/favicon-32x32.png +0 -0
  32. package/dist/web/favicon.ico +0 -0
  33. package/dist/web/img/caribbean-logo.png +0 -0
  34. package/dist/web/img/openclaw-logo.svg +60 -0
  35. package/dist/web/index.html +18 -0
  36. package/dist/web/site.webmanifest +11 -0
  37. package/dist/websocket-hub.d.ts +37 -0
  38. package/dist/websocket-hub.d.ts.map +1 -0
  39. package/dist/websocket-hub.js +218 -0
  40. package/dist/websocket-hub.js.map +1 -0
  41. package/package.json +42 -0
package/dist/api.d.ts ADDED
@@ -0,0 +1,43 @@
1
+ import type { NodeInfo } from '@openclaw-caribbean/shared';
2
+ export interface ApiServerConfig {
3
+ port: number;
4
+ host: string;
5
+ webDistPath?: string;
6
+ auth?: {
7
+ enabled: boolean;
8
+ tokens: string[];
9
+ user?: {
10
+ username: string;
11
+ password: string;
12
+ };
13
+ jwtSecret?: string;
14
+ };
15
+ }
16
+ export declare class ApiServer {
17
+ private fastify;
18
+ private config;
19
+ private getNodeInfo;
20
+ private getAllNodes;
21
+ private sendCommand;
22
+ private getCommandResult?;
23
+ private clearCommandResult?;
24
+ private getDatabaseNodes?;
25
+ private updateNodeName?;
26
+ private deleteNode?;
27
+ private authEnabled;
28
+ private updateAgentToken?;
29
+ constructor(config: ApiServerConfig, getNodeInfo: (nodeId: string) => NodeInfo | undefined, getAllNodes: () => NodeInfo[], sendCommand: (nodeId: string, action: string, params: Record<string, unknown>) => string, getCommandResult?: (commandId: string) => {
30
+ success: boolean;
31
+ error?: string;
32
+ data?: unknown;
33
+ timestamp: string;
34
+ } | undefined, clearCommandResult?: (commandId: string) => void, getDatabaseNodes?: () => Promise<NodeInfo[]>, updateNodeName?: (nodeId: string, name: string) => Promise<void>, deleteNode?: (nodeId: string) => Promise<void>, updateAgentToken?: (token: string | undefined) => void);
35
+ private setupAuthMiddleware;
36
+ private setupRoutes;
37
+ private setupStaticFiles;
38
+ start(): Promise<void>;
39
+ stop(): Promise<void>;
40
+ private readConfig;
41
+ updateAuthConfig(authConfig: any): void;
42
+ }
43
+ //# sourceMappingURL=api.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"api.d.ts","sourceRoot":"","sources":["../src/api.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AAK3D,MAAM,WAAW,eAAe;IAC9B,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,IAAI,CAAC,EAAE;QACL,OAAO,EAAE,OAAO,CAAC;QACjB,MAAM,EAAE,MAAM,EAAE,CAAC;QACjB,IAAI,CAAC,EAAE;YACL,QAAQ,EAAE,MAAM,CAAC;YACjB,QAAQ,EAAE,MAAM,CAAC;SAClB,CAAC;QACF,SAAS,CAAC,EAAE,MAAM,CAAC;KACpB,CAAC;CACH;AAED,qBAAa,SAAS;IACpB,OAAO,CAAC,OAAO,CAAM;IACrB,OAAO,CAAC,MAAM,CAAkB;IAChC,OAAO,CAAC,WAAW,CAA2C;IAC9D,OAAO,CAAC,WAAW,CAAmB;IACtC,OAAO,CAAC,WAAW,CAA8E;IACjG,OAAO,CAAC,gBAAgB,CAAC,CAA6G;IACtI,OAAO,CAAC,kBAAkB,CAAC,CAA8B;IACzD,OAAO,CAAC,gBAAgB,CAAC,CAA4B;IACrD,OAAO,CAAC,cAAc,CAAC,CAAkD;IACzE,OAAO,CAAC,UAAU,CAAC,CAAoC;IACvD,OAAO,CAAC,WAAW,CAAU;IAC7B,OAAO,CAAC,gBAAgB,CAAC,CAAsC;gBAG7D,MAAM,EAAE,eAAe,EACvB,WAAW,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,QAAQ,GAAG,SAAS,EACrD,WAAW,EAAE,MAAM,QAAQ,EAAE,EAC7B,WAAW,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,MAAM,EACxF,gBAAgB,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK;QAAE,OAAO,EAAE,OAAO,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,OAAO,CAAC;QAAC,SAAS,EAAE,MAAM,CAAA;KAAE,GAAG,SAAS,EAC7H,kBAAkB,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,EAChD,gBAAgB,CAAC,EAAE,MAAM,OAAO,CAAC,QAAQ,EAAE,CAAC,EAC5C,cAAc,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,EAChE,UAAU,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,EAC9C,gBAAgB,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,KAAK,IAAI;IAuBxD,OAAO,CAAC,mBAAmB;IAgC3B,OAAO,CAAC,WAAW;IAoPnB,OAAO,CAAC,gBAAgB;IAyClB,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAetB,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAI3B,OAAO,CAAC,UAAU;IAUlB,gBAAgB,CAAC,UAAU,EAAE,GAAG,GAAG,IAAI;CAWxC"}
package/dist/api.js ADDED
@@ -0,0 +1,354 @@
1
+ import Fastify from 'fastify';
2
+ import cors from '@fastify/cors';
3
+ import { readFileSync, existsSync, writeFileSync } from 'fs';
4
+ import { join } from 'path';
5
+ import { homedir } from 'os';
6
+ import { verifyToken, generateToken } from './auth.js';
7
+ const CONFIG_PATH = join(homedir(), '.caribbean', 'server.json');
8
+ export class ApiServer {
9
+ fastify;
10
+ config;
11
+ getNodeInfo;
12
+ getAllNodes;
13
+ sendCommand;
14
+ getCommandResult;
15
+ clearCommandResult;
16
+ getDatabaseNodes;
17
+ updateNodeName;
18
+ deleteNode;
19
+ authEnabled;
20
+ updateAgentToken;
21
+ constructor(config, getNodeInfo, getAllNodes, sendCommand, getCommandResult, clearCommandResult, getDatabaseNodes, updateNodeName, deleteNode, updateAgentToken) {
22
+ this.config = config;
23
+ this.getNodeInfo = getNodeInfo;
24
+ this.getAllNodes = getAllNodes;
25
+ this.sendCommand = sendCommand;
26
+ this.getCommandResult = getCommandResult;
27
+ this.clearCommandResult = clearCommandResult;
28
+ this.getDatabaseNodes = getDatabaseNodes;
29
+ this.updateNodeName = updateNodeName;
30
+ this.deleteNode = deleteNode;
31
+ this.updateAgentToken = updateAgentToken;
32
+ this.authEnabled = !!config.auth?.enabled && !!config.auth?.user;
33
+ this.fastify = Fastify({ logger: false });
34
+ this.fastify.register(cors, {
35
+ origin: true,
36
+ credentials: true
37
+ });
38
+ this.setupAuthMiddleware();
39
+ this.setupRoutes();
40
+ this.setupStaticFiles();
41
+ }
42
+ setupAuthMiddleware() {
43
+ this.fastify.addHook('onRequest', async (request, reply) => {
44
+ const path = request.routerPath;
45
+ if (path === '/api/login' || path === '/api/health' ||
46
+ path?.startsWith('/api/auth/') || path?.startsWith('/api/settings/')) {
47
+ return;
48
+ }
49
+ if (!this.authEnabled || !path?.startsWith('/api/')) {
50
+ return;
51
+ }
52
+ const authHeader = request.headers.authorization;
53
+ if (!authHeader || !authHeader.startsWith('Bearer ')) {
54
+ reply.code(401).send({ error: 'Unauthorized' });
55
+ return;
56
+ }
57
+ const token = authHeader.substring(7);
58
+ const jwtSecret = this.config.auth?.jwtSecret;
59
+ const payload = verifyToken(token, jwtSecret);
60
+ if (!payload) {
61
+ reply.code(401).send({ error: 'Invalid or expired token' });
62
+ return;
63
+ }
64
+ request.user = payload;
65
+ });
66
+ }
67
+ setupRoutes() {
68
+ this.fastify.get('/api/health', async () => {
69
+ return { status: 'ok', timestamp: new Date().toISOString() };
70
+ });
71
+ this.fastify.get('/api/auth/status', async () => {
72
+ return { enabled: this.authEnabled };
73
+ });
74
+ this.fastify.get('/api/settings', async () => {
75
+ return {
76
+ auth: {
77
+ enabled: this.authEnabled,
78
+ username: this.config.auth?.user?.username,
79
+ agentTokenSet: !!(this.config.auth?.tokens && this.config.auth.tokens.length > 0)
80
+ }
81
+ };
82
+ });
83
+ this.fastify.post('/api/settings/auth', async (request, reply) => {
84
+ const { enabled, username, password, agentToken } = request.body;
85
+ try {
86
+ const configContent = readFileSync(CONFIG_PATH, 'utf-8');
87
+ const config = JSON.parse(configContent);
88
+ if (enabled !== undefined) {
89
+ if (enabled) {
90
+ if (!username || !password) {
91
+ reply.code(400).send({ error: 'Username and password are required to enable auth' });
92
+ return;
93
+ }
94
+ config.auth.enabled = true;
95
+ config.auth.user = { username, password };
96
+ config.auth.jwtSecret = 'caribbean-jwt-secret-' + Date.now();
97
+ }
98
+ else {
99
+ config.auth.enabled = false;
100
+ config.auth.user = undefined;
101
+ config.auth.jwtSecret = undefined;
102
+ }
103
+ }
104
+ if (agentToken !== undefined) {
105
+ if (agentToken && agentToken.trim() !== '') {
106
+ config.auth.tokens = [agentToken.trim()];
107
+ }
108
+ else {
109
+ config.auth.tokens = [];
110
+ }
111
+ }
112
+ writeFileSync(CONFIG_PATH, JSON.stringify(config, null, 2));
113
+ this.updateAuthConfig(config.auth);
114
+ const result = { success: true };
115
+ if (config.auth.enabled && config.auth.user && config.auth.jwtSecret) {
116
+ result.token = generateToken({ username: config.auth.user.username }, config.auth.jwtSecret);
117
+ }
118
+ return result;
119
+ }
120
+ catch (error) {
121
+ console.error('Failed to update settings:', error);
122
+ reply.code(500).send({ error: 'Failed to update settings' });
123
+ }
124
+ });
125
+ this.fastify.post('/api/login', async (request, reply) => {
126
+ if (!this.authEnabled) {
127
+ reply.code(400).send({ error: 'Authentication is not enabled' });
128
+ return;
129
+ }
130
+ const { username, password } = request.body;
131
+ if (!username || !password) {
132
+ reply.code(400).send({ error: 'Username and password are required' });
133
+ return;
134
+ }
135
+ if (username !== this.config.auth?.user?.username || password !== this.config.auth?.user?.password) {
136
+ reply.code(401).send({ error: 'Invalid username or password' });
137
+ return;
138
+ }
139
+ const jwtSecret = this.config.auth?.jwtSecret;
140
+ const token = generateToken({ username }, jwtSecret);
141
+ return {
142
+ success: true,
143
+ token,
144
+ username
145
+ };
146
+ });
147
+ this.fastify.get('/api/nodes', async () => {
148
+ return {
149
+ nodes: this.getAllNodes(),
150
+ count: this.getAllNodes().length
151
+ };
152
+ });
153
+ this.fastify.get('/api/nodes/database', async () => {
154
+ if (this.getDatabaseNodes) {
155
+ const nodes = await this.getDatabaseNodes();
156
+ return {
157
+ nodes,
158
+ count: nodes.length
159
+ };
160
+ }
161
+ return {
162
+ nodes: [],
163
+ count: 0,
164
+ error: 'Database not available'
165
+ };
166
+ });
167
+ this.fastify.get('/api/nodes/:id', async (request, reply) => {
168
+ const { id } = request.params;
169
+ const node = this.getNodeInfo(id);
170
+ if (!node) {
171
+ reply.code(404).send({ error: 'Node not found' });
172
+ return;
173
+ }
174
+ return node;
175
+ });
176
+ this.fastify.get('/api/nodes/:id/status', async (request, reply) => {
177
+ const { id } = request.params;
178
+ const node = this.getNodeInfo(id);
179
+ if (!node) {
180
+ reply.code(404).send({ error: 'Node not found' });
181
+ return;
182
+ }
183
+ return {
184
+ nodeId: id,
185
+ status: node.status,
186
+ lastSeen: node.lastSeen,
187
+ connected: node.connected
188
+ };
189
+ });
190
+ this.fastify.patch('/api/nodes/:id/name', async (request, reply) => {
191
+ const { id } = request.params;
192
+ const { name } = request.body;
193
+ if (!name || name.trim() === '') {
194
+ reply.code(400).send({ error: 'Name is required' });
195
+ return;
196
+ }
197
+ const node = this.getNodeInfo(id);
198
+ if (!node) {
199
+ reply.code(404).send({ error: 'Node not found' });
200
+ return;
201
+ }
202
+ if (this.updateNodeName) {
203
+ try {
204
+ await this.updateNodeName(id, name.trim());
205
+ reply.send({ success: true, nodeId: id, name: name.trim() });
206
+ }
207
+ catch (error) {
208
+ reply.code(500).send({
209
+ error: error instanceof Error ? error.message : 'Failed to update node name'
210
+ });
211
+ }
212
+ }
213
+ else {
214
+ reply.code(501).send({ error: 'Database not available' });
215
+ }
216
+ });
217
+ this.fastify.post('/api/nodes/:id/command', async (request, reply) => {
218
+ const { id } = request.params;
219
+ const { action, params = {} } = request.body;
220
+ try {
221
+ const commandId = this.sendCommand(id, action, params);
222
+ return {
223
+ success: true,
224
+ commandId,
225
+ nodeId: id,
226
+ action
227
+ };
228
+ }
229
+ catch (error) {
230
+ reply.code(400).send({
231
+ success: false,
232
+ error: error instanceof Error ? error.message : 'Unknown error'
233
+ });
234
+ }
235
+ });
236
+ this.fastify.get('/api/commands/:id/result', async (request, reply) => {
237
+ const { id } = request.params;
238
+ if (!this.getCommandResult) {
239
+ reply.code(501).send({ error: 'Command result retrieval not available' });
240
+ return;
241
+ }
242
+ const result = this.getCommandResult(id);
243
+ if (!result) {
244
+ reply.code(404).send({ error: 'Command result not found' });
245
+ return;
246
+ }
247
+ if (this.clearCommandResult) {
248
+ this.clearCommandResult(id);
249
+ }
250
+ return result;
251
+ });
252
+ this.fastify.delete('/api/nodes/:id', async (request, reply) => {
253
+ const { id } = request.params;
254
+ if (this.deleteNode) {
255
+ try {
256
+ await this.deleteNode(id);
257
+ reply.send({ success: true, nodeId: id });
258
+ }
259
+ catch (error) {
260
+ reply.code(500).send({
261
+ error: error instanceof Error ? error.message : 'Failed to delete node'
262
+ });
263
+ }
264
+ }
265
+ else {
266
+ reply.code(501).send({ error: 'Database not available' });
267
+ }
268
+ });
269
+ this.fastify.get('/api/stats', async () => {
270
+ const nodes = this.getAllNodes();
271
+ const connected = nodes.filter(n => n.connected);
272
+ return {
273
+ total: nodes.length,
274
+ connected: connected.length,
275
+ disconnected: nodes.length - connected.length
276
+ };
277
+ });
278
+ }
279
+ setupStaticFiles() {
280
+ if (!this.config.webDistPath)
281
+ return;
282
+ const indexPath = join(this.config.webDistPath, 'index.html');
283
+ this.fastify.get('/', async (request, reply) => {
284
+ if (existsSync(indexPath)) {
285
+ reply.type('text/html').send(readFileSync(indexPath, 'utf-8'));
286
+ }
287
+ else {
288
+ reply.code(404).send({ error: 'Web UI not found. Run: cd apps/web && pnpm build && cp -r dist ../server/dist/web' });
289
+ }
290
+ });
291
+ this.fastify.get('/*', async (request, reply) => {
292
+ const filePath = join(this.config.webDistPath, request.url.replace(/^\//, ''));
293
+ if (existsSync(filePath)) {
294
+ const ext = filePath.split('.').pop();
295
+ const contentTypes = {
296
+ 'html': 'text/html',
297
+ 'css': 'text/css',
298
+ 'js': 'application/javascript',
299
+ 'json': 'application/json',
300
+ 'png': 'image/png',
301
+ 'jpg': 'image/jpeg',
302
+ 'jpeg': 'image/jpeg',
303
+ 'svg': 'image/svg+xml',
304
+ 'ico': 'image/x-icon',
305
+ 'woff': 'font/woff',
306
+ 'woff2': 'font/woff2',
307
+ 'ttf': 'font/ttf',
308
+ 'eot': 'application/vnd.ms-fontobject'
309
+ };
310
+ reply.type(contentTypes[ext || 'html'] || 'application/octet-stream').send(readFileSync(filePath));
311
+ }
312
+ else {
313
+ reply.code(404).send({ error: 'File not found' });
314
+ }
315
+ });
316
+ }
317
+ async start() {
318
+ await this.fastify.listen({
319
+ port: this.config.port,
320
+ host: this.config.host
321
+ });
322
+ console.log(`[API] REST API listening on http://${this.config.host}:${this.config.port}`);
323
+ if (this.config.webDistPath) {
324
+ const indexPath = join(this.config.webDistPath, 'index.html');
325
+ if (existsSync(indexPath)) {
326
+ console.log(`[API] Web UI available at http://${this.config.host}:${this.config.port}`);
327
+ }
328
+ }
329
+ }
330
+ async stop() {
331
+ await this.fastify.close();
332
+ }
333
+ readConfig() {
334
+ try {
335
+ const configContent = readFileSync(CONFIG_PATH, 'utf-8');
336
+ return JSON.parse(configContent);
337
+ }
338
+ catch (error) {
339
+ console.error('Failed to read config:', error);
340
+ return null;
341
+ }
342
+ }
343
+ updateAuthConfig(authConfig) {
344
+ this.config.auth = authConfig;
345
+ this.authEnabled = !!authConfig?.enabled && !!authConfig?.user;
346
+ if (this.updateAgentToken) {
347
+ const agentToken = (authConfig?.tokens && authConfig.tokens.length > 0)
348
+ ? authConfig.tokens[0]
349
+ : undefined;
350
+ this.updateAgentToken(agentToken);
351
+ }
352
+ }
353
+ }
354
+ //# sourceMappingURL=api.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"api.js","sourceRoot":"","sources":["../src/api.ts"],"names":[],"mappings":"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"}
package/dist/auth.d.ts ADDED
@@ -0,0 +1,8 @@
1
+ export interface JwtPayload {
2
+ username: string;
3
+ iat?: number;
4
+ exp?: number;
5
+ }
6
+ export declare function generateToken(payload: JwtPayload, secret?: string): string;
7
+ export declare function verifyToken(token: string, secret?: string): JwtPayload | null;
8
+ //# sourceMappingURL=auth.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.d.ts","sourceRoot":"","sources":["../src/auth.ts"],"names":[],"mappings":"AAKA,MAAM,WAAW,UAAU;IACzB,QAAQ,EAAE,MAAM,CAAC;IACjB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,MAAM,CAAC;CACd;AAED,wBAAgB,aAAa,CAAC,OAAO,EAAE,UAAU,EAAE,MAAM,GAAE,MAA2B,GAAG,MAAM,CAE9F;AAED,wBAAgB,WAAW,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,GAAE,MAA2B,GAAG,UAAU,GAAG,IAAI,CAMjG"}
package/dist/auth.js ADDED
@@ -0,0 +1,15 @@
1
+ import jwt from 'jsonwebtoken';
2
+ const DEFAULT_JWT_SECRET = 'caribbean-default-secret-change-in-production';
3
+ const JWT_EXPIRES_IN = '7d';
4
+ export function generateToken(payload, secret = DEFAULT_JWT_SECRET) {
5
+ return jwt.sign(payload, secret, { expiresIn: JWT_EXPIRES_IN });
6
+ }
7
+ export function verifyToken(token, secret = DEFAULT_JWT_SECRET) {
8
+ try {
9
+ return jwt.verify(token, secret);
10
+ }
11
+ catch (error) {
12
+ return null;
13
+ }
14
+ }
15
+ //# sourceMappingURL=auth.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.js","sourceRoot":"","sources":["../src/auth.ts"],"names":[],"mappings":"AAAA,OAAO,GAAG,MAAM,cAAc,CAAC;AAE/B,MAAM,kBAAkB,GAAG,+CAA+C,CAAC;AAC3E,MAAM,cAAc,GAAG,IAAI,CAAC;AAQ5B,MAAM,UAAU,aAAa,CAAC,OAAmB,EAAE,SAAiB,kBAAkB;IACpF,OAAO,GAAG,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,SAAS,EAAE,cAAc,EAAE,CAAC,CAAC;AAClE,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,KAAa,EAAE,SAAiB,kBAAkB;IAC5E,IAAI,CAAC;QACH,OAAO,GAAG,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,CAAe,CAAC;IACjD,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC"}
package/dist/cli.d.ts ADDED
@@ -0,0 +1,3 @@
1
+ #!/usr/bin/env node
2
+ export {};
3
+ //# sourceMappingURL=cli.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.d.ts","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":""}