@jetstart/core 1.1.1
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.
- package/.eslintrc.json +6 -0
- package/README.md +124 -0
- package/dist/build/builder.d.ts +57 -0
- package/dist/build/builder.d.ts.map +1 -0
- package/dist/build/builder.js +151 -0
- package/dist/build/builder.js.map +1 -0
- package/dist/build/cache.d.ts +51 -0
- package/dist/build/cache.d.ts.map +1 -0
- package/dist/build/cache.js +152 -0
- package/dist/build/cache.js.map +1 -0
- package/dist/build/dsl-parser.d.ts +54 -0
- package/dist/build/dsl-parser.d.ts.map +1 -0
- package/dist/build/dsl-parser.js +373 -0
- package/dist/build/dsl-parser.js.map +1 -0
- package/dist/build/dsl-types.d.ts +47 -0
- package/dist/build/dsl-types.d.ts.map +1 -0
- package/dist/build/dsl-types.js +7 -0
- package/dist/build/dsl-types.js.map +1 -0
- package/dist/build/gradle-injector.d.ts +14 -0
- package/dist/build/gradle-injector.d.ts.map +1 -0
- package/dist/build/gradle-injector.js +77 -0
- package/dist/build/gradle-injector.js.map +1 -0
- package/dist/build/gradle.d.ts +43 -0
- package/dist/build/gradle.d.ts.map +1 -0
- package/dist/build/gradle.js +281 -0
- package/dist/build/gradle.js.map +1 -0
- package/dist/build/index.d.ts +10 -0
- package/dist/build/index.d.ts.map +1 -0
- package/dist/build/index.js +26 -0
- package/dist/build/index.js.map +1 -0
- package/dist/build/parser.d.ts +12 -0
- package/dist/build/parser.d.ts.map +1 -0
- package/dist/build/parser.js +71 -0
- package/dist/build/parser.js.map +1 -0
- package/dist/build/watcher.d.ts +30 -0
- package/dist/build/watcher.d.ts.map +1 -0
- package/dist/build/watcher.js +120 -0
- package/dist/build/watcher.js.map +1 -0
- package/dist/index.d.ts +11 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +26 -0
- package/dist/index.js.map +1 -0
- package/dist/server/http.d.ts +12 -0
- package/dist/server/http.d.ts.map +1 -0
- package/dist/server/http.js +32 -0
- package/dist/server/http.js.map +1 -0
- package/dist/server/index.d.ts +35 -0
- package/dist/server/index.d.ts.map +1 -0
- package/dist/server/index.js +262 -0
- package/dist/server/index.js.map +1 -0
- package/dist/server/middleware.d.ts +7 -0
- package/dist/server/middleware.d.ts.map +1 -0
- package/dist/server/middleware.js +42 -0
- package/dist/server/middleware.js.map +1 -0
- package/dist/server/routes.d.ts +7 -0
- package/dist/server/routes.d.ts.map +1 -0
- package/dist/server/routes.js +104 -0
- package/dist/server/routes.js.map +1 -0
- package/dist/types/index.d.ts +20 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +6 -0
- package/dist/types/index.js.map +1 -0
- package/dist/utils/index.d.ts +7 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +23 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/logger.d.ts +10 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +33 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/qr.d.ts +8 -0
- package/dist/utils/qr.d.ts.map +1 -0
- package/dist/utils/qr.js +48 -0
- package/dist/utils/qr.js.map +1 -0
- package/dist/utils/session.d.ts +18 -0
- package/dist/utils/session.d.ts.map +1 -0
- package/dist/utils/session.js +49 -0
- package/dist/utils/session.js.map +1 -0
- package/dist/websocket/handler.d.ts +25 -0
- package/dist/websocket/handler.d.ts.map +1 -0
- package/dist/websocket/handler.js +126 -0
- package/dist/websocket/handler.js.map +1 -0
- package/dist/websocket/index.d.ts +18 -0
- package/dist/websocket/index.d.ts.map +1 -0
- package/dist/websocket/index.js +40 -0
- package/dist/websocket/index.js.map +1 -0
- package/dist/websocket/manager.d.ts +16 -0
- package/dist/websocket/manager.d.ts.map +1 -0
- package/dist/websocket/manager.js +58 -0
- package/dist/websocket/manager.js.map +1 -0
- package/package.json +78 -0
- package/src/build/builder.ts +192 -0
- package/src/build/cache.ts +144 -0
- package/src/build/dsl-parser.ts +382 -0
- package/src/build/dsl-types.ts +50 -0
- package/src/build/gradle-injector.ts +64 -0
- package/src/build/gradle.ts +305 -0
- package/src/build/index.ts +10 -0
- package/src/build/parser.ts +75 -0
- package/src/build/watcher.ts +103 -0
- package/src/index.ts +20 -0
- package/src/server/http.ts +38 -0
- package/src/server/index.ts +272 -0
- package/src/server/middleware.ts +43 -0
- package/src/server/routes.ts +116 -0
- package/src/types/index.ts +21 -0
- package/src/utils/index.ts +7 -0
- package/src/utils/logger.ts +28 -0
- package/src/utils/qr.ts +46 -0
- package/src/utils/session.ts +58 -0
- package/src/websocket/handler.ts +150 -0
- package/src/websocket/index.ts +56 -0
- package/src/websocket/manager.ts +63 -0
- package/tests/build.test.ts +13 -0
- package/tests/server.test.ts +13 -0
- package/tsconfig.json +25 -0
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Logger Utility
|
|
4
|
+
* Colored logging for Core
|
|
5
|
+
*/
|
|
6
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
7
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
8
|
+
};
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.log = log;
|
|
11
|
+
exports.success = success;
|
|
12
|
+
exports.error = error;
|
|
13
|
+
exports.warn = warn;
|
|
14
|
+
exports.debug = debug;
|
|
15
|
+
const chalk_1 = __importDefault(require("chalk"));
|
|
16
|
+
function log(message) {
|
|
17
|
+
console.log(chalk_1.default.cyan('[Core]'), message);
|
|
18
|
+
}
|
|
19
|
+
function success(message) {
|
|
20
|
+
console.log(chalk_1.default.green('✔'), chalk_1.default.cyan('[Core]'), message);
|
|
21
|
+
}
|
|
22
|
+
function error(message) {
|
|
23
|
+
console.error(chalk_1.default.red('✖'), chalk_1.default.cyan('[Core]'), message);
|
|
24
|
+
}
|
|
25
|
+
function warn(message) {
|
|
26
|
+
console.log(chalk_1.default.yellow('⚠'), chalk_1.default.cyan('[Core]'), message);
|
|
27
|
+
}
|
|
28
|
+
function debug(message) {
|
|
29
|
+
if (process.env.DEBUG) {
|
|
30
|
+
console.log(chalk_1.default.gray('[DEBUG]'), chalk_1.default.cyan('[Core]'), message);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/utils/logger.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;;;AAIH,kBAEC;AAED,0BAEC;AAED,sBAEC;AAED,oBAEC;AAED,sBAIC;AAtBD,kDAA0B;AAE1B,SAAgB,GAAG,CAAC,OAAe;IACjC,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,OAAO,CAAC,CAAC;AAC7C,CAAC;AAED,SAAgB,OAAO,CAAC,OAAe;IACrC,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,eAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,OAAO,CAAC,CAAC;AAC/D,CAAC;AAED,SAAgB,KAAK,CAAC,OAAe;IACnC,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,eAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,OAAO,CAAC,CAAC;AAC/D,CAAC;AAED,SAAgB,IAAI,CAAC,OAAe;IAClC,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,eAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,OAAO,CAAC,CAAC;AAChE,CAAC;AAED,SAAgB,KAAK,CAAC,OAAe;IACnC,IAAI,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC;QACtB,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,eAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,OAAO,CAAC,CAAC;IACpE,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* QR Code Generator
|
|
3
|
+
* Generates QR codes for device pairing
|
|
4
|
+
*/
|
|
5
|
+
import { QRCodeOptions } from '../types';
|
|
6
|
+
export declare function generateQRCode(options: QRCodeOptions): Promise<string>;
|
|
7
|
+
export declare function generateQRCodeTerminal(options: QRCodeOptions): Promise<void>;
|
|
8
|
+
//# sourceMappingURL=qr.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"qr.d.ts","sourceRoot":"","sources":["../../src/utils/qr.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAIH,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAEzC,wBAAsB,cAAc,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAC,MAAM,CAAC,CAgB5E;AAED,wBAAsB,sBAAsB,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC,CAkBlF"}
|
package/dist/utils/qr.js
ADDED
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* QR Code Generator
|
|
4
|
+
* Generates QR codes for device pairing
|
|
5
|
+
*/
|
|
6
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
7
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
8
|
+
};
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.generateQRCode = generateQRCode;
|
|
11
|
+
exports.generateQRCodeTerminal = generateQRCodeTerminal;
|
|
12
|
+
const qrcode_1 = __importDefault(require("qrcode"));
|
|
13
|
+
async function generateQRCode(options) {
|
|
14
|
+
const data = {
|
|
15
|
+
sessionId: options.sessionId,
|
|
16
|
+
serverUrl: options.serverUrl,
|
|
17
|
+
wsUrl: options.wsUrl,
|
|
18
|
+
token: options.token,
|
|
19
|
+
projectName: options.projectName,
|
|
20
|
+
version: options.version,
|
|
21
|
+
};
|
|
22
|
+
// Generate QR code as data URL
|
|
23
|
+
return qrcode_1.default.toDataURL(JSON.stringify(data), {
|
|
24
|
+
errorCorrectionLevel: 'M',
|
|
25
|
+
type: 'image/png',
|
|
26
|
+
width: 300,
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
async function generateQRCodeTerminal(options) {
|
|
30
|
+
const data = {
|
|
31
|
+
sessionId: options.sessionId,
|
|
32
|
+
serverUrl: options.serverUrl,
|
|
33
|
+
wsUrl: options.wsUrl,
|
|
34
|
+
token: options.token,
|
|
35
|
+
projectName: options.projectName,
|
|
36
|
+
version: options.version,
|
|
37
|
+
};
|
|
38
|
+
// Generate QR code for terminal
|
|
39
|
+
return qrcode_1.default.toString(JSON.stringify(data), {
|
|
40
|
+
type: 'terminal',
|
|
41
|
+
small: true,
|
|
42
|
+
}, (err, url) => {
|
|
43
|
+
if (err)
|
|
44
|
+
throw err;
|
|
45
|
+
console.log(url);
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=qr.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"qr.js","sourceRoot":"","sources":["../../src/utils/qr.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;;;AAMH,wCAgBC;AAED,wDAkBC;AAxCD,oDAA4B;AAIrB,KAAK,UAAU,cAAc,CAAC,OAAsB;IACzD,MAAM,IAAI,GAAe;QACvB,SAAS,EAAE,OAAO,CAAC,SAAS;QAC5B,SAAS,EAAE,OAAO,CAAC,SAAS;QAC5B,KAAK,EAAE,OAAO,CAAC,KAAK;QACpB,KAAK,EAAE,OAAO,CAAC,KAAK;QACpB,WAAW,EAAE,OAAO,CAAC,WAAW;QAChC,OAAO,EAAE,OAAO,CAAC,OAAO;KACzB,CAAC;IAEF,+BAA+B;IAC/B,OAAO,gBAAM,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE;QAC5C,oBAAoB,EAAE,GAAG;QACzB,IAAI,EAAE,WAAW;QACjB,KAAK,EAAE,GAAG;KACX,CAAC,CAAC;AACL,CAAC;AAEM,KAAK,UAAU,sBAAsB,CAAC,OAAsB;IACjE,MAAM,IAAI,GAAe;QACvB,SAAS,EAAE,OAAO,CAAC,SAAS;QAC5B,SAAS,EAAE,OAAO,CAAC,SAAS;QAC5B,KAAK,EAAE,OAAO,CAAC,KAAK;QACpB,KAAK,EAAE,OAAO,CAAC,KAAK;QACpB,WAAW,EAAE,OAAO,CAAC,WAAW;QAChC,OAAO,EAAE,OAAO,CAAC,OAAO;KACzB,CAAC;IAEF,gCAAgC;IAChC,OAAO,gBAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE;QAC3C,IAAI,EAAE,UAAU;QAChB,KAAK,EAAE,IAAI;KACZ,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;QACd,IAAI,GAAG;YAAE,MAAM,GAAG,CAAC;QACnB,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IACnB,CAAC,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Session Manager
|
|
3
|
+
* Manages development sessions
|
|
4
|
+
*/
|
|
5
|
+
import { ServerSession } from '../types';
|
|
6
|
+
export declare class SessionManager {
|
|
7
|
+
private sessions;
|
|
8
|
+
createSession(data: {
|
|
9
|
+
projectName: string;
|
|
10
|
+
projectPath: string;
|
|
11
|
+
}): Promise<ServerSession>;
|
|
12
|
+
getSession(sessionId: string): ServerSession | undefined;
|
|
13
|
+
updateActivity(sessionId: string): void;
|
|
14
|
+
deleteSession(sessionId: string): void;
|
|
15
|
+
cleanupExpiredSessions(): void;
|
|
16
|
+
private generateToken;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=session.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session.d.ts","sourceRoot":"","sources":["../../src/utils/session.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAGzC,qBAAa,cAAc;IACzB,OAAO,CAAC,QAAQ,CAAyC;IAEnD,aAAa,CAAC,IAAI,EAAE;QACxB,WAAW,EAAE,MAAM,CAAC;QACpB,WAAW,EAAE,MAAM,CAAC;KACrB,GAAG,OAAO,CAAC,aAAa,CAAC;IAc1B,UAAU,CAAC,SAAS,EAAE,MAAM,GAAG,aAAa,GAAG,SAAS;IAIxD,cAAc,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI;IAOvC,aAAa,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI;IAItC,sBAAsB,IAAI,IAAI;IAU9B,OAAO,CAAC,aAAa;CAGtB"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Session Manager
|
|
4
|
+
* Manages development sessions
|
|
5
|
+
*/
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.SessionManager = void 0;
|
|
8
|
+
const uuid_1 = require("uuid");
|
|
9
|
+
const shared_1 = require("@jetstart/shared");
|
|
10
|
+
class SessionManager {
|
|
11
|
+
sessions = new Map();
|
|
12
|
+
async createSession(data) {
|
|
13
|
+
const session = {
|
|
14
|
+
id: (0, uuid_1.v4)(),
|
|
15
|
+
token: this.generateToken(),
|
|
16
|
+
projectName: data.projectName,
|
|
17
|
+
projectPath: data.projectPath,
|
|
18
|
+
createdAt: Date.now(),
|
|
19
|
+
lastActivity: Date.now(),
|
|
20
|
+
};
|
|
21
|
+
this.sessions.set(session.id, session);
|
|
22
|
+
return session;
|
|
23
|
+
}
|
|
24
|
+
getSession(sessionId) {
|
|
25
|
+
return this.sessions.get(sessionId);
|
|
26
|
+
}
|
|
27
|
+
updateActivity(sessionId) {
|
|
28
|
+
const session = this.sessions.get(sessionId);
|
|
29
|
+
if (session) {
|
|
30
|
+
session.lastActivity = Date.now();
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
deleteSession(sessionId) {
|
|
34
|
+
this.sessions.delete(sessionId);
|
|
35
|
+
}
|
|
36
|
+
cleanupExpiredSessions() {
|
|
37
|
+
const now = Date.now();
|
|
38
|
+
for (const [id, session] of this.sessions.entries()) {
|
|
39
|
+
if (now - session.lastActivity > shared_1.SESSION_TOKEN_EXPIRY) {
|
|
40
|
+
this.sessions.delete(id);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
generateToken() {
|
|
45
|
+
return (0, uuid_1.v4)().replace(/-/g, '');
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
exports.SessionManager = SessionManager;
|
|
49
|
+
//# sourceMappingURL=session.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session.js","sourceRoot":"","sources":["../../src/utils/session.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;AAEH,+BAAoC;AAEpC,6CAAwD;AAExD,MAAa,cAAc;IACjB,QAAQ,GAA+B,IAAI,GAAG,EAAE,CAAC;IAEzD,KAAK,CAAC,aAAa,CAAC,IAGnB;QACC,MAAM,OAAO,GAAkB;YAC7B,EAAE,EAAE,IAAA,SAAM,GAAE;YACZ,KAAK,EAAE,IAAI,CAAC,aAAa,EAAE;YAC3B,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;YACrB,YAAY,EAAE,IAAI,CAAC,GAAG,EAAE;SACzB,CAAC;QAEF,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC;QACvC,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,UAAU,CAAC,SAAiB;QAC1B,OAAO,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;IACtC,CAAC;IAED,cAAc,CAAC,SAAiB;QAC9B,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAC7C,IAAI,OAAO,EAAE,CAAC;YACZ,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACpC,CAAC;IACH,CAAC;IAED,aAAa,CAAC,SAAiB;QAC7B,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;IAClC,CAAC;IAED,sBAAsB;QACpB,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAEvB,KAAK,MAAM,CAAC,EAAE,EAAE,OAAO,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,EAAE,CAAC;YACpD,IAAI,GAAG,GAAG,OAAO,CAAC,YAAY,GAAG,6BAAoB,EAAE,CAAC;gBACtD,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;YAC3B,CAAC;QACH,CAAC;IACH,CAAC;IAEO,aAAa;QACnB,OAAO,IAAA,SAAM,GAAE,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;IACpC,CAAC;CACF;AAhDD,wCAgDC"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* WebSocket Message Handler
|
|
3
|
+
* Processes incoming WebSocket messages
|
|
4
|
+
*/
|
|
5
|
+
import { ConnectionManager } from './manager';
|
|
6
|
+
export declare class WebSocketHandler {
|
|
7
|
+
private connectionManager;
|
|
8
|
+
private onClientConnected?;
|
|
9
|
+
constructor(connectionManager: ConnectionManager, options?: {
|
|
10
|
+
onClientConnected?: (sessionId: string) => void;
|
|
11
|
+
});
|
|
12
|
+
handleMessage(clientId: string, data: Buffer): void;
|
|
13
|
+
private isClientMessage;
|
|
14
|
+
private handleClientMessage;
|
|
15
|
+
private handleConnect;
|
|
16
|
+
private handleDisconnect;
|
|
17
|
+
sendBuildStart(sessionId: string): void;
|
|
18
|
+
sendBuildComplete(sessionId: string, apkUrl: string): void;
|
|
19
|
+
/**
|
|
20
|
+
* Send UI update (DSL-based hot reload)
|
|
21
|
+
*/
|
|
22
|
+
sendUIUpdate(sessionId: string, dslContent: string, screens?: string[]): void;
|
|
23
|
+
private generateHash;
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=handler.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handler.d.ts","sourceRoot":"","sources":["../../src/websocket/handler.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAUH,OAAO,EAAE,iBAAiB,EAAE,MAAM,WAAW,CAAC;AAG9C,qBAAa,gBAAgB;IAIzB,OAAO,CAAC,iBAAiB;IAH3B,OAAO,CAAC,iBAAiB,CAAC,CAA8B;gBAG9C,iBAAiB,EAAE,iBAAiB,EAC5C,OAAO,CAAC,EAAE;QAAE,iBAAiB,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAA;KAAE;IAK/D,aAAa,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,IAAI;IAenD,OAAO,CAAC,eAAe;IAIvB,OAAO,CAAC,mBAAmB;IAoB3B,OAAO,CAAC,aAAa;IAoBrB,OAAO,CAAC,gBAAgB;IAKxB,cAAc,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI;IAUvC,iBAAiB,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,IAAI;IAqB1D;;OAEG;IACH,YAAY,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,EAAE,GAAG,IAAI;IAe7E,OAAO,CAAC,YAAY;CAUrB"}
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* WebSocket Message Handler
|
|
4
|
+
* Processes incoming WebSocket messages
|
|
5
|
+
*/
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.WebSocketHandler = void 0;
|
|
8
|
+
const logger_1 = require("../utils/logger");
|
|
9
|
+
class WebSocketHandler {
|
|
10
|
+
connectionManager;
|
|
11
|
+
onClientConnected;
|
|
12
|
+
constructor(connectionManager, options) {
|
|
13
|
+
this.connectionManager = connectionManager;
|
|
14
|
+
this.onClientConnected = options?.onClientConnected;
|
|
15
|
+
}
|
|
16
|
+
handleMessage(clientId, data) {
|
|
17
|
+
try {
|
|
18
|
+
const message = JSON.parse(data.toString());
|
|
19
|
+
(0, logger_1.log)(`Received message from ${clientId}: ${message.type}`);
|
|
20
|
+
// Route message based on type
|
|
21
|
+
if (this.isClientMessage(message)) {
|
|
22
|
+
this.handleClientMessage(clientId, message);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
catch (err) {
|
|
26
|
+
(0, logger_1.error)(`Failed to parse message from ${clientId}: ${err.message}`);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
isClientMessage(message) {
|
|
30
|
+
return message.type.startsWith('client:');
|
|
31
|
+
}
|
|
32
|
+
handleClientMessage(clientId, message) {
|
|
33
|
+
switch (message.type) {
|
|
34
|
+
case 'client:connect':
|
|
35
|
+
this.handleConnect(clientId, message);
|
|
36
|
+
break;
|
|
37
|
+
case 'client:status':
|
|
38
|
+
(0, logger_1.log)(`Client ${clientId} status: ${message.status}`);
|
|
39
|
+
break;
|
|
40
|
+
case 'client:log':
|
|
41
|
+
// Forward to logs service
|
|
42
|
+
break;
|
|
43
|
+
case 'client:heartbeat':
|
|
44
|
+
// Update last activity
|
|
45
|
+
break;
|
|
46
|
+
case 'client:disconnect':
|
|
47
|
+
this.handleDisconnect(clientId, message);
|
|
48
|
+
break;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
handleConnect(clientId, message) {
|
|
52
|
+
(0, logger_1.log)(`Client connecting with session: ${message.sessionId}`);
|
|
53
|
+
// Send connected confirmation
|
|
54
|
+
const response = {
|
|
55
|
+
type: 'core:connected',
|
|
56
|
+
timestamp: Date.now(),
|
|
57
|
+
sessionId: message.sessionId,
|
|
58
|
+
projectName: 'DemoProject', // In real implementation, get from session
|
|
59
|
+
};
|
|
60
|
+
this.connectionManager.sendToClient(clientId, response);
|
|
61
|
+
// Trigger initial build for the client
|
|
62
|
+
if (this.onClientConnected) {
|
|
63
|
+
(0, logger_1.log)(`Triggering initial build for session: ${message.sessionId}`);
|
|
64
|
+
this.onClientConnected(message.sessionId);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
handleDisconnect(clientId, message) {
|
|
68
|
+
(0, logger_1.log)(`Client disconnecting: ${message.reason || 'No reason provided'}`);
|
|
69
|
+
}
|
|
70
|
+
// Send build notifications
|
|
71
|
+
sendBuildStart(sessionId) {
|
|
72
|
+
const message = {
|
|
73
|
+
type: 'core:build-start',
|
|
74
|
+
timestamp: Date.now(),
|
|
75
|
+
sessionId,
|
|
76
|
+
};
|
|
77
|
+
this.connectionManager.broadcast(message);
|
|
78
|
+
}
|
|
79
|
+
sendBuildComplete(sessionId, apkUrl) {
|
|
80
|
+
const message = {
|
|
81
|
+
type: 'core:build-complete',
|
|
82
|
+
timestamp: Date.now(),
|
|
83
|
+
sessionId,
|
|
84
|
+
apkInfo: {
|
|
85
|
+
path: '/path/to/app.apk',
|
|
86
|
+
size: 5242880,
|
|
87
|
+
hash: 'abc123',
|
|
88
|
+
versionCode: 1,
|
|
89
|
+
versionName: '1.0.0',
|
|
90
|
+
minSdkVersion: 24,
|
|
91
|
+
targetSdkVersion: 34,
|
|
92
|
+
applicationId: 'com.example.app',
|
|
93
|
+
},
|
|
94
|
+
downloadUrl: apkUrl,
|
|
95
|
+
};
|
|
96
|
+
this.connectionManager.broadcast(message);
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
* Send UI update (DSL-based hot reload)
|
|
100
|
+
*/
|
|
101
|
+
sendUIUpdate(sessionId, dslContent, screens) {
|
|
102
|
+
const message = {
|
|
103
|
+
type: 'core:ui-update',
|
|
104
|
+
timestamp: Date.now(),
|
|
105
|
+
sessionId,
|
|
106
|
+
dslContent,
|
|
107
|
+
screens,
|
|
108
|
+
hash: this.generateHash(dslContent),
|
|
109
|
+
};
|
|
110
|
+
(0, logger_1.log)(`Sending UI update: ${dslContent.length} bytes`);
|
|
111
|
+
(0, logger_1.log)(`DSL Content: ${dslContent}`);
|
|
112
|
+
this.connectionManager.broadcast(message);
|
|
113
|
+
}
|
|
114
|
+
generateHash(content) {
|
|
115
|
+
// Simple hash for caching (in production, use crypto.createHash)
|
|
116
|
+
let hash = 0;
|
|
117
|
+
for (let i = 0; i < content.length; i++) {
|
|
118
|
+
const char = content.charCodeAt(i);
|
|
119
|
+
hash = ((hash << 5) - hash) + char;
|
|
120
|
+
hash = hash & hash; // Convert to 32bit integer
|
|
121
|
+
}
|
|
122
|
+
return hash.toString(16);
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
exports.WebSocketHandler = WebSocketHandler;
|
|
126
|
+
//# sourceMappingURL=handler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handler.js","sourceRoot":"","sources":["../../src/websocket/handler.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* WebSocket Server
|
|
3
|
+
* Real-time communication with clients
|
|
4
|
+
*/
|
|
5
|
+
import { WebSocketServer } from 'ws';
|
|
6
|
+
import { Server } from 'http';
|
|
7
|
+
import { WebSocketHandler } from './handler';
|
|
8
|
+
export interface WebSocketConfig {
|
|
9
|
+
port: number;
|
|
10
|
+
server?: Server;
|
|
11
|
+
onClientConnected?: (sessionId: string) => void;
|
|
12
|
+
}
|
|
13
|
+
export interface WebSocketServerResult {
|
|
14
|
+
server: WebSocketServer;
|
|
15
|
+
handler: WebSocketHandler;
|
|
16
|
+
}
|
|
17
|
+
export declare function createWebSocketServer(config: WebSocketConfig): Promise<WebSocketServerResult>;
|
|
18
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/websocket/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,eAAe,EAAa,MAAM,IAAI,CAAC;AAChD,OAAO,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AAC9B,OAAO,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAI7C,MAAM,WAAW,eAAe;IAC9B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,iBAAiB,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAC;CACjD;AAED,MAAM,WAAW,qBAAqB;IACpC,MAAM,EAAE,eAAe,CAAC;IACxB,OAAO,EAAE,gBAAgB,CAAC;CAC3B;AAED,wBAAsB,qBAAqB,CAAC,MAAM,EAAE,eAAe,GAAG,OAAO,CAAC,qBAAqB,CAAC,CAiCnG"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* WebSocket Server
|
|
4
|
+
* Real-time communication with clients
|
|
5
|
+
*/
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.createWebSocketServer = createWebSocketServer;
|
|
8
|
+
const ws_1 = require("ws");
|
|
9
|
+
const handler_1 = require("./handler");
|
|
10
|
+
const manager_1 = require("./manager");
|
|
11
|
+
const logger_1 = require("../utils/logger");
|
|
12
|
+
async function createWebSocketServer(config) {
|
|
13
|
+
const wss = new ws_1.WebSocketServer({
|
|
14
|
+
port: config.port,
|
|
15
|
+
});
|
|
16
|
+
const connectionManager = new manager_1.ConnectionManager();
|
|
17
|
+
const handler = new handler_1.WebSocketHandler(connectionManager, {
|
|
18
|
+
onClientConnected: config.onClientConnected,
|
|
19
|
+
});
|
|
20
|
+
wss.on('connection', (ws, _request) => {
|
|
21
|
+
const clientId = connectionManager.addConnection(ws);
|
|
22
|
+
(0, logger_1.log)(`WebSocket client connected: ${clientId}`);
|
|
23
|
+
// Handle messages
|
|
24
|
+
ws.on('message', (data) => {
|
|
25
|
+
handler.handleMessage(clientId, data);
|
|
26
|
+
});
|
|
27
|
+
// Handle disconnection
|
|
28
|
+
ws.on('close', () => {
|
|
29
|
+
(0, logger_1.log)(`WebSocket client disconnected: ${clientId}`);
|
|
30
|
+
connectionManager.removeConnection(clientId);
|
|
31
|
+
});
|
|
32
|
+
// Handle errors
|
|
33
|
+
ws.on('error', (err) => {
|
|
34
|
+
console.error(`WebSocket error for ${clientId}:`, err.message);
|
|
35
|
+
});
|
|
36
|
+
});
|
|
37
|
+
(0, logger_1.log)(`WebSocket server listening on port ${config.port}`);
|
|
38
|
+
return { server: wss, handler };
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/websocket/index.ts"],"names":[],"mappings":";AAAA;;;GAGG;;AAmBH,sDAiCC;AAlDD,2BAAgD;AAEhD,uCAA6C;AAC7C,uCAA8C;AAC9C,4CAAsC;AAa/B,KAAK,UAAU,qBAAqB,CAAC,MAAuB;IACjE,MAAM,GAAG,GAAG,IAAI,oBAAe,CAAC;QAC9B,IAAI,EAAE,MAAM,CAAC,IAAI;KAClB,CAAC,CAAC;IAEH,MAAM,iBAAiB,GAAG,IAAI,2BAAiB,EAAE,CAAC;IAClD,MAAM,OAAO,GAAG,IAAI,0BAAgB,CAAC,iBAAiB,EAAE;QACtD,iBAAiB,EAAE,MAAM,CAAC,iBAAiB;KAC5C,CAAC,CAAC;IAEH,GAAG,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC,EAAa,EAAE,QAAQ,EAAE,EAAE;QAC/C,MAAM,QAAQ,GAAG,iBAAiB,CAAC,aAAa,CAAC,EAAE,CAAC,CAAC;QACrD,IAAA,YAAG,EAAC,+BAA+B,QAAQ,EAAE,CAAC,CAAC;QAE/C,kBAAkB;QAClB,EAAE,CAAC,EAAE,CAAC,SAAS,EAAE,CAAC,IAAY,EAAE,EAAE;YAChC,OAAO,CAAC,aAAa,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;QACxC,CAAC,CAAC,CAAC;QAEH,uBAAuB;QACvB,EAAE,CAAC,EAAE,CAAC,OAAO,EAAE,GAAG,EAAE;YAClB,IAAA,YAAG,EAAC,kCAAkC,QAAQ,EAAE,CAAC,CAAC;YAClD,iBAAiB,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;QAC/C,CAAC,CAAC,CAAC;QAEH,gBAAgB;QAChB,EAAE,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,GAAU,EAAE,EAAE;YAC5B,OAAO,CAAC,KAAK,CAAC,uBAAuB,QAAQ,GAAG,EAAE,GAAG,CAAC,OAAO,CAAC,CAAC;QACjE,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAA,YAAG,EAAC,sCAAsC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC;IACzD,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,OAAO,EAAE,CAAC;AAClC,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Connection Manager
|
|
3
|
+
* Manages WebSocket connections
|
|
4
|
+
*/
|
|
5
|
+
import { WebSocket } from 'ws';
|
|
6
|
+
import { CoreMessage } from '@jetstart/shared';
|
|
7
|
+
export declare class ConnectionManager {
|
|
8
|
+
private connections;
|
|
9
|
+
addConnection(ws: WebSocket): string;
|
|
10
|
+
removeConnection(id: string): void;
|
|
11
|
+
getConnection(id: string): WebSocket | undefined;
|
|
12
|
+
sendToClient(clientId: string, message: CoreMessage): boolean;
|
|
13
|
+
broadcast(message: CoreMessage): void;
|
|
14
|
+
getConnectionCount(): number;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=manager.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"manager.d.ts","sourceRoot":"","sources":["../../src/websocket/manager.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,SAAS,EAAE,MAAM,IAAI,CAAC;AAE/B,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAE/C,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,WAAW,CAAqC;IAExD,aAAa,CAAC,EAAE,EAAE,SAAS,GAAG,MAAM;IAMpC,gBAAgB,CAAC,EAAE,EAAE,MAAM,GAAG,IAAI;IAIlC,aAAa,CAAC,EAAE,EAAE,MAAM,GAAG,SAAS,GAAG,SAAS;IAIhD,YAAY,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,WAAW,GAAG,OAAO;IAgB7D,SAAS,CAAC,OAAO,EAAE,WAAW,GAAG,IAAI;IAiBrC,kBAAkB,IAAI,MAAM;CAG7B"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Connection Manager
|
|
4
|
+
* Manages WebSocket connections
|
|
5
|
+
*/
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.ConnectionManager = void 0;
|
|
8
|
+
const ws_1 = require("ws");
|
|
9
|
+
const uuid_1 = require("uuid");
|
|
10
|
+
class ConnectionManager {
|
|
11
|
+
connections = new Map();
|
|
12
|
+
addConnection(ws) {
|
|
13
|
+
const id = (0, uuid_1.v4)();
|
|
14
|
+
this.connections.set(id, ws);
|
|
15
|
+
return id;
|
|
16
|
+
}
|
|
17
|
+
removeConnection(id) {
|
|
18
|
+
this.connections.delete(id);
|
|
19
|
+
}
|
|
20
|
+
getConnection(id) {
|
|
21
|
+
return this.connections.get(id);
|
|
22
|
+
}
|
|
23
|
+
sendToClient(clientId, message) {
|
|
24
|
+
const ws = this.connections.get(clientId);
|
|
25
|
+
if (!ws || ws.readyState !== ws_1.WebSocket.OPEN) {
|
|
26
|
+
return false;
|
|
27
|
+
}
|
|
28
|
+
try {
|
|
29
|
+
ws.send(JSON.stringify(message));
|
|
30
|
+
return true;
|
|
31
|
+
}
|
|
32
|
+
catch (err) {
|
|
33
|
+
console.error(`Failed to send message to ${clientId}:`, err);
|
|
34
|
+
return false;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
broadcast(message) {
|
|
38
|
+
const data = JSON.stringify(message);
|
|
39
|
+
const connectionCount = Array.from(this.connections.values()).filter(ws => ws.readyState === ws_1.WebSocket.OPEN).length;
|
|
40
|
+
console.log(`[ConnectionManager] Broadcasting ${message.type} to ${connectionCount} connected clients`);
|
|
41
|
+
this.connections.forEach((ws, clientId) => {
|
|
42
|
+
if (ws.readyState === ws_1.WebSocket.OPEN) {
|
|
43
|
+
try {
|
|
44
|
+
ws.send(data);
|
|
45
|
+
console.log(`[ConnectionManager] Sent ${message.type} to client ${clientId}`);
|
|
46
|
+
}
|
|
47
|
+
catch (err) {
|
|
48
|
+
console.error(`Failed to broadcast to ${clientId}:`, err);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
getConnectionCount() {
|
|
54
|
+
return this.connections.size;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
exports.ConnectionManager = ConnectionManager;
|
|
58
|
+
//# sourceMappingURL=manager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"manager.js","sourceRoot":"","sources":["../../src/websocket/manager.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;AAEH,2BAA+B;AAC/B,+BAAoC;AAGpC,MAAa,iBAAiB;IACpB,WAAW,GAA2B,IAAI,GAAG,EAAE,CAAC;IAExD,aAAa,CAAC,EAAa;QACzB,MAAM,EAAE,GAAG,IAAA,SAAM,GAAE,CAAC;QACpB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;QAC7B,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,gBAAgB,CAAC,EAAU;QACzB,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IAC9B,CAAC;IAED,aAAa,CAAC,EAAU;QACtB,OAAO,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAClC,CAAC;IAED,YAAY,CAAC,QAAgB,EAAE,OAAoB;QACjD,MAAM,EAAE,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAE1C,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,UAAU,KAAK,cAAS,CAAC,IAAI,EAAE,CAAC;YAC5C,OAAO,KAAK,CAAC;QACf,CAAC;QAED,IAAI,CAAC;YACH,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC;YACjC,OAAO,IAAI,CAAC;QACd,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,CAAC,KAAK,CAAC,6BAA6B,QAAQ,GAAG,EAAE,GAAG,CAAC,CAAC;YAC7D,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAED,SAAS,CAAC,OAAoB;QAC5B,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QACrC,MAAM,eAAe,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,UAAU,KAAK,cAAS,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC;QACpH,OAAO,CAAC,GAAG,CAAC,oCAAoC,OAAO,CAAC,IAAI,OAAO,eAAe,oBAAoB,CAAC,CAAC;QAExG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,QAAQ,EAAE,EAAE;YACxC,IAAI,EAAE,CAAC,UAAU,KAAK,cAAS,CAAC,IAAI,EAAE,CAAC;gBACrC,IAAI,CAAC;oBACH,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBACd,OAAO,CAAC,GAAG,CAAC,4BAA4B,OAAO,CAAC,IAAI,cAAc,QAAQ,EAAE,CAAC,CAAC;gBAChF,CAAC;gBAAC,OAAO,GAAG,EAAE,CAAC;oBACb,OAAO,CAAC,KAAK,CAAC,0BAA0B,QAAQ,GAAG,EAAE,GAAG,CAAC,CAAC;gBAC5D,CAAC;YACH,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,kBAAkB;QAChB,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;IAC/B,CAAC;CACF;AArDD,8CAqDC"}
|
package/package.json
ADDED
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@jetstart/core",
|
|
3
|
+
"version": "1.1.1",
|
|
4
|
+
"description": "Build server and orchestration for JetStart",
|
|
5
|
+
"main": "dist/index.js",
|
|
6
|
+
"types": "dist/index.d.ts",
|
|
7
|
+
"scripts": {
|
|
8
|
+
"build": "tsc",
|
|
9
|
+
"dev": "tsc --watch",
|
|
10
|
+
"start": "node dist/index.js",
|
|
11
|
+
"start:dev": "ts-node src/index.ts",
|
|
12
|
+
"clean": "rm -rf dist",
|
|
13
|
+
"test": "jest",
|
|
14
|
+
"test:watch": "jest --watch",
|
|
15
|
+
"test:coverage": "jest --coverage",
|
|
16
|
+
"typecheck": "tsc --noEmit"
|
|
17
|
+
},
|
|
18
|
+
"keywords": [
|
|
19
|
+
"jetstart",
|
|
20
|
+
"core",
|
|
21
|
+
"build-server",
|
|
22
|
+
"websocket"
|
|
23
|
+
],
|
|
24
|
+
"author": "Phantom",
|
|
25
|
+
"license": "MIT",
|
|
26
|
+
"repository": {
|
|
27
|
+
"type": "git",
|
|
28
|
+
"url": "https://github.com/dev-phantom/jetstart.git",
|
|
29
|
+
"directory": "packages/core"
|
|
30
|
+
},
|
|
31
|
+
"bugs": {
|
|
32
|
+
"url": "https://github.com/dev-phantom/jetstart/issues"
|
|
33
|
+
},
|
|
34
|
+
"homepage": "https://github.com/dev-phantom/jetstart#readme",
|
|
35
|
+
"dependencies": {
|
|
36
|
+
"@jetstart/shared": "file:../shared",
|
|
37
|
+
"express": "^4.18.2",
|
|
38
|
+
"ws": "^8.14.2",
|
|
39
|
+
"chokidar": "^3.5.3",
|
|
40
|
+
"qrcode": "^1.5.3",
|
|
41
|
+
"uuid": "^9.0.1",
|
|
42
|
+
"cors": "^2.8.5",
|
|
43
|
+
"dotenv": "^16.3.1",
|
|
44
|
+
"chalk": "^4.1.2"
|
|
45
|
+
},
|
|
46
|
+
"devDependencies": {
|
|
47
|
+
"@types/express": "^4.17.21",
|
|
48
|
+
"@types/ws": "^8.5.10",
|
|
49
|
+
"@types/qrcode": "^1.5.5",
|
|
50
|
+
"@types/uuid": "^9.0.7",
|
|
51
|
+
"@types/cors": "^2.8.17",
|
|
52
|
+
"@types/node": "^20.10.0",
|
|
53
|
+
"@types/jest": "^29.5.0",
|
|
54
|
+
"jest": "^29.5.0",
|
|
55
|
+
"ts-jest": "^29.1.0",
|
|
56
|
+
"ts-node": "^10.9.2",
|
|
57
|
+
"typescript": "^5.3.0"
|
|
58
|
+
},
|
|
59
|
+
"engines": {
|
|
60
|
+
"node": ">=18.0.0",
|
|
61
|
+
"npm": ">=9.0.0"
|
|
62
|
+
},
|
|
63
|
+
"jest": {
|
|
64
|
+
"preset": "ts-jest",
|
|
65
|
+
"testEnvironment": "node",
|
|
66
|
+
"roots": [
|
|
67
|
+
"<rootDir>/tests"
|
|
68
|
+
],
|
|
69
|
+
"testMatch": [
|
|
70
|
+
"**/*.test.ts"
|
|
71
|
+
],
|
|
72
|
+
"collectCoverageFrom": [
|
|
73
|
+
"src/**/*.ts",
|
|
74
|
+
"!src/**/*.d.ts",
|
|
75
|
+
"!src/**/index.ts"
|
|
76
|
+
]
|
|
77
|
+
}
|
|
78
|
+
}
|