@aiqa/sdk 0.0.0 → 0.0.2

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.
@@ -0,0 +1,302 @@
1
+ // src/shared.ts
2
+ import { io } from "socket.io-client";
3
+
4
+ // src/types.ts
5
+ var Methods = /* @__PURE__ */ ((Methods2) => {
6
+ Methods2["AUTHENTICATE"] = "AUTHENTICATE";
7
+ Methods2["GET_FACTS"] = "GET_FACTS";
8
+ Methods2["START_RECORDING"] = "START_RECORDING";
9
+ Methods2["STOP_RECORDING"] = "STOP_RECORDING";
10
+ Methods2["IS_RECORDING"] = "IS_RECORDING";
11
+ Methods2["ADD_FACT"] = "ADD_FACT";
12
+ return Methods2;
13
+ })(Methods || {});
14
+ var FactAnswerFormatType = /* @__PURE__ */ ((FactAnswerFormatType2) => {
15
+ FactAnswerFormatType2["string"] = "STRING";
16
+ FactAnswerFormatType2["number"] = "NUMBER";
17
+ FactAnswerFormatType2["integer"] = "INT";
18
+ FactAnswerFormatType2["float"] = "FLOAT";
19
+ FactAnswerFormatType2["bool"] = "BOOL";
20
+ FactAnswerFormatType2["list"] = "LIST";
21
+ FactAnswerFormatType2["strict"] = "STRICT";
22
+ FactAnswerFormatType2["single_choice"] = "SINGLE_CHOICE";
23
+ FactAnswerFormatType2["multiple_choices"] = "MULTIPLE_CHOICES";
24
+ return FactAnswerFormatType2;
25
+ })(FactAnswerFormatType || {});
26
+ var IAiqaSdk = class {
27
+ };
28
+
29
+ // package.json
30
+ var package_default = {
31
+ name: "@aiqa/sdk",
32
+ version: "0.0.2",
33
+ main: "dist/node/node.js",
34
+ module: "dist/node/node.js",
35
+ types: "dist/node/node.d.ts",
36
+ scripts: {
37
+ build: "tsup",
38
+ "dev:node": "tsx src/node.ts",
39
+ "start:node": "node dist/node/node.js",
40
+ "serve:browser": "serve .",
41
+ test: "jest"
42
+ },
43
+ exports: {
44
+ ".": {
45
+ node: {
46
+ import: "./dist/node/node.js",
47
+ types: "./dist/node/node.d.ts"
48
+ },
49
+ browser: {
50
+ import: "./dist/browser/browser.js",
51
+ types: "./dist/browser/browser.d.ts"
52
+ },
53
+ default: "./dist/node/node.js"
54
+ }
55
+ },
56
+ private: false,
57
+ license: "MIT",
58
+ author: "AIQA",
59
+ description: "TypeScript/JavaScript SDK for interacting with the AIQA.",
60
+ keywords: [
61
+ "aiqa",
62
+ "sdk"
63
+ ],
64
+ files: [
65
+ "dist"
66
+ ],
67
+ devDependencies: {
68
+ "@jest/globals": "^29.7.0",
69
+ esbuild: "^0.23.0",
70
+ jest: "^29.7.0",
71
+ "socket.io": "^4.7.5",
72
+ "ts-jest": "^29.2.3",
73
+ "ts-node": "^10.9.2",
74
+ "@types/node": "^22.0.0",
75
+ serve: "^14.2.3",
76
+ tsup: "^8.0.0",
77
+ tsx: "^4.0.0",
78
+ typescript: "^5.7.0"
79
+ },
80
+ dependencies: {
81
+ "socket.io-client": "^4.7.5"
82
+ }
83
+ };
84
+
85
+ // src/shared.ts
86
+ var SDK_VERSION = package_default.version ?? "0.0.1";
87
+ var DEFAULT_URL = "ws://localhost:3025/ws";
88
+ var DEFAULT_TIMEOUT_MS = 1e4;
89
+ var AiQaSdk = class {
90
+ constructor(applicationId, applicationSecret, url) {
91
+ this.socket = null;
92
+ this.url = url ?? DEFAULT_URL;
93
+ this.internalListeners = /* @__PURE__ */ new Map();
94
+ this.internalEvents = /* @__PURE__ */ new Set(["authenticated"]);
95
+ if (applicationId && applicationSecret) {
96
+ this.applicationId = applicationId;
97
+ this.applicationSecretKey = applicationSecret;
98
+ } else {
99
+ throw new Error("Application id and application secret are required");
100
+ }
101
+ }
102
+ on(name, callback) {
103
+ if (this.internalEvents.has(name)) {
104
+ if (!this.internalListeners.has(name)) {
105
+ this.internalListeners.set(name, /* @__PURE__ */ new Set());
106
+ }
107
+ this.internalListeners.get(name).add(callback);
108
+ return;
109
+ }
110
+ if (!this.socket) {
111
+ throw new Error("Not connected");
112
+ }
113
+ if (this.isManagerEvent(name)) {
114
+ this.socket.io.on(name, callback);
115
+ } else {
116
+ this.socket.on(name, callback);
117
+ }
118
+ }
119
+ off(name, callback) {
120
+ if (this.internalEvents.has(name)) {
121
+ if (!callback) {
122
+ this.internalListeners.delete(name);
123
+ return;
124
+ }
125
+ const handlers = this.internalListeners.get(name);
126
+ if (handlers) {
127
+ handlers.delete(callback);
128
+ if (handlers.size === 0) {
129
+ this.internalListeners.delete(name);
130
+ }
131
+ }
132
+ return;
133
+ }
134
+ if (!this.socket) {
135
+ throw new Error("Not connected");
136
+ }
137
+ if (this.isManagerEvent(name)) {
138
+ this.socket.io.off(name, callback);
139
+ } else {
140
+ this.socket.off(name, callback);
141
+ }
142
+ }
143
+ connect() {
144
+ if (!this.url) {
145
+ return;
146
+ }
147
+ const url = new URL(this.url);
148
+ const socketOptions = {
149
+ reconnectionDelayMax: 1e4,
150
+ path: url.pathname
151
+ };
152
+ this.socket = io(url.origin, socketOptions);
153
+ this.socket.on("connect", () => {
154
+ this.authenticate();
155
+ });
156
+ this.socket.on("app_version", (payload) => {
157
+ let versionRange = payload;
158
+ if (typeof payload === "string") {
159
+ try {
160
+ versionRange = JSON.parse(payload);
161
+ } catch (error) {
162
+ versionRange = payload;
163
+ }
164
+ }
165
+ const minVersion = versionRange?.min;
166
+ const maxVersion = versionRange?.max;
167
+ if (minVersion || maxVersion) {
168
+ const tooLow = minVersion ? this.compareVersions(SDK_VERSION, minVersion) < 0 : false;
169
+ const tooHigh = maxVersion ? this.compareVersions(SDK_VERSION, maxVersion) > 0 : false;
170
+ if (tooLow || tooHigh) {
171
+ const error = new Error(
172
+ `SDK version ${SDK_VERSION} is not supported. Supported range: ${minVersion || "-"} to ${maxVersion || "-"}.`
173
+ );
174
+ this.socket.disconnect();
175
+ this.socket.emit("error", error);
176
+ }
177
+ }
178
+ });
179
+ }
180
+ disconnect() {
181
+ if (this.socket) {
182
+ this.socket.disconnect();
183
+ }
184
+ }
185
+ sendMessage(method, data) {
186
+ return new Promise((resolve, reject) => {
187
+ if (!this.socket || !this.socket.connected) {
188
+ reject(new Error("Socket is not connected"));
189
+ return;
190
+ }
191
+ const requestId = this.createRequestId();
192
+ let timeout;
193
+ const handler = (payload2) => {
194
+ if (timeout) {
195
+ clearTimeout(timeout);
196
+ }
197
+ this.socket.off(requestId, handler);
198
+ let parsed = payload2;
199
+ if (typeof payload2 === "string") {
200
+ try {
201
+ parsed = JSON.parse(payload2);
202
+ } catch (error) {
203
+ parsed = payload2;
204
+ }
205
+ }
206
+ if (parsed && parsed.error !== void 0) {
207
+ reject(parsed.error);
208
+ return;
209
+ }
210
+ resolve(parsed && parsed.data !== void 0 ? parsed.data : parsed);
211
+ };
212
+ this.socket.on(requestId, handler);
213
+ const payload = data && typeof data === "object" ? { ...data, requestId } : { requestId, data };
214
+ this.socket.emit(method, JSON.stringify(payload));
215
+ timeout = setTimeout(() => {
216
+ this.socket.off(requestId, handler);
217
+ reject(new Error(`Request timed out for ${method}`));
218
+ }, DEFAULT_TIMEOUT_MS);
219
+ });
220
+ }
221
+ async getApplication() {
222
+ if (this.cachedApplication) {
223
+ return this.cachedApplication;
224
+ }
225
+ throw new Error("Application is not available yet. Wait for authentication to complete.");
226
+ }
227
+ async getFacts() {
228
+ const result = await this.sendMessage("GET_FACTS" /* GET_FACTS */);
229
+ return result && result.data !== void 0 ? result.data : result;
230
+ }
231
+ async addFact(fact) {
232
+ const payload = {
233
+ ...fact,
234
+ critical: fact.critical ?? false,
235
+ is_skipped: fact.is_skipped ?? false
236
+ };
237
+ const result = await this.sendMessage("ADD_FACT" /* ADD_FACT */, payload);
238
+ return result && result.data !== void 0 ? result.data : result;
239
+ }
240
+ async authenticate() {
241
+ try {
242
+ const result = await this.sendMessage("AUTHENTICATE" /* AUTHENTICATE */, {
243
+ applicationId: this.applicationId,
244
+ applicationSecretKey: this.applicationSecretKey
245
+ });
246
+ const application = result && result.data !== void 0 ? result.data : result;
247
+ this.cachedApplication = application;
248
+ this.emitInternal("authenticated", application);
249
+ } catch (error) {
250
+ this.socket.emit("error", error);
251
+ }
252
+ }
253
+ async startRecording() {
254
+ const result = await this.sendMessage("START_RECORDING" /* START_RECORDING */);
255
+ return result && result.data !== void 0 ? result.data : result;
256
+ }
257
+ async stopRecording() {
258
+ const result = await this.sendMessage("STOP_RECORDING" /* STOP_RECORDING */);
259
+ return result && result.data !== void 0 ? result.data : result;
260
+ }
261
+ async isRecordingNow() {
262
+ const result = await this.sendMessage("IS_RECORDING" /* IS_RECORDING */);
263
+ return result && result.data !== void 0 ? result.data : result;
264
+ }
265
+ compareVersions(left, right) {
266
+ const leftParts = left.split(".").map((part) => Number(part));
267
+ const rightParts = right.split(".").map((part) => Number(part));
268
+ const maxLength = Math.max(leftParts.length, rightParts.length);
269
+ for (let i = 0; i < maxLength; i += 1) {
270
+ const l = leftParts[i] ?? 0;
271
+ const r = rightParts[i] ?? 0;
272
+ if (l > r) {
273
+ return 1;
274
+ }
275
+ if (l < r) {
276
+ return -1;
277
+ }
278
+ }
279
+ return 0;
280
+ }
281
+ emitInternal(name, ...args) {
282
+ const handlers = this.internalListeners.get(name);
283
+ if (!handlers) {
284
+ return;
285
+ }
286
+ handlers.forEach((handler) => handler(...args));
287
+ }
288
+ createRequestId() {
289
+ return `req_${Date.now().toString(36)}_${Math.random().toString(36).slice(2, 10)}`;
290
+ }
291
+ isManagerEvent(name) {
292
+ return name === "reconnect_attempt" || name === "reconnect_error" || name === "reconnect_failed" || name === "error";
293
+ }
294
+ };
295
+ var shared_default = AiQaSdk;
296
+ export {
297
+ shared_default as AiQaSdk,
298
+ FactAnswerFormatType,
299
+ IAiqaSdk,
300
+ Methods
301
+ };
302
+ //# sourceMappingURL=node.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/shared.ts","../../src/types.ts","../../package.json"],"sourcesContent":["import { io, Socket } from \"socket.io-client\";\nimport { Methods, Application, ApplicationFact, ApplicationFactInput, FactIsMatched, SdkEvent, IAiqaSdk } from \"./types.js\";\n// @ts-ignore - compiled builds resolve this at build time\nimport pkg from \"../package.json\";\n\nconst SDK_VERSION = (pkg as { version?: string }).version ?? '0.0.1';\nconst DEFAULT_URL = 'ws://localhost:3025/ws';\nconst DEFAULT_TIMEOUT_MS = 10000;\n\nclass AiQaSdk implements IAiqaSdk {\n socket: Socket | null = null;\n url: string;\n applicationId: string;\n applicationSecretKey: string;\n cachedApplication?: Application;\n internalListeners: Map<SdkEvent, Set<(...args: any[]) => void>>;\n internalEvents: Set<SdkEvent>;\n\n constructor(applicationId: string, applicationSecret: string, url?: string) {\n this.url = url ?? DEFAULT_URL;\n this.internalListeners = new Map();\n this.internalEvents = new Set(['authenticated']);\n\n if (applicationId && applicationSecret) {\n this.applicationId = applicationId;\n this.applicationSecretKey = applicationSecret;\n } else {\n throw new Error('Application id and application secret are required');\n }\n }\n\n on(name: SdkEvent, callback: (...args: any[]) => any) {\n if (this.internalEvents.has(name)) {\n if (!this.internalListeners.has(name)) {\n this.internalListeners.set(name, new Set());\n }\n this.internalListeners.get(name)!.add(callback);\n return;\n }\n\n if (!this.socket) {\n throw new Error('Not connected');\n }\n\n if (this.isManagerEvent(name)) {\n this.socket.io.on(name, callback);\n } else {\n this.socket.on(name, callback);\n }\n }\n\n off(name: SdkEvent, callback?: (...args: any[]) => any) {\n if (this.internalEvents.has(name)) {\n if (!callback) {\n this.internalListeners.delete(name);\n return;\n }\n const handlers = this.internalListeners.get(name);\n if (handlers) {\n handlers.delete(callback);\n if (handlers.size === 0) {\n this.internalListeners.delete(name);\n }\n }\n return;\n }\n\n if (!this.socket) {\n throw new Error('Not connected');\n }\n\n if (this.isManagerEvent(name)) {\n this.socket.io.off(name, callback);\n } else {\n this.socket.off(name, callback);\n }\n }\n\n connect() {\n if (!this.url) {\n return;\n }\n\n const url = new URL(this.url);\n\n const socketOptions: any = {\n reconnectionDelayMax: 10000,\n path: url.pathname,\n };\n\n this.socket = io(url.origin, socketOptions);\n\n this.socket.on('connect', () => {\n this.authenticate();\n });\n\n this.socket.on('app_version', (payload: any) => {\n let versionRange = payload;\n if (typeof payload === 'string') {\n try {\n versionRange = JSON.parse(payload);\n } catch (error) {\n versionRange = payload;\n }\n }\n\n const minVersion = versionRange?.min;\n const maxVersion = versionRange?.max;\n\n if (minVersion || maxVersion) {\n const tooLow = minVersion ? this.compareVersions(SDK_VERSION, minVersion) < 0 : false;\n const tooHigh = maxVersion ? this.compareVersions(SDK_VERSION, maxVersion) > 0 : false;\n if (tooLow || tooHigh) {\n const error = new Error(\n `SDK version ${SDK_VERSION} is not supported. Supported range: ${minVersion || '-'} to ${maxVersion || '-'}.`\n );\n this.socket!.disconnect();\n this.socket!.emit('error', error);\n }\n }\n });\n }\n\n disconnect() {\n if (this.socket) {\n this.socket.disconnect();\n }\n }\n\n sendMessage(method: Methods, data?: any): Promise<any> {\n return new Promise((resolve, reject) => {\n if (!this.socket || !this.socket.connected) {\n reject(new Error('Socket is not connected'));\n return;\n }\n\n const requestId = this.createRequestId();\n let timeout: ReturnType<typeof setTimeout> | undefined;\n const handler = (payload: any) => {\n if (timeout) {\n clearTimeout(timeout);\n }\n this.socket!.off(requestId, handler);\n let parsed = payload;\n if (typeof payload === 'string') {\n try {\n parsed = JSON.parse(payload);\n } catch (error) {\n parsed = payload;\n }\n }\n\n if (parsed && parsed.error !== undefined) {\n reject(parsed.error);\n return;\n }\n\n resolve(parsed && parsed.data !== undefined ? parsed.data : parsed);\n };\n\n this.socket.on(requestId, handler);\n\n const payload = data && typeof data === 'object' ? { ...data, requestId } : { requestId, data };\n this.socket.emit(method, JSON.stringify(payload));\n\n timeout = setTimeout(() => {\n this.socket!.off(requestId, handler);\n reject(new Error(`Request timed out for ${method}`));\n }, DEFAULT_TIMEOUT_MS);\n });\n }\n\n async getApplication(): Promise<Application> {\n if (this.cachedApplication) {\n return this.cachedApplication;\n }\n throw new Error('Application is not available yet. Wait for authentication to complete.');\n }\n\n async getFacts(): Promise<ApplicationFact[]> {\n const result = await this.sendMessage(Methods.GET_FACTS);\n return result && result.data !== undefined ? result.data : result;\n }\n\n async addFact(fact: ApplicationFactInput): Promise<FactIsMatched> {\n const payload = {\n ...fact,\n critical: fact.critical ?? false,\n is_skipped: fact.is_skipped ?? false\n };\n const result = await this.sendMessage(Methods.ADD_FACT, payload);\n return result && result.data !== undefined ? result.data : result;\n }\n\n async authenticate(): Promise<void> {\n try {\n const result = await this.sendMessage(Methods.AUTHENTICATE, {\n applicationId: this.applicationId,\n applicationSecretKey: this.applicationSecretKey\n });\n\n const application = result && result.data !== undefined ? result.data : result;\n\n this.cachedApplication = application;\n\n this.emitInternal('authenticated', application);\n } catch (error) {\n this.socket!.emit('error', error);\n }\n }\n\n async startRecording(): Promise<boolean> {\n const result = await this.sendMessage(Methods.START_RECORDING);\n return result && result.data !== undefined ? result.data : result;\n }\n\n async stopRecording(): Promise<boolean> {\n const result = await this.sendMessage(Methods.STOP_RECORDING);\n return result && result.data !== undefined ? result.data : result;\n }\n\n async isRecordingNow(): Promise<boolean> {\n // @TODO: track it from the server, should be sent on successfull connect\n const result = await this.sendMessage(Methods.IS_RECORDING);\n return result && result.data !== undefined ? result.data : result;\n }\n\n compareVersions(left: string, right: string): number {\n const leftParts = left.split('.').map((part) => Number(part));\n const rightParts = right.split('.').map((part) => Number(part));\n const maxLength = Math.max(leftParts.length, rightParts.length);\n\n for (let i = 0; i < maxLength; i += 1) {\n const l = leftParts[i] ?? 0;\n const r = rightParts[i] ?? 0;\n if (l > r) {\n return 1;\n }\n if (l < r) {\n return -1;\n }\n }\n\n return 0;\n }\n\n private emitInternal(name: SdkEvent, ...args: any[]) {\n const handlers = this.internalListeners.get(name);\n if (!handlers) {\n return;\n }\n handlers.forEach((handler) => handler(...args));\n }\n\n private createRequestId() {\n return `req_${Date.now().toString(36)}_${Math.random().toString(36).slice(2, 10)}`;\n }\n\n private isManagerEvent(name: SdkEvent) {\n return name === 'reconnect_attempt' || name === 'reconnect_error' || name === 'reconnect_failed' || name === 'error';\n }\n}\n\nexport default AiQaSdk;\n","export type Application = {\n application_id: string;\n client_name: string;\n client_phone_number: string;\n agent_id: string;\n agent_first_name: string;\n agent_last_name: string;\n}\n\nexport enum Methods {\n AUTHENTICATE = \"AUTHENTICATE\",\n GET_FACTS = \"GET_FACTS\",\n START_RECORDING = \"START_RECORDING\",\n STOP_RECORDING = \"STOP_RECORDING\",\n IS_RECORDING = \"IS_RECORDING\",\n ADD_FACT = \"ADD_FACT\"\n}\n\nexport type SdkEvent =\n | Methods\n | 'connect'\n | 'disconnect'\n | 'close'\n | 'error'\n | 'reconnect_attempt'\n | 'reconnect_error'\n | 'reconnect_failed'\n | 'authenticated'\n | 'app_version';\n\nexport enum FactAnswerFormatType {\n string = 'STRING',\n number = 'NUMBER',\n integer = 'INT',\n float = 'FLOAT',\n bool = 'BOOL',\n list = 'LIST',\n strict = 'STRICT',\n single_choice = 'SINGLE_CHOICE',\n multiple_choices = 'MULTIPLE_CHOICES',\n}\n\nexport type ApplicationFactAnswerChoice = {\n key: string;\n text: string;\n}\n\nexport type ApplicationFactAnswerFormat = {\n type: FactAnswerFormatType;\n choices?: ApplicationFactAnswerChoice[];\n}\n\nexport type ApplicationFactInput = {\n id: string;\n question: string;\n expected_answer: any;\n answer_format: ApplicationFactAnswerFormat;\n\n category_id?: string;\n category_name?: string;\n language?: string;\n\n critical?: boolean;\n is_skipped?: boolean;\n}\n\nexport type QuestionStatus = 'searching' | 'asked' | 'not_asked';\n\nexport type VerificationStatus = 'processing' | 'matched' | 'unmatched';\n\nexport type ApplicationFact = ApplicationFactInput & {\n ai_answer?: any;\n question_status: QuestionStatus;\n verification_status: VerificationStatus;\n}\n\nexport type FactIsMatched = boolean;\n\nexport type SdkError = {\n code:\n | 'INVALID_CONFIG'\n | 'CONNECTION_ERROR'\n | 'TIMEOUT'\n | 'SERVER_ERROR'\n | 'UNEXPECTED_RESPONSE';\n message: string;\n details?: any;\n}\n\n\nexport abstract class IAiqaSdk {\n abstract connect(): void;\n abstract disconnect(): void;\n\n abstract on(eventName: string, callback: (...args: any[]) => any): void;\n abstract off(eventName: string): void;\n\n abstract getApplication(): Promise<Application>;\n abstract addFact(fact: ApplicationFactInput): Promise<FactIsMatched>;\n abstract getFacts(): Promise<ApplicationFact[]>;\n}\n","{\n \"name\": \"@aiqa/sdk\",\n \"version\": \"0.0.2\",\n \"main\": \"dist/node/node.js\",\n \"module\": \"dist/node/node.js\",\n \"types\": \"dist/node/node.d.ts\",\n \"scripts\": {\n \"build\": \"tsup\",\n \"dev:node\": \"tsx src/node.ts\",\n \"start:node\": \"node dist/node/node.js\",\n \"serve:browser\": \"serve .\",\n \"test\": \"jest\"\n },\n \"exports\": {\n \".\": {\n \"node\": {\n \"import\": \"./dist/node/node.js\",\n \"types\": \"./dist/node/node.d.ts\"\n },\n \"browser\": {\n \"import\": \"./dist/browser/browser.js\",\n \"types\": \"./dist/browser/browser.d.ts\"\n },\n \"default\": \"./dist/node/node.js\"\n }\n },\n \"private\": false,\n \"license\": \"MIT\",\n \"author\": \"AIQA\",\n \"description\": \"TypeScript/JavaScript SDK for interacting with the AIQA.\",\n \"keywords\": [\n \"aiqa\",\n \"sdk\"\n ],\n \"files\": [\n \"dist\"\n ],\n \"devDependencies\": {\n \"@jest/globals\": \"^29.7.0\",\n \"esbuild\": \"^0.23.0\",\n \"jest\": \"^29.7.0\",\n \"socket.io\": \"^4.7.5\",\n \"ts-jest\": \"^29.2.3\",\n \"ts-node\": \"^10.9.2\",\n \"@types/node\": \"^22.0.0\",\n \"serve\": \"^14.2.3\",\n \"tsup\": \"^8.0.0\",\n \"tsx\": \"^4.0.0\",\n \"typescript\": \"^5.7.0\"\n },\n \"dependencies\": {\n \"socket.io-client\": \"^4.7.5\"\n }\n}"],"mappings":"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","names":["Methods","FactAnswerFormatType","payload"]}
package/package.json CHANGED
@@ -1,24 +1,55 @@
1
1
  {
2
2
  "name": "@aiqa/sdk",
3
- "version": "0.0.0",
4
- "main": "build/index.js",
5
- "private": false,
6
- "license": "MIT",
3
+ "version": "0.0.2",
4
+ "main": "dist/node/node.js",
5
+ "module": "dist/node/node.js",
6
+ "types": "dist/node/node.d.ts",
7
+ "engines": { "node": ">=18" },
7
8
  "scripts": {
8
- "build": "node build-sdk.js"
9
+ "build": "tsup",
10
+ "dev:node": "tsx src/node.ts",
11
+ "start:node": "node dist/node/node.js",
12
+ "serve:browser": "serve .",
13
+ "test": "jest"
9
14
  },
10
- "author": "",
11
- "description": "",
15
+ "exports": {
16
+ ".": {
17
+ "node": {
18
+ "import": "./dist/node/node.js",
19
+ "types": "./dist/node/node.d.ts"
20
+ },
21
+ "browser": {
22
+ "import": "./dist/browser/browser.js",
23
+ "types": "./dist/browser/browser.d.ts"
24
+ },
25
+ "default": "./dist/node/node.js"
26
+ }
27
+ },
28
+ "private": false,
29
+ "license": "MIT",
30
+ "author": "AIQA",
31
+ "description": "TypeScript/JavaScript SDK for interacting with the AIQA.",
32
+ "keywords": [
33
+ "aiqa",
34
+ "sdk"
35
+ ],
36
+ "files": [
37
+ "dist"
38
+ ],
12
39
  "devDependencies": {
13
40
  "@jest/globals": "^29.7.0",
14
- "@types/node": "^22.0.0",
41
+ "esbuild": "^0.23.0",
15
42
  "jest": "^29.7.0",
16
43
  "socket.io": "^4.7.5",
17
44
  "ts-jest": "^29.2.3",
18
45
  "ts-node": "^10.9.2",
19
- "typescript": "^5.5.4"
46
+ "@types/node": "^22.0.0",
47
+ "serve": "^14.2.3",
48
+ "tsup": "^8.0.0",
49
+ "tsx": "^4.0.0",
50
+ "typescript": "^5.7.0"
20
51
  },
21
52
  "dependencies": {
22
53
  "socket.io-client": "^4.7.5"
23
54
  }
24
- }
55
+ }
@@ -1,20 +0,0 @@
1
- {
2
- // Use IntelliSense to learn about possible attributes.
3
- // Hover to view descriptions of existing attributes.
4
- // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
5
- "version": "0.2.0",
6
- "configurations": [
7
- {
8
- "type": "node",
9
- "request": "launch",
10
- "name": "Launch Program",
11
- "skipFiles": [
12
- "<node_internals>/**"
13
- ],
14
- "program": "${workspaceFolder}/build/index.js",
15
- "outFiles": [
16
- "${workspaceFolder}/**/*.js"
17
- ]
18
- }
19
- ]
20
- }
package/build/sdk.js DELETED
@@ -1,37 +0,0 @@
1
- // Build script for AiQA SDK
2
- // Run with: node build-sdk.js
3
- // Uses global 'io' from socket.io-client CDN loaded in index.html
4
-
5
- const { execSync } = require('child_process');
6
- const path = require('path');
7
- const fs = require('fs');
8
-
9
- try {
10
- console.log('Building SDK...');
11
- // Bundle SDK, marking socket.io-client as external since we use window.io from CDN
12
- execSync(`npx esbuild sdk-src/index.ts --bundle --format=iife --global-name=AiQaSdk --platform=browser --target=es2020 --external:socket.io-client --outfile=sdk.js`, {
13
- cwd: __dirname,
14
- stdio: 'inherit'
15
- });
16
-
17
- // Fix the export - replace the module wrapper with direct class export
18
- const sdkPath = path.join(__dirname, 'sdk.js');
19
- let sdkContent = fs.readFileSync(sdkPath, 'utf8');
20
-
21
- // Replace the IIFE that returns a module with one that returns the class directly
22
- // Find the pattern: var AiQaSdk = (() => { ... return __toCommonJS(index_exports); })();
23
- // And replace with: var AiQaSdk = (() => { ... return index_default; })();
24
- sdkContent = sdkContent.replace(
25
- /return __toCommonJS\(index_exports\);\s*\}\)\(\);/,
26
- 'return index_default;\n})();'
27
- );
28
-
29
- fs.writeFileSync(sdkPath, sdkContent);
30
-
31
- console.log('SDK built successfully!');
32
- console.log('Note: socket.io-client must be loaded via CDN before sdk.js (already done in index.html)');
33
- } catch (error) {
34
- console.error('Build failed:', error.message);
35
- process.exit(1);
36
- }
37
-
package/index.js DELETED
@@ -1,3 +0,0 @@
1
- var aaa = require('./build/index')
2
-
3
- module.exports = aaa
package/jest.config.js DELETED
@@ -1,7 +0,0 @@
1
- /** @type {import('ts-jest').JestConfigWithTsJest} **/
2
- module.exports = {
3
- testEnvironment: "node",
4
- transform: {
5
- "^.+.tsx?$": ["ts-jest",{}],
6
- },
7
- };