scoundrel-remote-eval 1.0.19 → 1.0.20

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/README.md CHANGED
@@ -25,7 +25,7 @@ const client = new Client(clientWebSocket)
25
25
 
26
26
  const math = await client.import("math")
27
27
  const pi = await math.readAttributeWithReference("pi")
28
- const cosOfPi = await math.callMethodWithReference("cos", pi)
28
+ const cosOfPi = await math.callMethod("cos", {returnReference: true}, pi)
29
29
  const result = await cosOfPi.serialize()
30
30
 
31
31
  expect(result).toEqual(-1)
@@ -34,6 +34,44 @@ client.close()
34
34
  pythonWebSocketRunner.close()
35
35
  ```
36
36
 
37
+ ## Client and reference examples
38
+
39
+ Create remote objects, call methods, and fetch attributes:
40
+
41
+ ```js
42
+ const arrayRef = await client.newObjectWithReference("Array")
43
+ await arrayRef.callMethod("push", "one", "two")
44
+ const joined = await arrayRef.callMethod("join", ", ")
45
+ expect(joined).toEqual("one, two")
46
+
47
+ const lengthRef = await arrayRef.callMethod("push", {returnReference: true}, "three")
48
+ const length = await lengthRef.serialize()
49
+ expect(length).toEqual(3)
50
+ ```
51
+
52
+ Read attributes directly or as references:
53
+
54
+ ```js
55
+ const math = await client.import("math")
56
+ const piRef = await math.readAttributeWithReference("pi")
57
+ const pi = await piRef.serialize()
58
+
59
+ const e = await math.readAttribute("E")
60
+ expect([pi, e].every((value) => typeof value === "number")).toEqual(true)
61
+ ```
62
+
63
+ Fetch globally available or registered objects:
64
+
65
+ ```js
66
+ client.registerObject("config", {mode: "test"})
67
+
68
+ const configRef = await client.getObject("config")
69
+ const config = await configRef.serialize()
70
+ expect(config).toEqual({mode: "test"})
71
+
72
+ client.unregisterObject("config")
73
+ ```
74
+
37
75
  ## Serialization
38
76
 
39
77
  `Reference#serialize()` only supports JSON-safe values (strings, numbers, booleans, null, plain objects, and arrays). It throws an error if the value contains functions, symbols, bigints, class instances/non-plain objects, circular references, non-finite numbers, or other unsupported types.
@@ -82,7 +120,13 @@ const client = new Client(clientWebSocket, {enableServerControl: false})
82
120
  // equivalent to: new Client(clientWebSocket)
83
121
  ```
84
122
 
85
- Registered objects and classes are available inside `evalWithReference`:
123
+ You can also enable it after construction:
124
+
125
+ ```js
126
+ client.enableServerControl()
127
+ ```
128
+
129
+ Registered objects and classes are available inside `eval`:
86
130
 
87
131
  ```js
88
132
  const client = new Client(clientWebSocket, {enableServerControl: true})
@@ -101,15 +145,28 @@ client.registerClass("TestGreeter", TestGreeter)
101
145
  client.registerObject("testSettings", {prefix: "Hello"})
102
146
 
103
147
  const serverClient = server.getClients()[0] // from your ScoundrelServer instance
104
- const greetingRef = await serverClient.evalWithReference("(() => { const greeter = new TestGreeter(testSettings.prefix); return greeter.greet('World') })()")
148
+ const greetingRef = await serverClient.eval("(() => { const greeter = new TestGreeter(testSettings.prefix); return greeter.greet('World') })()")
105
149
  const greeting = await greetingRef.serialize()
106
150
 
107
151
  expect(greeting).toEqual("Hello World")
108
152
  ```
109
153
 
110
- You can unregister classes or objects to remove them from server-side lookups and `evalWithReference` scope:
154
+ You can unregister classes or objects to remove them from server-side lookups and `eval` scope:
111
155
 
112
156
  ```js
113
157
  client.unregisterClass("TestGreeter")
114
158
  client.unregisterObject("testSettings")
115
159
  ```
160
+
161
+ `eval` defaults to returning a reference, but you can request the raw result:
162
+
163
+ ```js
164
+ const result = await serverClient.eval({returnResult: true}, "(() => 1 + 1)()")
165
+ expect(result).toEqual(2)
166
+ ```
167
+
168
+ Use `eval` with `returnReference` if you need to be explicit:
169
+
170
+ ```js
171
+ const greetingRef = await serverClient.eval({returnReference: true}, "(() => { return 'Hello' })()")
172
+ ```
@@ -1,3 +1,8 @@
1
+ /**
2
+ * @typedef {{returnReference?: boolean, returnResult?: boolean}} ReturnOptions
3
+ * @typedef {ReturnOptions & {returnResult?: false}} ReturnReferenceOptions
4
+ * @typedef {ReturnOptions & {returnResult: true, returnReference?: false}} ReturnResultOptions
5
+ */
1
6
  export default class Client {
2
7
  /**
3
8
  * Creates a new Scoundrel Client
@@ -29,12 +34,33 @@ export default class Client {
29
34
  close(): Promise<void>;
30
35
  /**
31
36
  * Calls a method on a reference and returns the result directly
37
+ * @overload
32
38
  * @param {number} referenceId Reference identifier
33
39
  * @param {string} methodName Method name to invoke
34
40
  * @param {...any} args Arguments to pass to the method
35
41
  * @returns {Promise<any>} Result from the method call
36
42
  */
37
43
  callMethodOnReference(referenceId: number, methodName: string, ...args: any[]): Promise<any>;
44
+ /**
45
+ * Calls a method on a reference and returns a new reference
46
+ * @overload
47
+ * @param {number} referenceId Reference identifier
48
+ * @param {string} methodName Method name to invoke
49
+ * @param {ReturnReferenceOptions} options Options for the call
50
+ * @param {...any} args Arguments to pass to the method
51
+ * @returns {Promise<Reference>} Reference to the returned value
52
+ */
53
+ callMethodOnReference(referenceId: number, methodName: string, options: ReturnReferenceOptions, ...args: any[]): Promise<Reference>;
54
+ /**
55
+ * Calls a method on a reference and returns the result directly
56
+ * @overload
57
+ * @param {number} referenceId Reference identifier
58
+ * @param {string} methodName Method name to invoke
59
+ * @param {ReturnResultOptions} options Options for the call
60
+ * @param {...any} args Arguments to pass to the method
61
+ * @returns {Promise<any>} Result from the method call
62
+ */
63
+ callMethodOnReference(referenceId: number, methodName: string, options: ReturnResultOptions, ...args: any[]): Promise<any>;
38
64
  /**
39
65
  * Calls a method on a reference and returns a new reference
40
66
  * @param {number} referenceId Reference identifier
@@ -43,6 +69,29 @@ export default class Client {
43
69
  * @returns {Promise<Reference>} Reference to the return value
44
70
  */
45
71
  callMethodOnReferenceWithReference(referenceId: number, methodName: string, ...args: any[]): Promise<Reference>;
72
+ /**
73
+ * Evaluates a string and returns a reference or result
74
+ * @overload
75
+ * @param {string} evalString Code to evaluate
76
+ * @returns {Promise<Reference>} Reference to the evaluated value
77
+ */
78
+ eval(evalString: string): Promise<Reference>;
79
+ /**
80
+ * Evaluates a string and returns a reference or result
81
+ * @overload
82
+ * @param {ReturnReferenceOptions} options Eval options
83
+ * @param {string} evalString Code to evaluate
84
+ * @returns {Promise<Reference>} Reference to the evaluated value
85
+ */
86
+ eval(options: ReturnReferenceOptions, evalString: string): Promise<Reference>;
87
+ /**
88
+ * Evaluates a string and returns a reference or result
89
+ * @overload
90
+ * @param {ReturnResultOptions} options Eval options
91
+ * @param {string} evalString Code to evaluate
92
+ * @returns {Promise<any>} Evaluated result
93
+ */
94
+ eval(options: ReturnResultOptions, evalString: string): Promise<any>;
46
95
  /**
47
96
  * Evaluates a string and returns a new reference
48
97
  * @param {string} evalString Code to evaluate
@@ -182,5 +231,16 @@ export default class Client {
182
231
  spawnReference(id: string): Reference;
183
232
  enableServerControl(): void;
184
233
  }
234
+ export type ReturnOptions = {
235
+ returnReference?: boolean;
236
+ returnResult?: boolean;
237
+ };
238
+ export type ReturnReferenceOptions = ReturnOptions & {
239
+ returnResult?: false;
240
+ };
241
+ export type ReturnResultOptions = ReturnOptions & {
242
+ returnResult: true;
243
+ returnReference?: false;
244
+ };
185
245
  import Reference from "./reference.js";
186
246
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/client/index.js"],"names":[],"mappings":"AAUA;IACE;;;;OAIG;IACH,qBAHW,GAAG,YACH;QAAC,mBAAmB,CAAC,EAAE,OAAO,CAAA;KAAC,EA2BzC;IAxBC,aAAsB;IAGtB,kCAAkC;IAClC,kBADW,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CACJ;IAC1B,qBAA0B;IAC1B,8BAA8B;IAE9B,kCAAkC;IAClC,UADW,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CACZ;IAElB,kCAAkC;IAClC,UADW,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CACZ;IAElB,wCAAwC;IACxC,YADW,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAChB;IAEpB,kCAAkC;IAClC,SADW,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CACb;IAEjB,qBAAqB;IAErB,sBAAsB;IACtB,sBADW,OAAO,CAC8C;IAGlE;;OAEG;IACH,uBAEC;IAED;;;;;;OAMG;IACH,mCALW,MAAM,cACN,MAAM,WACF,GAAG,EAAA,GACL,OAAO,CAAC,GAAG,CAAC,CAWxB;IAED;;;;;;OAMG;IACH,gDALW,MAAM,cACN,MAAM,WACF,GAAG,EAAA,GACL,OAAO,CAAC,SAAS,CAAC,CAY9B;IAED;;;;OAIG;IACH,8BAHW,MAAM,GACJ,OAAO,CAAC,SAAS,CAAC,CAe9B;IAED;;;;OAIG;IACH,mBAHW,MAAM,GACJ,OAAO,CAAC,SAAS,CAAC,CAe9B;IAED;;;;OAIG;IACH,sBAHW,MAAM,GACJ,OAAO,CAAC,SAAS,CAAC,CAY9B;IAED;;;;;OAKG;IACH,kCAJW,MAAM,WACF,GAAG,EAAA,GACL,OAAO,CAAC,SAAS,CAAC,CAe9B;IAED;;;;OAIG;IACH,qBAHW,GAAG,GACD,OAAO,CAQnB;IAED;;;;;;;;OAQG;IACH,YAAa,0EANV;QAAqB,OAAO,EAApB,MAAM;QACO,UAAU,EAAvB,MAAM;QACI,IAAI,EAAd,GAAG;QACW,KAAK,GAAnB,MAAM;QACQ,UAAU,GAAxB,MAAM;KAEkE,UAuPlF;IAED;;;;OAIG;IACH,cAHW,GAAG,GACD,GAAG,CAwBf;IAED;;;;;OAKG;IACH,mDAJW,MAAM,iBACN,MAAM,GACJ,OAAO,CAAC,SAAS,CAAC,CAW9B;IAED;;;;;OAKG;IACH,sCAJW,MAAM,iBACN,MAAM,GACJ,OAAO,CAAC,GAAG,CAAC,CASxB;IAED;;;;OAIG;IACH,yBAHW,MAAM,iBACN,GAAG,QAMb;IAED;;;OAGG;IACH,2BAFW,MAAM,QAMhB;IAED;;;;OAIG;IACH,+BAHW,MAAM,GACJ,GAAG,CAIf;IAED;;;;OAIG;IACH,oBAHW,MAAM,GACJ,GAAG,CAIf;IAED;;;;OAIG;IACH,2BAHW,MAAM,kBACN,GAAG,QAMb;IAED;;;OAGG;IACH,6BAFW,MAAM,QAMhB;IAED;;;;OAIG;IACH,iCAHW,MAAM,GACJ,GAAG,CAIf;IAED;;;;OAIG;IACH,4BAHW,MAAM,QACN,GAAG,QAIb;IAED;;;;;OAKG;IACH,qBAJW,MAAM,QACN,GAAG,GACD,OAAO,CAAC,GAAG,CAAC,CAkBxB;IAED;;;OAGG;IACH,WAFW,GAAG,QAIb;IAED;;;;OAIG;IACH,gCAHW,MAAM,GACJ,OAAO,CAAC,GAAG,CAAC,CAMxB;IAED;;;;OAIG;IACH,mBAHW,MAAM,GACJ,SAAS,CAQrB;IAED,4BAEC;CACF;sBAvnBqB,gBAAgB"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/client/index.js"],"names":[],"mappings":"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"}
@@ -4,6 +4,11 @@ import Reference from "./reference.js";
4
4
  import safeJSONStringify from "../utils/safe-json-stringify.js";
5
5
  const logger = new Logger("Scoundrel Client");
6
6
  // logger.setDebug(true)
7
+ /**
8
+ * @typedef {{returnReference?: boolean, returnResult?: boolean}} ReturnOptions
9
+ * @typedef {ReturnOptions & {returnResult?: false}} ReturnReferenceOptions
10
+ * @typedef {ReturnOptions & {returnResult: true, returnReference?: false}} ReturnResultOptions
11
+ */
7
12
  export default class Client {
8
13
  /**
9
14
  * Creates a new Scoundrel Client
@@ -285,18 +290,85 @@ export default class Client {
285
290
  }
286
291
  /**
287
292
  * Calls a method on a reference and returns the result directly
293
+ * @overload
288
294
  * @param {number} referenceId Reference identifier
289
295
  * @param {string} methodName Method name to invoke
290
296
  * @param {...any} args Arguments to pass to the method
291
297
  * @returns {Promise<any>} Result from the method call
292
298
  */
293
- async callMethodOnReference(referenceId, methodName, ...args) {
299
+ /**
300
+ * Calls a method on a reference and returns a new reference
301
+ * @overload
302
+ * @param {number} referenceId Reference identifier
303
+ * @param {string} methodName Method name to invoke
304
+ * @param {ReturnReferenceOptions} options Options for the call
305
+ * @param {...any} args Arguments to pass to the method
306
+ * @returns {Promise<Reference>} Reference to the returned value
307
+ */
308
+ /**
309
+ * Calls a method on a reference and returns the result directly
310
+ * @overload
311
+ * @param {number} referenceId Reference identifier
312
+ * @param {string} methodName Method name to invoke
313
+ * @param {ReturnResultOptions} options Options for the call
314
+ * @param {...any} args Arguments to pass to the method
315
+ * @returns {Promise<any>} Result from the method call
316
+ */
317
+ /**
318
+ * Calls a method on a reference and returns the result directly
319
+ * @param {number} referenceId Reference identifier
320
+ * @param {string} methodName Method name to invoke
321
+ * @param {ReturnOptions | any} [optionsOrArg] Options for the call or first argument
322
+ * @param {...any} args Arguments to pass to the method
323
+ * @returns {Promise<Reference | any>} Result or reference from the method call
324
+ */
325
+ async callMethodOnReference(referenceId, methodName, optionsOrArg, ...args) {
326
+ const allowedOptions = new Set(["returnReference", "returnResult"]);
327
+ /** @type {ReturnOptions | undefined} */
328
+ let options;
329
+ /** @type {any[]} */
330
+ let methodArgs;
331
+ if (typeof optionsOrArg === "undefined") {
332
+ methodArgs = [];
333
+ }
334
+ else if (this.isPlainObject(optionsOrArg)) {
335
+ const optionKeys = Object.keys(optionsOrArg);
336
+ const hasOptionKey = optionKeys.some((key) => allowedOptions.has(key));
337
+ if (hasOptionKey) {
338
+ const unknownOptions = optionKeys.filter((key) => !allowedOptions.has(key));
339
+ if (unknownOptions.length > 0) {
340
+ throw new Error(`Unknown callMethodOnReference options: ${unknownOptions.join(", ")}`);
341
+ }
342
+ options = /** @type {ReturnOptions} */ (optionsOrArg);
343
+ methodArgs = args;
344
+ }
345
+ else {
346
+ methodArgs = [optionsOrArg, ...args];
347
+ }
348
+ }
349
+ else {
350
+ methodArgs = [optionsOrArg, ...args];
351
+ }
352
+ const returnReference = options?.returnReference === true;
353
+ const returnResult = options?.returnResult === true;
354
+ if (returnReference && returnResult) {
355
+ throw new Error("callMethodOnReference options returnReference and returnResult cannot both be true");
356
+ }
357
+ const withReference = returnReference;
294
358
  const result = await this.sendCommand("call_method_on_reference", {
295
- args: this.parseArg(args),
359
+ args: this.parseArg(methodArgs),
296
360
  method_name: methodName,
297
361
  reference_id: referenceId,
298
- with: "result"
362
+ with: withReference ? "reference" : "result"
299
363
  });
364
+ if (!result)
365
+ throw new Error("Blank result given");
366
+ if (withReference) {
367
+ const objectId = result.response;
368
+ if (!objectId)
369
+ throw new Error(`No object ID given in result: ${JSON.stringify(result)}`);
370
+ return this.spawnReference(objectId);
371
+ }
300
372
  return result.response;
301
373
  }
302
374
  /**
@@ -307,31 +379,87 @@ export default class Client {
307
379
  * @returns {Promise<Reference>} Reference to the return value
308
380
  */
309
381
  async callMethodOnReferenceWithReference(referenceId, methodName, ...args) {
310
- const result = await this.sendCommand("call_method_on_reference", {
311
- args: this.parseArg(args),
312
- method_name: methodName,
313
- reference_id: referenceId,
314
- with: "reference"
315
- });
316
- const id = result.response;
317
- return this.spawnReference(id);
382
+ console.warn("Scoundrel Client", "callMethodOnReferenceWithReference is deprecated; use callMethodOnReference with returnReference instead.");
383
+ return this.callMethodOnReference(referenceId, methodName, { returnReference: true }, ...args);
318
384
  }
319
385
  /**
320
- * Evaluates a string and returns a new reference
386
+ * Evaluates a string and returns a reference or result
387
+ * @overload
321
388
  * @param {string} evalString Code to evaluate
322
389
  * @returns {Promise<Reference>} Reference to the evaluated value
323
390
  */
324
- async evalWithReference(evalString) {
391
+ /**
392
+ * Evaluates a string and returns a reference or result
393
+ * @overload
394
+ * @param {ReturnReferenceOptions} options Eval options
395
+ * @param {string} evalString Code to evaluate
396
+ * @returns {Promise<Reference>} Reference to the evaluated value
397
+ */
398
+ /**
399
+ * Evaluates a string and returns a reference or result
400
+ * @overload
401
+ * @param {ReturnResultOptions} options Eval options
402
+ * @param {string} evalString Code to evaluate
403
+ * @returns {Promise<any>} Evaluated result
404
+ */
405
+ /**
406
+ * Evaluates a string and returns a reference or result
407
+ * @param {string | ReturnOptions} optionsOrEvalString Options or code to evaluate
408
+ * @param {string} [evalString] Code to evaluate
409
+ * @returns {Promise<Reference | any>} Reference or evaluated result
410
+ */
411
+ async eval(optionsOrEvalString, evalString) {
412
+ const allowedOptions = new Set(["returnReference", "returnResult"]);
413
+ /** @type {ReturnOptions} */
414
+ let options = {};
415
+ /** @type {string | undefined} */
416
+ let targetEvalString = evalString;
417
+ if (typeof evalString === "undefined") {
418
+ if (this.isPlainObject(optionsOrEvalString)) {
419
+ throw new Error("eval requires an eval string when options are provided");
420
+ }
421
+ targetEvalString = /** @type {string} */ (optionsOrEvalString);
422
+ }
423
+ else {
424
+ options = /** @type {ReturnOptions} */ (optionsOrEvalString ?? {});
425
+ if (!this.isPlainObject(options)) {
426
+ throw new Error("eval options must be a plain object");
427
+ }
428
+ }
429
+ const unknownOptions = Object.keys(options).filter((key) => !allowedOptions.has(key));
430
+ if (unknownOptions.length > 0) {
431
+ throw new Error(`Unknown eval options: ${unknownOptions.join(", ")}`);
432
+ }
433
+ const returnReference = options.returnReference === true;
434
+ const returnResult = options.returnResult === true;
435
+ if (returnReference && returnResult) {
436
+ throw new Error("eval options returnReference and returnResult cannot both be true");
437
+ }
438
+ const withReference = returnReference || !returnResult;
325
439
  const result = await this.sendCommand("eval", {
326
- eval_string: evalString,
327
- with_reference: true
440
+ eval_string: targetEvalString,
441
+ with_reference: withReference
328
442
  });
329
443
  if (!result)
330
444
  throw new Error("Blank result given");
331
- const objectId = result.object_id;
332
- if (!objectId)
333
- throw new Error(`No object ID given in result: ${JSON.stringify(result)}`);
334
- return this.spawnReference(objectId);
445
+ if (withReference) {
446
+ const objectId = result.object_id;
447
+ if (!objectId)
448
+ throw new Error(`No object ID given in result: ${JSON.stringify(result)}`);
449
+ return this.spawnReference(objectId);
450
+ }
451
+ if (!("response" in result))
452
+ throw new Error(`No response given in result: ${JSON.stringify(result)}`);
453
+ return result.response;
454
+ }
455
+ /**
456
+ * Evaluates a string and returns a new reference
457
+ * @param {string} evalString Code to evaluate
458
+ * @returns {Promise<Reference>} Reference to the evaluated value
459
+ */
460
+ async evalWithReference(evalString) {
461
+ console.warn("Scoundrel Client", "evalWithReference is deprecated; use eval instead.");
462
+ return this.eval({ returnReference: true }, evalString);
335
463
  }
336
464
  /**
337
465
  * Imports a module and returns a reference to it
@@ -571,4 +699,4 @@ export default class Client {
571
699
  this.serverControlEnabled = true;
572
700
  }
573
701
  }
574
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/client/index.js"],"names":[],"mappings":"AAAA,YAAY;AAEZ,OAAO,MAAM,MAAM,cAAc,CAAA;AACjC,OAAO,SAAS,MAAM,gBAAgB,CAAA;AACtC,OAAO,iBAAiB,MAAM,iCAAiC,CAAA;AAE/D,MAAM,MAAM,GAAG,IAAI,MAAM,CAAC,kBAAkB,CAAC,CAAA;AAE7C,wBAAwB;AAExB,MAAM,CAAC,OAAO,OAAO,MAAM;IACzB;;;;OAIG;IACH,YAAY,OAAO,EAAE,OAAO,GAAG,EAAE;QAkKjC;;;;;;;;WAQG;QACH,cAAS,GAAG,CAAC,EAAC,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,UAAU,EAAE,GAAG,QAAQ,EAAC,EAAE,EAAE;YACrF,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,CAAC,WAAW,EAAE,EAAC,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,UAAU,EAAE,QAAQ,EAAC,CAAC,CAAC,CAAA;YAExF,IAAI,CAAC;gBACH,IAAI,CAAC,OAAO,EAAE,CAAC;oBACb,MAAM,IAAI,KAAK,CAAC,iCAAiC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;gBACtF,CAAC;qBAAM,IAAI,OAAO,IAAI,kBAAkB,EAAE,CAAC;oBACzC,IAAI,CAAC,CAAC,SAAS,IAAI,IAAI,CAAC,gBAAgB,CAAC,EAAE,CAAC;wBAC1C,MAAM,IAAI,KAAK,CAAC,oBAAoB,SAAS,eAAe,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;oBAC9G,CAAC;oBAED,MAAM,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAA;oBAErD,OAAO,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAA;oBAEvC,IAAI,KAAK,EAAE,CAAC;wBACV,MAAM,YAAY,GAAG,IAAI,KAAK,CAAC,KAAK,CAAC,CAAA;wBACrC,MAAM,aAAa,GAAG,CAAC,KAAK,EAAE,EAAE;4BAC9B,IAAI,CAAC,KAAK;gCAAE,OAAO,EAAE,CAAA;4BACrB,OAAO,KAAK;iCACT,KAAK,CAAC,IAAI,CAAC;iCACX,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;iCAC1B,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC;iCACtB,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;iCAChD,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;iCAC7C,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,yBAAyB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;iCACvD,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;iCAClD,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAA;wBACjD,CAAC,CAAA;wBAED,MAAM,aAAa,GAAG,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE;4BACrC,MAAM,KAAK,GAAG,aAAa,CAAC,KAAK,CAAC,CAAA;4BAClC,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC;gCAAE,OAAO,EAAE,CAAA;4BACjC,OAAO,CAAC,GAAG,KAAK,IAAI,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAA;wBACpD,CAAC,CAAA;wBAED,MAAM,aAAa,GAAG;4BACpB,UAAU,KAAK,EAAE;4BACjB,GAAG,aAAa,CAAC,qBAAqB,EAAE,UAAU,CAAC;4BACnD,GAAG,aAAa,CAAC,oBAAoB,EAAE,YAAY,CAAC,KAAK,CAAC;4BAC1D,GAAG,aAAa,CAAC,oBAAoB,EAAE,YAAY,CAAC,WAAW,CAAC,CAAC,CAAC,wBAAwB,YAAY,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;yBAC7H,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;wBAEZ,YAAY,CAAC,KAAK,GAAG,aAAa,CAAA;wBAElC,YAAY,CAAC,MAAM,CAAC,YAAY,CAAC,CAAA;oBACnC,CAAC;yBAAM,CAAC;wBACN,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,CAAC,qBAAqB,SAAS,YAAY,EAAE,IAAI,CAAC,CAAC,CAAA;wBACpE,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;oBACjC,CAAC;gBACH,CAAC;qBAAM,IAAI,CAAC,IAAI,CAAC,oBAAoB,EAAE,CAAC;oBACtC,IAAI,CAAC,IAAI,CAAC,EAAC,OAAO,EAAE,kBAAkB,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,4BAA4B,EAAC,CAAC,CAAA;oBACpG,OAAM;gBACR,CAAC;qBAAM,IAAI,OAAO,IAAI,YAAY,EAAE,CAAC;oBACnC,MAAM,YAAY,GAAG,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;oBAChE,MAAM,WAAW,GAAG,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;oBAC9D,IAAI,MAAM,CAAA;oBAEV,IAAI,YAAY,KAAK,SAAS,EAAE,CAAC;wBAC/B,MAAM,GAAG,YAAY,CAAA;oBACvB,CAAC;yBAAM,IAAI,WAAW,KAAK,SAAS,EAAE,CAAC;wBACrC,MAAM,GAAG,WAAW,CAAA;oBACtB,CAAC;yBAAM,CAAC;wBACN,MAAM,GAAG,UAAU,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;wBAErC,IAAI,MAAM,KAAK,SAAS;4BAAE,MAAM,IAAI,KAAK,CAAC,mBAAmB,IAAI,CAAC,WAAW,EAAE,CAAC,CAAA;oBAClF,CAAC;oBAED,MAAM,QAAQ,GAAG,EAAE,IAAI,CAAC,YAAY,CAAA;oBAEpC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,MAAM,CAAA;oBAC/B,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,EAAC,SAAS,EAAE,QAAQ,EAAC,CAAC,CAAA;gBACzD,CAAC;qBAAM,IAAI,OAAO,IAAI,2BAA2B,EAAE,CAAC;oBAClD,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,CAAA;oBACjC,IAAI,MAAM,CAAA;oBAEV,IAAI,OAAO,SAAS,IAAI,QAAQ,EAAE,CAAC;wBACjC,MAAM,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,UAAU,CAAC,SAAS,CAAC,CAAA;wBAEvE,IAAI,CAAC,aAAa;4BAAE,MAAM,IAAI,KAAK,CAAC,kBAAkB,SAAS,EAAE,CAAC,CAAA;wBAElE,MAAM,GAAG,IAAI,aAAa,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAA;oBAC1C,CAAC;yBAAM,CAAC;wBACN,MAAM,IAAI,KAAK,CAAC,wCAAwC,OAAO,SAAS,EAAE,CAAC,CAAA;oBAC7E,CAAC;oBAED,MAAM,QAAQ,GAAG,EAAE,IAAI,CAAC,YAAY,CAAA;oBAEpC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,MAAM,CAAA;oBAC/B,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,EAAC,SAAS,EAAE,QAAQ,EAAC,CAAC,CAAA;gBACzD,CAAC;qBAAM,IAAI,OAAO,IAAI,0BAA0B,EAAE,CAAC;oBACjD,MAAM,WAAW,GAAG,IAAI,CAAC,YAAY,CAAA;oBACrC,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAA;oBAExC,IAAI,CAAC,MAAM;wBAAE,MAAM,IAAI,KAAK,CAAC,yBAAyB,WAAW,EAAE,CAAC,CAAA;oBAEpE,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;oBAEvC,IAAI,CAAC,MAAM;wBAAE,MAAM,IAAI,KAAK,CAAC,qBAAqB,IAAI,CAAC,WAAW,WAAW,MAAM,CAAC,WAAW,CAAC,IAAI,GAAG,CAAC,CAAA;oBAExG,MAAM,gBAAgB,GAAG,CAAC,aAAa,EAAE,EAAE;wBACzC,IAAI,IAAI,CAAC,IAAI,IAAI,WAAW,EAAE,CAAC;4BAC7B,MAAM,QAAQ,GAAG,EAAE,IAAI,CAAC,YAAY,CAAA;4BAEpC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,aAAa,CAAA;4BACtC,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,EAAC,QAAQ,EAAE,QAAQ,EAAC,CAAC,CAAA;wBACxD,CAAC;6BAAM,CAAC;4BACN,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,EAAC,QAAQ,EAAE,aAAa,EAAC,CAAC,CAAA;wBAC7D,CAAC;oBACH,CAAC,CAAA;oBAED,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,CAAA;oBAElD,IAAI,QAAQ,IAAI,OAAO,QAAQ,CAAC,IAAI,IAAI,UAAU,EAAE,CAAC;wBACnD,QAAQ,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,KAAK,CAAC,CAAC,YAAY,EAAE,EAAE;4BACrD,IAAI,YAAY,YAAY,KAAK,EAAE,CAAC;gCAClC,IAAI,CAAC,IAAI,CAAC,EAAC,OAAO,EAAE,kBAAkB,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,YAAY,CAAC,OAAO,EAAE,UAAU,EAAE,YAAY,CAAC,KAAK,EAAC,CAAC,CAAA;4BAC9H,CAAC;iCAAM,CAAC;gCACN,IAAI,CAAC,IAAI,CAAC,EAAC,OAAO,EAAE,kBAAkB,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,CAAC,YAAY,CAAC,EAAC,CAAC,CAAA;4BAC9F,CAAC;wBACH,CAAC,CAAC,CAAA;oBACJ,CAAC;yBAAM,CAAC;wBACN,gBAAgB,CAAC,QAAQ,CAAC,CAAA;oBAC5B,CAAC;gBACH,CAAC;qBAAM,IAAI,OAAO,IAAI,qBAAqB,EAAE,CAAC;oBAC5C,MAAM,WAAW,GAAG,IAAI,CAAC,YAAY,CAAA;oBACrC,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAA;oBAExC,IAAI,CAAC,MAAM;wBAAE,MAAM,IAAI,KAAK,CAAC,yBAAyB,WAAW,EAAE,CAAC,CAAA;oBAEpE,MAAM,UAAU,GAAG,iBAAiB,CAAC,MAAM,CAAC,CAAA;oBAC5C,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,UAAU,CAAC,CAAA;gBAC9C,CAAC;qBAAM,IAAI,OAAO,IAAI,gBAAgB,EAAE,CAAC;oBACvC,MAAM,aAAa,GAAG,IAAI,CAAC,cAAc,CAAA;oBACzC,MAAM,WAAW,GAAG,IAAI,CAAC,YAAY,CAAA;oBACrC,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAA;oBAC5B,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAA;oBAExC,IAAI,CAAC,MAAM;wBAAE,MAAM,IAAI,KAAK,CAAC,yBAAyB,WAAW,EAAE,CAAC,CAAA;oBAEpE,MAAM,SAAS,GAAG,MAAM,CAAC,aAAa,CAAC,CAAA;oBAEvC,IAAI,UAAU,IAAI,WAAW,EAAE,CAAC;wBAC9B,MAAM,QAAQ,GAAG,EAAE,IAAI,CAAC,YAAY,CAAA;wBAEpC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,SAAS,CAAA;wBAClC,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,EAAC,QAAQ,EAAE,QAAQ,EAAC,CAAC,CAAA;oBACxD,CAAC;yBAAM,CAAC;wBACN,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,EAAC,QAAQ,EAAE,SAAS,EAAC,CAAC,CAAA;oBACzD,CAAC;gBACH,CAAC;qBAAM,IAAI,OAAO,IAAI,MAAM,EAAE,CAAC;oBAC7B,MAAM,iBAAiB,GAAG,CAAC,UAAU,EAAE,EAAE;wBACvC,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;4BACxB,MAAM,QAAQ,GAAG,EAAE,IAAI,CAAC,YAAY,CAAA;4BAEpC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,UAAU,CAAA;4BACnC,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,EAAC,SAAS,EAAE,QAAQ,EAAC,CAAC,CAAA;wBACzD,CAAC;6BAAM,CAAC;4BACN,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,EAAC,QAAQ,EAAE,UAAU,EAAC,CAAC,CAAA;wBAC1D,CAAC;oBACH,CAAC,CAAA;oBAED,MAAM,KAAK,GAAG,EAAC,GAAG,IAAI,CAAC,QAAQ,EAAE,GAAG,IAAI,CAAC,QAAQ,EAAC,CAAA;oBAClD,MAAM,mBAAmB,GAAG,IAAI,GAAG,CAAC;wBAClC,OAAO;wBACP,MAAM;wBACN,OAAO;wBACP,OAAO;wBACP,OAAO;wBACP,UAAU;wBACV,UAAU;wBACV,SAAS;wBACT,QAAQ;wBACR,IAAI;wBACJ,MAAM;wBACN,QAAQ;wBACR,SAAS;wBACT,SAAS;wBACT,KAAK;wBACL,UAAU;wBACV,IAAI;wBACJ,QAAQ;wBACR,IAAI;wBACJ,YAAY;wBACZ,KAAK;wBACL,QAAQ;wBACR,OAAO;wBACP,QAAQ;wBACR,MAAM;wBACN,OAAO;wBACP,KAAK;wBACL,QAAQ;wBACR,KAAK;wBACL,MAAM;wBACN,OAAO;wBACP,MAAM;wBACN,OAAO;wBACP,KAAK;wBACL,MAAM;wBACN,OAAO;wBACP,YAAY;wBACZ,SAAS;wBACT,WAAW;wBACX,QAAQ;wBACR,WAAW;wBACX,SAAS;wBACT,QAAQ;wBACR,MAAM;qBACP,CAAC,CAAA;oBAEF,MAAM,iBAAiB,GAAG,CAAC,IAAI,EAAE,EAAE,CACjC,mDAAmD,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;oBAElG,MAAM,SAAS,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;oBACpC,MAAM,WAAW,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC,CAAA;oBAEtE,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;wBAC3B,MAAM,IAAI,KAAK,CAAC,qCAAqC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;oBAChF,CAAC;oBAED,4EAA4E;oBAC5E,MAAM,SAAS,GAAG,IAAI,QAAQ,CAAC,cAAc,EAAE,GAAG,SAAS,EAAE,2BAA2B,CAAC,CAAA;oBACzF,MAAM,UAAU,GAAG,SAAS,CAAC,IAAI,CAAC,WAAW,EAAE,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAA;oBAErF,IAAI,UAAU,IAAI,OAAO,UAAU,CAAC,IAAI,IAAI,UAAU,EAAE,CAAC;wBACvD,UAAU,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,KAAK,CAAC,CAAC,YAAY,EAAE,EAAE;4BACxD,IAAI,YAAY,YAAY,KAAK,EAAE,CAAC;gCAClC,IAAI,CAAC,IAAI,CAAC,EAAC,OAAO,EAAE,kBAAkB,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,YAAY,CAAC,OAAO,EAAE,UAAU,EAAE,YAAY,CAAC,KAAK,EAAC,CAAC,CAAA;4BAC9H,CAAC;iCAAM,CAAC;gCACN,IAAI,CAAC,IAAI,CAAC,EAAC,OAAO,EAAE,kBAAkB,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,CAAC,YAAY,CAAC,EAAC,CAAC,CAAA;4BAC9F,CAAC;wBACH,CAAC,CAAC,CAAA;oBACJ,CAAC;yBAAM,CAAC;wBACN,iBAAiB,CAAC,UAAU,CAAC,CAAA;oBAC/B,CAAC;gBACH,CAAC;qBAAM,CAAC;oBACN,MAAM,IAAI,KAAK,CAAC,oBAAoB,OAAO,EAAE,CAAC,CAAA;gBAChD,CAAC;YACH,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,IAAI,KAAK,YAAY,KAAK,EAAE,CAAC;oBAC3B,IAAI,CAAC,IAAI,CAAC,EAAC,OAAO,EAAE,kBAAkB,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,CAAC,OAAO,EAAE,UAAU,EAAE,KAAK,CAAC,KAAK,EAAC,CAAC,CAAA;gBAChH,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,IAAI,CAAC,EAAC,OAAO,EAAE,kBAAkB,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,CAAC,EAAC,CAAC,CAAA;gBACvF,CAAC;gBAED,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;YACrB,CAAC;QACH,CAAC,CAAA;QAjaC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;QACtB,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;QAEtC,kCAAkC;QAClC,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAA;QAC1B,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAA;QAC1B,IAAI,CAAC,qBAAqB,GAAG,CAAC,CAAA;QAE9B,kCAAkC;QAClC,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAA;QAElB,kCAAkC;QAClC,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAA;QAElB,wCAAwC;QACxC,IAAI,CAAC,UAAU,GAAG,EAAE,CAAA;QAEpB,kCAAkC;QAClC,IAAI,CAAC,OAAO,GAAG,EAAE,CAAA;QAEjB,IAAI,CAAC,YAAY,GAAG,CAAC,CAAA;QAErB,sBAAsB;QACtB,IAAI,CAAC,oBAAoB,GAAG,OAAO,CAAC,OAAO,CAAC,mBAAmB,CAAC,CAAA;IAClE,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,KAAK;QACT,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAA;IACtB,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,qBAAqB,CAAC,WAAW,EAAE,UAAU,EAAE,GAAG,IAAI;QAC1D,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,0BAA0B,EAAE;YAChE,IAAI,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;YACzB,WAAW,EAAE,UAAU;YACvB,YAAY,EAAE,WAAW;YACzB,IAAI,EAAE,QAAQ;SACf,CAAC,CAAA;QAEF,OAAO,MAAM,CAAC,QAAQ,CAAA;IACxB,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,kCAAkC,CAAC,WAAW,EAAE,UAAU,EAAE,GAAG,IAAI;QACvE,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,0BAA0B,EAAE;YAChE,IAAI,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;YACzB,WAAW,EAAE,UAAU;YACvB,YAAY,EAAE,WAAW;YACzB,IAAI,EAAE,WAAW;SAClB,CAAC,CAAA;QACF,MAAM,EAAE,GAAG,MAAM,CAAC,QAAQ,CAAA;QAE1B,OAAO,IAAI,CAAC,cAAc,CAAC,EAAE,CAAC,CAAA;IAChC,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,iBAAiB,CAAC,UAAU;QAChC,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE;YAC5C,WAAW,EAAE,UAAU;YACvB,cAAc,EAAE,IAAI;SACrB,CAAC,CAAA;QAEF,IAAI,CAAC,MAAM;YAAE,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAA;QAElD,MAAM,QAAQ,GAAG,MAAM,CAAC,SAAS,CAAA;QAEjC,IAAI,CAAC,QAAQ;YAAE,MAAM,IAAI,KAAK,CAAC,iCAAiC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,CAAA;QAEzF,OAAO,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAA;IACtC,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,MAAM,CAAC,UAAU;QACrB,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE;YAC9C,WAAW,EAAE,UAAU;SACxB,CAAC,CAAA;QAEF,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,CAAC,QAAQ,EAAE,EAAC,MAAM,EAAC,CAAC,CAAC,CAAA;QAEtC,IAAI,CAAC,MAAM;YAAE,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAA;QAC/C,IAAI,CAAC,MAAM,CAAC,SAAS;YAAE,MAAM,IAAI,KAAK,CAAC,iCAAiC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,CAAA;QAEjG,MAAM,EAAE,GAAG,MAAM,CAAC,SAAS,CAAA;QAE3B,OAAO,IAAI,CAAC,cAAc,CAAC,EAAE,CAAC,CAAA;IAChC,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,SAAS,CAAC,UAAU;QACxB,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,YAAY,EAAE;YAClD,WAAW,EAAE,UAAU;SACxB,CAAC,CAAA;QAEF,IAAI,CAAC,MAAM;YAAE,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAA;QAElD,MAAM,EAAE,GAAG,MAAM,CAAC,SAAS,CAAA;QAE3B,OAAO,IAAI,CAAC,cAAc,CAAC,EAAE,CAAC,CAAA;IAChC,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,sBAAsB,CAAC,SAAS,EAAE,GAAG,IAAI;QAC7C,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,2BAA2B,EAAE;YACjE,IAAI,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;YACzB,UAAU,EAAE,SAAS;SACtB,CAAC,CAAA;QAEF,IAAI,CAAC,MAAM;YAAE,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAA;QAElD,MAAM,EAAE,GAAG,MAAM,CAAC,SAAS,CAAA;QAE3B,IAAI,CAAC,EAAE;YAAE,MAAM,IAAI,KAAK,CAAC,iCAAiC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,CAAA;QAEnF,OAAO,IAAI,CAAC,cAAc,CAAC,EAAE,CAAC,CAAA;IAChC,CAAC;IAED;;;;OAIG;IACH,aAAa,CAAC,KAAK;QACjB,IAAI,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;YAChE,OAAO,IAAI,CAAA;QACb,CAAC;QAED,OAAO,KAAK,CAAA;IACd,CAAC;IAoQD;;;;OAIG;IACH,QAAQ,CAAC,GAAG;QACV,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;YACvB,OAAO,GAAG,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAA;QAC3D,CAAC;aAAM,IAAI,GAAG,YAAY,SAAS,EAAE,CAAC;YACpC,OAAO;gBACL,qBAAqB,EAAE,GAAG,CAAC,EAAE;gBAC7B,gBAAgB,EAAE,WAAW;aAC9B,CAAA;QACH,CAAC;aAAM,IAAI,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,CAAC;YACnC,+BAA+B;YAC/B,MAAM,SAAS,GAAG,EAAE,CAAA;YAEpB,KAAK,MAAM,GAAG,IAAI,GAAG,EAAE,CAAC;gBACtB,MAAM,KAAK,GAAG,GAAG,CAAC,GAAG,CAAC,CAAA;gBAEtB,SAAS,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;YACvC,CAAC;YAED,OAAO,SAAS,CAAA;QAClB,CAAC;QAED,OAAO,GAAG,CAAA;IACZ,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,qCAAqC,CAAC,WAAW,EAAE,aAAa;QACpE,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,gBAAgB,EAAE;YACtD,cAAc,EAAE,aAAa;YAC7B,YAAY,EAAE,WAAW;YACzB,IAAI,EAAE,WAAW;SAClB,CAAC,CAAA;QACF,MAAM,EAAE,GAAG,MAAM,CAAC,QAAQ,CAAA;QAE1B,OAAO,IAAI,CAAC,cAAc,CAAC,EAAE,CAAC,CAAA;IAChC,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,wBAAwB,CAAC,WAAW,EAAE,aAAa;QACvD,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,gBAAgB,EAAE;YACtD,cAAc,EAAE,aAAa;YAC7B,YAAY,EAAE,WAAW;YACzB,IAAI,EAAE,QAAQ;SACf,CAAC,CAAA;QACF,OAAO,MAAM,CAAC,QAAQ,CAAA;IACxB,CAAC;IAED;;;;OAIG;IACH,aAAa,CAAC,SAAS,EAAE,aAAa;QACpC,IAAI,SAAS,IAAI,IAAI,CAAC,QAAQ;YAAE,MAAM,IAAI,KAAK,CAAC,yBAAyB,SAAS,EAAE,CAAC,CAAA;QAErF,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,aAAa,CAAA;IAC1C,CAAC;IAED;;;OAGG;IACH,eAAe,CAAC,SAAS;QACvB,IAAI,CAAC,CAAC,SAAS,IAAI,IAAI,CAAC,QAAQ,CAAC;YAAE,MAAM,IAAI,KAAK,CAAC,yBAAyB,SAAS,EAAE,CAAC,CAAA;QAExF,OAAO,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAA;IACjC,CAAC;IAED;;;;OAIG;IACH,mBAAmB,CAAC,SAAS;QAC3B,OAAO,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAA;IACjC,CAAC;IAED;;;;OAIG;IACH,QAAQ,CAAC,SAAS;QAChB,OAAO,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAA;IACjC,CAAC;IAED;;;;OAIG;IACH,cAAc,CAAC,UAAU,EAAE,cAAc;QACvC,IAAI,UAAU,IAAI,IAAI,CAAC,QAAQ;YAAE,MAAM,IAAI,KAAK,CAAC,0BAA0B,UAAU,EAAE,CAAC,CAAA;QAExF,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,GAAG,cAAc,CAAA;IAC5C,CAAC;IAED;;;OAGG;IACH,gBAAgB,CAAC,UAAU;QACzB,IAAI,CAAC,CAAC,UAAU,IAAI,IAAI,CAAC,QAAQ,CAAC;YAAE,MAAM,IAAI,KAAK,CAAC,0BAA0B,UAAU,EAAE,CAAC,CAAA;QAE3F,OAAO,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAA;IAClC,CAAC;IAED;;;;OAIG;IACH,oBAAoB,CAAC,UAAU;QAC7B,OAAO,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAA;IAClC,CAAC;IAED;;;;OAIG;IACH,gBAAgB,CAAC,SAAS,EAAE,IAAI;QAC9B,IAAI,CAAC,IAAI,CAAC,EAAC,OAAO,EAAE,kBAAkB,EAAE,UAAU,EAAE,SAAS,EAAE,IAAI,EAAE,EAAC,UAAU,EAAE,SAAS,EAAE,IAAI,EAAC,EAAC,CAAC,CAAA;IACtG,CAAC;IAED;;;;;OAKG;IACH,WAAW,CAAC,OAAO,EAAE,IAAI;QACvB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACrC,MAAM,oBAAoB,GAAG,EAAE,IAAI,CAAC,qBAAqB,CAAA;YACzD,MAAM,WAAW,GAAG,IAAI,KAAK,CAAC,YAAY,OAAO,cAAc,CAAC,CAAA;YAChE,4DAA4D;YAC5D,IAAI,KAAK,CAAC,iBAAiB;gBAAE,KAAK,CAAC,iBAAiB,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,CAAA;YACnF,MAAM,WAAW,GAAG;gBAClB,OAAO;gBACP,UAAU,EAAE,oBAAoB;gBAChC,IAAI;aACL,CAAA;YAED,IAAI,CAAC,gBAAgB,CAAC,oBAAoB,CAAC,GAAG,EAAC,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,WAAW,CAAC,KAAK,EAAC,CAAA;YAC/F,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,CAAC,SAAS,EAAE,WAAW,CAAC,CAAC,CAAA;YAC1C,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;QACxB,CAAC,CAAC,CAAA;IACJ,CAAC;IAED;;;OAGG;IACH,IAAI,CAAC,IAAI;QACP,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IACzB,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,kBAAkB,CAAC,WAAW;QAClC,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,qBAAqB,EAAE,EAAC,YAAY,EAAE,WAAW,EAAC,CAAC,CAAA;QAEvF,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;IACzB,CAAC;IAED;;;;OAIG;IACH,cAAc,CAAC,EAAE;QACf,MAAM,SAAS,GAAG,IAAI,SAAS,CAAC,IAAI,EAAE,EAAE,CAAC,CAAA;QAEzC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,GAAG,SAAS,CAAA;QAE/B,OAAO,SAAS,CAAA;IAClB,CAAC;IAED,mBAAmB;QACjB,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAA;IAClC,CAAC;CACF","sourcesContent":["// @ts-check\n\nimport Logger from \"../logger.js\"\nimport Reference from \"./reference.js\"\nimport safeJSONStringify from \"../utils/safe-json-stringify.js\"\n\nconst logger = new Logger(\"Scoundrel Client\")\n\n// logger.setDebug(true)\n\nexport default class Client {\n  /**\n   * Creates a new Scoundrel Client\n   * @param {any} backend The backend connection (e.g., WebSocket)\n   * @param {{enableServerControl?: boolean}} [options] Client configuration options\n   */\n  constructor(backend, options = {}) {\n    this.backend = backend\n    this.backend.onCommand(this.onCommand)\n\n    /** @type {Record<number, any>} */\n    this.outgoingCommands = {}\n    this.incomingCommands = {}\n    this.outgoingCommandsCount = 0\n\n    /** @type {Record<string, any>} */\n    this._classes = {}\n\n    /** @type {Record<string, any>} */\n    this._objects = {}\n\n    /** @type {Record<string, Reference>} */\n    this.references = {}\n\n    /** @type {Record<number, any>} */\n    this.objects = {}\n\n    this.objectsCount = 0\n\n    /** @type {boolean} */\n    this.serverControlEnabled = Boolean(options.enableServerControl)\n  }\n\n  /**\n   * Closes the client connection\n   */\n  async close() {\n    this.backend.close()\n  }\n\n  /**\n   * Calls a method on a reference and returns the result directly\n   * @param {number} referenceId Reference identifier\n   * @param {string} methodName Method name to invoke\n   * @param  {...any} args Arguments to pass to the method\n   * @returns {Promise<any>} Result from the method call\n   */\n  async callMethodOnReference(referenceId, methodName, ...args) {\n    const result = await this.sendCommand(\"call_method_on_reference\", {\n      args: this.parseArg(args),\n      method_name: methodName,\n      reference_id: referenceId,\n      with: \"result\"\n    })\n\n    return result.response\n  }\n\n  /**\n   * Calls a method on a reference and returns a new reference\n   * @param {number} referenceId Reference identifier\n   * @param {string} methodName Method name to invoke\n   * @param  {...any} args Arguments to pass to the method\n   * @returns {Promise<Reference>} Reference to the return value\n   */\n  async callMethodOnReferenceWithReference(referenceId, methodName, ...args) {\n    const result = await this.sendCommand(\"call_method_on_reference\", {\n      args: this.parseArg(args),\n      method_name: methodName,\n      reference_id: referenceId,\n      with: \"reference\"\n    })\n    const id = result.response\n\n    return this.spawnReference(id)\n  }\n\n  /**\n   * Evaluates a string and returns a new reference\n   * @param {string} evalString Code to evaluate\n   * @returns {Promise<Reference>} Reference to the evaluated value\n   */\n  async evalWithReference(evalString) {\n    const result = await this.sendCommand(\"eval\", {\n      eval_string: evalString,\n      with_reference: true\n    })\n\n    if (!result) throw new Error(\"Blank result given\")\n\n    const objectId = result.object_id\n\n    if (!objectId) throw new Error(`No object ID given in result: ${JSON.stringify(result)}`)\n\n    return this.spawnReference(objectId)\n  }\n\n  /**\n   * Imports a module and returns a reference to it\n   * @param {string} importName Module name to import\n   * @returns {Promise<Reference>} Reference to the module\n   */\n  async import(importName) {\n    const result = await this.sendCommand(\"import\", {\n      import_name: importName\n    })\n\n    logger.log(() => [\"import\", {result}])\n\n    if (!result) throw new Error(\"No result given\")\n    if (!result.object_id) throw new Error(`No object ID given in result: ${JSON.stringify(result)}`)\n\n    const id = result.object_id\n\n    return this.spawnReference(id)\n  }\n\n  /**\n   * Gets a registered object by name\n   * @param {string} objectName Registered object name\n   * @returns {Promise<Reference>} Reference to the object\n   */\n  async getObject(objectName) {\n    const result = await this.sendCommand(\"get_object\", {\n      object_name: objectName\n    })\n\n    if (!result) throw new Error(\"Blank result given\")\n\n    const id = result.object_id\n\n    return this.spawnReference(id)\n  }\n\n  /**\n   * Spawns a new reference to an object\n   * @param {string} className Class name to construct\n   * @param  {...any} args Constructor arguments\n   * @returns {Promise<Reference>} Reference to the new instance\n   */\n  async newObjectWithReference(className, ...args) {\n    const result = await this.sendCommand(\"new_object_with_reference\", {\n      args: this.parseArg(args),\n      class_name: className\n    })\n\n    if (!result) throw new Error(\"Blank result given\")\n\n    const id = result.object_id\n\n    if (!id) throw new Error(`No object ID given in result: ${JSON.stringify(result)}`)\n\n    return this.spawnReference(id)\n  }\n\n  /**\n   * Checks if the input is a plain object\n   * @param {any} input Value to inspect\n   * @returns {boolean} True when the value is a plain object\n   */\n  isPlainObject(input) {\n    if (input && typeof input === \"object\" && !Array.isArray(input)) {\n      return true\n    }\n\n    return false\n  }\n\n  /**\n   * Handles an incoming command from the backend\n   * @param {object} args Command payload\n   * @param {string} args.command Command name\n   * @param {number} args.command_id Command identifier\n   * @param {any} args.data Command data\n   * @param {string} [args.error] Error message from the backend\n   * @param {string} [args.errorStack] Error stack from the backend\n   */\n  onCommand = ({command, command_id: commandID, data, error, errorStack, ...restArgs}) => {\n    logger.log(() => [\"onCommand\", {command, commandID, data, error, errorStack, restArgs}])\n\n    try {\n      if (!command) {\n        throw new Error(`No command key given in data: ${Object.keys(restArgs).join(\", \")}`)\n      } else if (command == \"command_response\") {\n        if (!(commandID in this.outgoingCommands)) {\n          throw new Error(`Outgoing command ${commandID} not found: ${Object.keys(this.outgoingCommands).join(\", \")}`)\n        }\n\n        const savedCommand = this.outgoingCommands[commandID]\n\n        delete this.outgoingCommands[commandID]\n\n        if (error) {\n          const errorToThrow = new Error(error)\n          const sanitizeStack = (stack) => {\n            if (!stack) return []\n            return stack\n              .split(\"\\n\")\n              .map((line) => line.trim())\n              .filter((line) => line)\n              .filter((line) => !/node_modules\\/ws/.test(line))\n              .filter((line) => !/(?:^|\\()node:/.test(line))\n              .filter((line) => !/(?:^|\\()node:internal\\//.test(line))\n              .filter((line) => !/(?:^|\\()internal\\//.test(line))\n              .filter((line) => !line.startsWith(\"Error:\"))\n          }\n\n          const formatSection = (label, stack) => {\n            const lines = sanitizeStack(stack)\n            if (lines.length === 0) return []\n            return [`${label} ${lines[0]}`, ...lines.slice(1)]\n          }\n\n          const combinedStack = [\n            `Error: ${error}`,\n            ...formatSection(\"[SCOUNTDREL-SERVER]\", errorStack),\n            ...formatSection(\"[SCOUNDREL-CLIENT]\", errorToThrow.stack),\n            ...formatSection(\"[SCOUNDREL-CLIENT]\", savedCommand.originStack ? `Command created at:\\n${savedCommand.originStack}` : null)\n          ].join(\"\\n\")\n\n          errorToThrow.stack = combinedStack\n\n          savedCommand.reject(errorToThrow)\n        } else {\n          logger.log(() => [`Resolving command ${commandID} with data`, data])\n          savedCommand.resolve(data.data)\n        }\n      } else if (!this.serverControlEnabled) {\n        this.send({command: \"command_response\", command_id: commandID, error: \"Server control is disabled\"})\n        return\n      } else if (command == \"get_object\") {\n        const serverObject = this._getRegisteredObject(data.object_name)\n        const serverClass = this._getRegisteredClass(data.object_name)\n        let object\n\n        if (serverObject !== undefined) {\n          object = serverObject\n        } else if (serverClass !== undefined) {\n          object = serverClass\n        } else {\n          object = globalThis[data.object_name]\n\n          if (object === undefined) throw new Error(`No such object: ${data.object_name}`)\n        }\n\n        const objectId = ++this.objectsCount\n\n        this.objects[objectId] = object\n        this.respondToCommand(commandID, {object_id: objectId})\n      } else if (command == \"new_object_with_reference\") {\n        const className = data.class_name\n        let object\n\n        if (typeof className == \"string\") {\n          const ClassInstance = this.getClass(className) || globalThis[className]\n\n          if (!ClassInstance) throw new Error(`No such class: ${className}`)\n\n          object = new ClassInstance(...data.args)\n        } else {\n          throw new Error(`Don't know how to handle class name: ${typeof className}`)\n        }\n\n        const objectId = ++this.objectsCount\n\n        this.objects[objectId] = object\n        this.respondToCommand(commandID, {object_id: objectId})\n      } else if (command == \"call_method_on_reference\") {\n        const referenceId = data.reference_id\n        const object = this.objects[referenceId]\n\n        if (!object) throw new Error(`No object by that ID: ${referenceId}`)\n\n        const method = object[data.method_name]\n\n        if (!method) throw new Error(`No method called '${data.method_name}' on a '${object.constructor.name}'`)\n\n        const respondWithValue = (responseValue) => {\n          if (data.with == \"reference\") {\n            const objectId = ++this.objectsCount\n\n            this.objects[objectId] = responseValue\n            this.respondToCommand(commandID, {response: objectId})\n          } else {\n            this.respondToCommand(commandID, {response: responseValue})\n          }\n        }\n\n        const response = method.call(object, ...data.args)\n\n        if (response && typeof response.then == \"function\") {\n          response.then(respondWithValue).catch((promiseError) => {\n            if (promiseError instanceof Error) {\n              this.send({command: \"command_response\", command_id: commandID, error: promiseError.message, errorStack: promiseError.stack})\n            } else {\n              this.send({command: \"command_response\", command_id: commandID, error: String(promiseError)})\n            }\n          })\n        } else {\n          respondWithValue(response)\n        }\n      } else if (command == \"serialize_reference\") {\n        const referenceId = data.reference_id\n        const object = this.objects[referenceId]\n\n        if (!object) throw new Error(`No object by that ID: ${referenceId}`)\n\n        const serialized = safeJSONStringify(object)\n        this.respondToCommand(commandID, serialized)\n      } else if (command == \"read_attribute\") {\n        const attributeName = data.attribute_name\n        const referenceId = data.reference_id\n        const returnWith = data.with\n        const object = this.objects[referenceId]\n\n        if (!object) throw new Error(`No object by that ID: ${referenceId}`)\n\n        const attribute = object[attributeName]\n\n        if (returnWith == \"reference\") {\n          const objectId = ++this.objectsCount\n\n          this.objects[objectId] = attribute\n          this.respondToCommand(commandID, {response: objectId})\n        } else {\n          this.respondToCommand(commandID, {response: attribute})\n        }\n      } else if (command == \"eval\") {\n        const respondWithResult = (evalResult) => {\n          if (data.with_reference) {\n            const objectId = ++this.objectsCount\n\n            this.objects[objectId] = evalResult\n            this.respondToCommand(commandID, {object_id: objectId})\n          } else {\n            this.respondToCommand(commandID, {response: evalResult})\n          }\n        }\n\n        const scope = {...this._objects, ...this._classes}\n        const reservedIdentifiers = new Set([\n          \"break\",\n          \"case\",\n          \"catch\",\n          \"class\",\n          \"const\",\n          \"continue\",\n          \"debugger\",\n          \"default\",\n          \"delete\",\n          \"do\",\n          \"else\",\n          \"export\",\n          \"extends\",\n          \"finally\",\n          \"for\",\n          \"function\",\n          \"if\",\n          \"import\",\n          \"in\",\n          \"instanceof\",\n          \"new\",\n          \"return\",\n          \"super\",\n          \"switch\",\n          \"this\",\n          \"throw\",\n          \"try\",\n          \"typeof\",\n          \"var\",\n          \"void\",\n          \"while\",\n          \"with\",\n          \"yield\",\n          \"let\",\n          \"enum\",\n          \"await\",\n          \"implements\",\n          \"package\",\n          \"protected\",\n          \"static\",\n          \"interface\",\n          \"private\",\n          \"public\",\n          \"eval\"\n        ])\n\n        const isValidIdentifier = (name) =>\n          /^(?:[$_]|\\p{ID_Start})(?:[$_]|\\p{ID_Continue})*$/u.test(name) && !reservedIdentifiers.has(name)\n\n        const scopeKeys = Object.keys(scope)\n        const invalidKeys = scopeKeys.filter((key) => !isValidIdentifier(key))\n\n        if (invalidKeys.length > 0) {\n          throw new Error(`Invalid registered identifier(s): ${invalidKeys.join(\", \")}`)\n        }\n\n        // Ensure registered objects/classes are available as locals inside the eval\n        const evaluator = new Function(\"__evalString\", ...scopeKeys, \"return eval(__evalString)\")\n        const evalResult = evaluator(data.eval_string, ...scopeKeys.map((key) => scope[key]))\n\n        if (evalResult && typeof evalResult.then == \"function\") {\n          evalResult.then(respondWithResult).catch((promiseError) => {\n            if (promiseError instanceof Error) {\n              this.send({command: \"command_response\", command_id: commandID, error: promiseError.message, errorStack: promiseError.stack})\n            } else {\n              this.send({command: \"command_response\", command_id: commandID, error: String(promiseError)})\n            }\n          })\n        } else {\n          respondWithResult(evalResult)\n        }\n      } else {\n        throw new Error(`Unknown command: ${command}`)\n      }\n    } catch (error) {\n      if (error instanceof Error) {\n        this.send({command: \"command_response\", command_id: commandID, error: error.message, errorStack: error.stack})\n      } else {\n        this.send({command: \"command_response\", command_id: commandID, error: String(error)})\n      }\n\n      logger.error(error)\n    }\n  }\n\n  /**\n   * Parases an argument for sending to the server\n   * @param {any} arg Argument to serialize for transport\n   * @returns {any} Serialized argument payload\n   */\n  parseArg(arg) {\n    if (Array.isArray(arg)) {\n      return arg.map((argInArray) => this.parseArg(argInArray))\n    } else if (arg instanceof Reference) {\n      return {\n        __scoundrel_object_id: arg.id,\n        __scoundrel_type: \"reference\"\n      }\n    } else if (this.isPlainObject(arg)) {\n      /** @type {Record<any, any>} */\n      const newObject = {}\n\n      for (const key in arg) {\n        const value = arg[key]\n\n        newObject[key] = this.parseArg(value)\n      }\n\n      return newObject\n    }\n\n    return arg\n  }\n\n  /**\n   * Reads an attribute on a reference and returns a new reference\n   * @param {number} referenceId Reference identifier\n   * @param {string} attributeName Attribute name to read\n   * @returns {Promise<Reference>} Reference to the attribute value\n   */\n  async readAttributeOnReferenceWithReference(referenceId, attributeName) {\n    const result = await this.sendCommand(\"read_attribute\", {\n      attribute_name: attributeName,\n      reference_id: referenceId,\n      with: \"reference\"\n    })\n    const id = result.response\n\n    return this.spawnReference(id)\n  }\n\n  /**\n   * Reads an attribute on a reference and returns the result directly\n   * @param {number} referenceId Reference identifier\n   * @param {string} attributeName Attribute name to read\n   * @returns {Promise<any>} Attribute value\n   */\n  async readAttributeOnReference(referenceId, attributeName) {\n    const result = await this.sendCommand(\"read_attribute\", {\n      attribute_name: attributeName,\n      reference_id: referenceId,\n      with: \"result\"\n    })\n    return result.response\n  }\n\n  /**\n   * Registers a class by name\n   * @param {string} className Class name to register\n   * @param {any} classInstance Class constructor or instance\n   */\n  registerClass(className, classInstance) {\n    if (className in this._classes) throw new Error(`Class already exists: ${className}`)\n\n    this._classes[className] = classInstance\n  }\n\n  /**\n   * Unregisters a class by name\n   * @param {string} className Class name to remove\n   */\n  unregisterClass(className) {\n    if (!(className in this._classes)) throw new Error(`Class does not exist: ${className}`)\n\n    delete this._classes[className]\n  }\n\n  /**\n   * Gets a registered class by name\n   * @param {string} className Class name to look up\n   * @returns {any} Registered class or undefined\n   */\n  _getRegisteredClass(className) {\n    return this._classes[className]\n  }\n\n  /**\n   * Gets a registered class by name\n   * @param {string} className Class name to look up\n   * @returns {any} Registered class or undefined\n   */\n  getClass(className) {\n    return this._classes[className]\n  }\n\n  /**\n   * Registers an object by name\n   * @param {string} objectName Object name to register\n   * @param {any} objectInstance Object instance\n   */\n  registerObject(objectName, objectInstance) {\n    if (objectName in this._objects) throw new Error(`Object already exists: ${objectName}`)\n\n    this._objects[objectName] = objectInstance\n  }\n\n  /**\n   * Unregisters an object by name\n   * @param {string} objectName Object name to remove\n   */\n  unregisterObject(objectName) {\n    if (!(objectName in this._objects)) throw new Error(`Object does not exist: ${objectName}`)\n\n    delete this._objects[objectName]\n  }\n\n  /**\n   * Gets a registered object by name\n   * @param {string} objectName Object name to look up\n   * @returns {any} Registered object or undefined\n   */\n  _getRegisteredObject(objectName) {\n    return this._objects[objectName]\n  }\n\n  /**\n   * Responds to a command from the backend\n   * @param {number} commandId Command identifier\n   * @param {any} data Response payload\n   */\n  respondToCommand(commandId, data) {\n    this.send({command: \"command_response\", command_id: commandId, data: {command_id: commandId, data}})\n  }\n\n  /**\n   * Sends a command to the backend and returns a promise that resolves with the response\n   * @param {string} command Command name\n   * @param {any} data Command payload\n   * @returns {Promise<any>} Response from the backend\n   */\n  sendCommand(command, data) {\n    return new Promise((resolve, reject) => {\n      const outgoingCommandCount = ++this.outgoingCommandsCount\n      const originError = new Error(`Command '${command}' dispatched`)\n      // Strip the sendCommand frame to highlight the caller site.\n      if (Error.captureStackTrace) Error.captureStackTrace(originError, this.sendCommand)\n      const commandData = {\n        command,\n        command_id: outgoingCommandCount,\n        data\n      }\n\n      this.outgoingCommands[outgoingCommandCount] = {resolve, reject, originStack: originError.stack}\n      logger.log(() => [\"Sending\", commandData])\n      this.send(commandData)\n    })\n  }\n\n  /**\n   * Sends data to the backend\n   * @param {any} data Payload to send\n   */\n  send(data) {\n    this.backend.send(data)\n  }\n\n  /**\n   * Serializes a reference and returns the result directly\n   * @param {number} referenceId Reference identifier\n   * @returns {Promise<any>} Parsed JSON representation\n   */\n  async serializeReference(referenceId) {\n    const json = await this.sendCommand(\"serialize_reference\", {reference_id: referenceId})\n\n    return JSON.parse(json)\n  }\n\n  /**\n   * Spawns a new reference to an object\n   * @param {string} id Reference identifier\n   * @returns {Reference} Reference instance\n   */\n  spawnReference(id) {\n    const reference = new Reference(this, id)\n\n    this.references[id] = reference\n\n    return reference\n  }\n\n  enableServerControl() {\n    this.serverControlEnabled = true\n  }\n}\n"]}
702
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/client/index.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport Logger from \"../logger.js\"\nimport Reference from \"./reference.js\"\nimport safeJSONStringify from \"../utils/safe-json-stringify.js\"\n\nconst logger = new Logger(\"Scoundrel Client\")\n\n// logger.setDebug(true)\n\n/**\n * @typedef {{returnReference?: boolean, returnResult?: boolean}} ReturnOptions\n * @typedef {ReturnOptions & {returnResult?: false}} ReturnReferenceOptions\n * @typedef {ReturnOptions & {returnResult: true, returnReference?: false}} ReturnResultOptions\n */\nexport default class Client {\n  /**\n   * Creates a new Scoundrel Client\n   * @param {any} backend The backend connection (e.g., WebSocket)\n   * @param {{enableServerControl?: boolean}} [options] Client configuration options\n   */\n  constructor(backend, options = {}) {\n    this.backend = backend\n    this.backend.onCommand(this.onCommand)\n\n    /** @type {Record<number, any>} */\n    this.outgoingCommands = {}\n    this.incomingCommands = {}\n    this.outgoingCommandsCount = 0\n\n    /** @type {Record<string, any>} */\n    this._classes = {}\n\n    /** @type {Record<string, any>} */\n    this._objects = {}\n\n    /** @type {Record<string, Reference>} */\n    this.references = {}\n\n    /** @type {Record<number, any>} */\n    this.objects = {}\n\n    this.objectsCount = 0\n\n    /** @type {boolean} */\n    this.serverControlEnabled = Boolean(options.enableServerControl)\n  }\n\n  /**\n   * Closes the client connection\n   */\n  async close() {\n    this.backend.close()\n  }\n\n  /**\n   * Calls a method on a reference and returns the result directly\n   * @overload\n   * @param {number} referenceId Reference identifier\n   * @param {string} methodName Method name to invoke\n   * @param  {...any} args Arguments to pass to the method\n   * @returns {Promise<any>} Result from the method call\n   */\n  /**\n   * Calls a method on a reference and returns a new reference\n   * @overload\n   * @param {number} referenceId Reference identifier\n   * @param {string} methodName Method name to invoke\n   * @param {ReturnReferenceOptions} options Options for the call\n   * @param  {...any} args Arguments to pass to the method\n   * @returns {Promise<Reference>} Reference to the returned value\n   */\n  /**\n   * Calls a method on a reference and returns the result directly\n   * @overload\n   * @param {number} referenceId Reference identifier\n   * @param {string} methodName Method name to invoke\n   * @param {ReturnResultOptions} options Options for the call\n   * @param  {...any} args Arguments to pass to the method\n   * @returns {Promise<any>} Result from the method call\n   */\n  /**\n   * Calls a method on a reference and returns the result directly\n   * @param {number} referenceId Reference identifier\n   * @param {string} methodName Method name to invoke\n   * @param {ReturnOptions | any} [optionsOrArg] Options for the call or first argument\n   * @param  {...any} args Arguments to pass to the method\n   * @returns {Promise<Reference | any>} Result or reference from the method call\n   */\n  async callMethodOnReference(referenceId, methodName, optionsOrArg, ...args) {\n    const allowedOptions = new Set([\"returnReference\", \"returnResult\"])\n    /** @type {ReturnOptions | undefined} */\n    let options\n    /** @type {any[]} */\n    let methodArgs\n\n    if (typeof optionsOrArg === \"undefined\") {\n      methodArgs = []\n    } else if (this.isPlainObject(optionsOrArg)) {\n      const optionKeys = Object.keys(optionsOrArg)\n      const hasOptionKey = optionKeys.some((key) => allowedOptions.has(key))\n\n      if (hasOptionKey) {\n        const unknownOptions = optionKeys.filter((key) => !allowedOptions.has(key))\n        if (unknownOptions.length > 0) {\n          throw new Error(`Unknown callMethodOnReference options: ${unknownOptions.join(\", \")}`)\n        }\n\n        options = /** @type {ReturnOptions} */ (optionsOrArg)\n        methodArgs = args\n      } else {\n        methodArgs = [optionsOrArg, ...args]\n      }\n    } else {\n      methodArgs = [optionsOrArg, ...args]\n    }\n\n    const returnReference = options?.returnReference === true\n    const returnResult = options?.returnResult === true\n\n    if (returnReference && returnResult) {\n      throw new Error(\"callMethodOnReference options returnReference and returnResult cannot both be true\")\n    }\n\n    const withReference = returnReference\n    const result = await this.sendCommand(\"call_method_on_reference\", {\n      args: this.parseArg(methodArgs),\n      method_name: methodName,\n      reference_id: referenceId,\n      with: withReference ? \"reference\" : \"result\"\n    })\n\n    if (!result) throw new Error(\"Blank result given\")\n\n    if (withReference) {\n      const objectId = result.response\n\n      if (!objectId) throw new Error(`No object ID given in result: ${JSON.stringify(result)}`)\n\n      return this.spawnReference(objectId)\n    }\n\n    return result.response\n  }\n\n  /**\n   * Calls a method on a reference and returns a new reference\n   * @param {number} referenceId Reference identifier\n   * @param {string} methodName Method name to invoke\n   * @param  {...any} args Arguments to pass to the method\n   * @returns {Promise<Reference>} Reference to the return value\n   */\n  async callMethodOnReferenceWithReference(referenceId, methodName, ...args) {\n    console.warn(\"Scoundrel Client\", \"callMethodOnReferenceWithReference is deprecated; use callMethodOnReference with returnReference instead.\")\n    return this.callMethodOnReference(referenceId, methodName, {returnReference: true}, ...args)\n  }\n\n  /**\n   * Evaluates a string and returns a reference or result\n   * @overload\n   * @param {string} evalString Code to evaluate\n   * @returns {Promise<Reference>} Reference to the evaluated value\n   */\n  /**\n   * Evaluates a string and returns a reference or result\n   * @overload\n   * @param {ReturnReferenceOptions} options Eval options\n   * @param {string} evalString Code to evaluate\n   * @returns {Promise<Reference>} Reference to the evaluated value\n   */\n  /**\n   * Evaluates a string and returns a reference or result\n   * @overload\n   * @param {ReturnResultOptions} options Eval options\n   * @param {string} evalString Code to evaluate\n   * @returns {Promise<any>} Evaluated result\n   */\n  /**\n   * Evaluates a string and returns a reference or result\n   * @param {string | ReturnOptions} optionsOrEvalString Options or code to evaluate\n   * @param {string} [evalString] Code to evaluate\n   * @returns {Promise<Reference | any>} Reference or evaluated result\n   */\n  async eval(optionsOrEvalString, evalString) {\n    const allowedOptions = new Set([\"returnReference\", \"returnResult\"])\n    /** @type {ReturnOptions} */\n    let options = {}\n    /** @type {string | undefined} */\n    let targetEvalString = evalString\n\n    if (typeof evalString === \"undefined\") {\n      if (this.isPlainObject(optionsOrEvalString)) {\n        throw new Error(\"eval requires an eval string when options are provided\")\n      }\n\n      targetEvalString = /** @type {string} */ (optionsOrEvalString)\n    } else {\n      options = /** @type {ReturnOptions} */ (optionsOrEvalString ?? {})\n\n      if (!this.isPlainObject(options)) {\n        throw new Error(\"eval options must be a plain object\")\n      }\n    }\n\n    const unknownOptions = Object.keys(options).filter((key) => !allowedOptions.has(key))\n    if (unknownOptions.length > 0) {\n      throw new Error(`Unknown eval options: ${unknownOptions.join(\", \")}`)\n    }\n\n    const returnReference = options.returnReference === true\n    const returnResult = options.returnResult === true\n\n    if (returnReference && returnResult) {\n      throw new Error(\"eval options returnReference and returnResult cannot both be true\")\n    }\n\n    const withReference = returnReference || !returnResult\n    const result = await this.sendCommand(\"eval\", {\n      eval_string: targetEvalString,\n      with_reference: withReference\n    })\n\n    if (!result) throw new Error(\"Blank result given\")\n\n    if (withReference) {\n      const objectId = result.object_id\n\n      if (!objectId) throw new Error(`No object ID given in result: ${JSON.stringify(result)}`)\n\n      return this.spawnReference(objectId)\n    }\n\n    if (!(\"response\" in result)) throw new Error(`No response given in result: ${JSON.stringify(result)}`)\n\n    return result.response\n  }\n\n  /**\n   * Evaluates a string and returns a new reference\n   * @param {string} evalString Code to evaluate\n   * @returns {Promise<Reference>} Reference to the evaluated value\n   */\n  async evalWithReference(evalString) {\n    console.warn(\"Scoundrel Client\", \"evalWithReference is deprecated; use eval instead.\")\n    return this.eval({returnReference: true}, evalString)\n  }\n\n  /**\n   * Imports a module and returns a reference to it\n   * @param {string} importName Module name to import\n   * @returns {Promise<Reference>} Reference to the module\n   */\n  async import(importName) {\n    const result = await this.sendCommand(\"import\", {\n      import_name: importName\n    })\n\n    logger.log(() => [\"import\", {result}])\n\n    if (!result) throw new Error(\"No result given\")\n    if (!result.object_id) throw new Error(`No object ID given in result: ${JSON.stringify(result)}`)\n\n    const id = result.object_id\n\n    return this.spawnReference(id)\n  }\n\n  /**\n   * Gets a registered object by name\n   * @param {string} objectName Registered object name\n   * @returns {Promise<Reference>} Reference to the object\n   */\n  async getObject(objectName) {\n    const result = await this.sendCommand(\"get_object\", {\n      object_name: objectName\n    })\n\n    if (!result) throw new Error(\"Blank result given\")\n\n    const id = result.object_id\n\n    return this.spawnReference(id)\n  }\n\n  /**\n   * Spawns a new reference to an object\n   * @param {string} className Class name to construct\n   * @param  {...any} args Constructor arguments\n   * @returns {Promise<Reference>} Reference to the new instance\n   */\n  async newObjectWithReference(className, ...args) {\n    const result = await this.sendCommand(\"new_object_with_reference\", {\n      args: this.parseArg(args),\n      class_name: className\n    })\n\n    if (!result) throw new Error(\"Blank result given\")\n\n    const id = result.object_id\n\n    if (!id) throw new Error(`No object ID given in result: ${JSON.stringify(result)}`)\n\n    return this.spawnReference(id)\n  }\n\n  /**\n   * Checks if the input is a plain object\n   * @param {any} input Value to inspect\n   * @returns {boolean} True when the value is a plain object\n   */\n  isPlainObject(input) {\n    if (input && typeof input === \"object\" && !Array.isArray(input)) {\n      return true\n    }\n\n    return false\n  }\n\n  /**\n   * Handles an incoming command from the backend\n   * @param {object} args Command payload\n   * @param {string} args.command Command name\n   * @param {number} args.command_id Command identifier\n   * @param {any} args.data Command data\n   * @param {string} [args.error] Error message from the backend\n   * @param {string} [args.errorStack] Error stack from the backend\n   */\n  onCommand = ({command, command_id: commandID, data, error, errorStack, ...restArgs}) => {\n    logger.log(() => [\"onCommand\", {command, commandID, data, error, errorStack, restArgs}])\n\n    try {\n      if (!command) {\n        throw new Error(`No command key given in data: ${Object.keys(restArgs).join(\", \")}`)\n      } else if (command == \"command_response\") {\n        if (!(commandID in this.outgoingCommands)) {\n          throw new Error(`Outgoing command ${commandID} not found: ${Object.keys(this.outgoingCommands).join(\", \")}`)\n        }\n\n        const savedCommand = this.outgoingCommands[commandID]\n\n        delete this.outgoingCommands[commandID]\n\n        if (error) {\n          const errorToThrow = new Error(error)\n          const sanitizeStack = (stack) => {\n            if (!stack) return []\n            return stack\n              .split(\"\\n\")\n              .map((line) => line.trim())\n              .filter((line) => line)\n              .filter((line) => !/node_modules\\/ws/.test(line))\n              .filter((line) => !/(?:^|\\()node:/.test(line))\n              .filter((line) => !/(?:^|\\()node:internal\\//.test(line))\n              .filter((line) => !/(?:^|\\()internal\\//.test(line))\n              .filter((line) => !line.startsWith(\"Error:\"))\n          }\n\n          const formatSection = (label, stack) => {\n            const lines = sanitizeStack(stack)\n            if (lines.length === 0) return []\n            return [`${label} ${lines[0]}`, ...lines.slice(1)]\n          }\n\n          const combinedStack = [\n            `Error: ${error}`,\n            ...formatSection(\"[SCOUNTDREL-SERVER]\", errorStack),\n            ...formatSection(\"[SCOUNDREL-CLIENT]\", errorToThrow.stack),\n            ...formatSection(\"[SCOUNDREL-CLIENT]\", savedCommand.originStack ? `Command created at:\\n${savedCommand.originStack}` : null)\n          ].join(\"\\n\")\n\n          errorToThrow.stack = combinedStack\n\n          savedCommand.reject(errorToThrow)\n        } else {\n          logger.log(() => [`Resolving command ${commandID} with data`, data])\n          savedCommand.resolve(data.data)\n        }\n      } else if (!this.serverControlEnabled) {\n        this.send({command: \"command_response\", command_id: commandID, error: \"Server control is disabled\"})\n        return\n      } else if (command == \"get_object\") {\n        const serverObject = this._getRegisteredObject(data.object_name)\n        const serverClass = this._getRegisteredClass(data.object_name)\n        let object\n\n        if (serverObject !== undefined) {\n          object = serverObject\n        } else if (serverClass !== undefined) {\n          object = serverClass\n        } else {\n          object = globalThis[data.object_name]\n\n          if (object === undefined) throw new Error(`No such object: ${data.object_name}`)\n        }\n\n        const objectId = ++this.objectsCount\n\n        this.objects[objectId] = object\n        this.respondToCommand(commandID, {object_id: objectId})\n      } else if (command == \"new_object_with_reference\") {\n        const className = data.class_name\n        let object\n\n        if (typeof className == \"string\") {\n          const ClassInstance = this.getClass(className) || globalThis[className]\n\n          if (!ClassInstance) throw new Error(`No such class: ${className}`)\n\n          object = new ClassInstance(...data.args)\n        } else {\n          throw new Error(`Don't know how to handle class name: ${typeof className}`)\n        }\n\n        const objectId = ++this.objectsCount\n\n        this.objects[objectId] = object\n        this.respondToCommand(commandID, {object_id: objectId})\n      } else if (command == \"call_method_on_reference\") {\n        const referenceId = data.reference_id\n        const object = this.objects[referenceId]\n\n        if (!object) throw new Error(`No object by that ID: ${referenceId}`)\n\n        const method = object[data.method_name]\n\n        if (!method) throw new Error(`No method called '${data.method_name}' on a '${object.constructor.name}'`)\n\n        const respondWithValue = (responseValue) => {\n          if (data.with == \"reference\") {\n            const objectId = ++this.objectsCount\n\n            this.objects[objectId] = responseValue\n            this.respondToCommand(commandID, {response: objectId})\n          } else {\n            this.respondToCommand(commandID, {response: responseValue})\n          }\n        }\n\n        const response = method.call(object, ...data.args)\n\n        if (response && typeof response.then == \"function\") {\n          response.then(respondWithValue).catch((promiseError) => {\n            if (promiseError instanceof Error) {\n              this.send({command: \"command_response\", command_id: commandID, error: promiseError.message, errorStack: promiseError.stack})\n            } else {\n              this.send({command: \"command_response\", command_id: commandID, error: String(promiseError)})\n            }\n          })\n        } else {\n          respondWithValue(response)\n        }\n      } else if (command == \"serialize_reference\") {\n        const referenceId = data.reference_id\n        const object = this.objects[referenceId]\n\n        if (!object) throw new Error(`No object by that ID: ${referenceId}`)\n\n        const serialized = safeJSONStringify(object)\n        this.respondToCommand(commandID, serialized)\n      } else if (command == \"read_attribute\") {\n        const attributeName = data.attribute_name\n        const referenceId = data.reference_id\n        const returnWith = data.with\n        const object = this.objects[referenceId]\n\n        if (!object) throw new Error(`No object by that ID: ${referenceId}`)\n\n        const attribute = object[attributeName]\n\n        if (returnWith == \"reference\") {\n          const objectId = ++this.objectsCount\n\n          this.objects[objectId] = attribute\n          this.respondToCommand(commandID, {response: objectId})\n        } else {\n          this.respondToCommand(commandID, {response: attribute})\n        }\n      } else if (command == \"eval\") {\n        const respondWithResult = (evalResult) => {\n          if (data.with_reference) {\n            const objectId = ++this.objectsCount\n\n            this.objects[objectId] = evalResult\n            this.respondToCommand(commandID, {object_id: objectId})\n          } else {\n            this.respondToCommand(commandID, {response: evalResult})\n          }\n        }\n\n        const scope = {...this._objects, ...this._classes}\n        const reservedIdentifiers = new Set([\n          \"break\",\n          \"case\",\n          \"catch\",\n          \"class\",\n          \"const\",\n          \"continue\",\n          \"debugger\",\n          \"default\",\n          \"delete\",\n          \"do\",\n          \"else\",\n          \"export\",\n          \"extends\",\n          \"finally\",\n          \"for\",\n          \"function\",\n          \"if\",\n          \"import\",\n          \"in\",\n          \"instanceof\",\n          \"new\",\n          \"return\",\n          \"super\",\n          \"switch\",\n          \"this\",\n          \"throw\",\n          \"try\",\n          \"typeof\",\n          \"var\",\n          \"void\",\n          \"while\",\n          \"with\",\n          \"yield\",\n          \"let\",\n          \"enum\",\n          \"await\",\n          \"implements\",\n          \"package\",\n          \"protected\",\n          \"static\",\n          \"interface\",\n          \"private\",\n          \"public\",\n          \"eval\"\n        ])\n\n        const isValidIdentifier = (name) =>\n          /^(?:[$_]|\\p{ID_Start})(?:[$_]|\\p{ID_Continue})*$/u.test(name) && !reservedIdentifiers.has(name)\n\n        const scopeKeys = Object.keys(scope)\n        const invalidKeys = scopeKeys.filter((key) => !isValidIdentifier(key))\n\n        if (invalidKeys.length > 0) {\n          throw new Error(`Invalid registered identifier(s): ${invalidKeys.join(\", \")}`)\n        }\n\n        // Ensure registered objects/classes are available as locals inside the eval\n        const evaluator = new Function(\"__evalString\", ...scopeKeys, \"return eval(__evalString)\")\n        const evalResult = evaluator(data.eval_string, ...scopeKeys.map((key) => scope[key]))\n\n        if (evalResult && typeof evalResult.then == \"function\") {\n          evalResult.then(respondWithResult).catch((promiseError) => {\n            if (promiseError instanceof Error) {\n              this.send({command: \"command_response\", command_id: commandID, error: promiseError.message, errorStack: promiseError.stack})\n            } else {\n              this.send({command: \"command_response\", command_id: commandID, error: String(promiseError)})\n            }\n          })\n        } else {\n          respondWithResult(evalResult)\n        }\n      } else {\n        throw new Error(`Unknown command: ${command}`)\n      }\n    } catch (error) {\n      if (error instanceof Error) {\n        this.send({command: \"command_response\", command_id: commandID, error: error.message, errorStack: error.stack})\n      } else {\n        this.send({command: \"command_response\", command_id: commandID, error: String(error)})\n      }\n\n      logger.error(error)\n    }\n  }\n\n  /**\n   * Parases an argument for sending to the server\n   * @param {any} arg Argument to serialize for transport\n   * @returns {any} Serialized argument payload\n   */\n  parseArg(arg) {\n    if (Array.isArray(arg)) {\n      return arg.map((argInArray) => this.parseArg(argInArray))\n    } else if (arg instanceof Reference) {\n      return {\n        __scoundrel_object_id: arg.id,\n        __scoundrel_type: \"reference\"\n      }\n    } else if (this.isPlainObject(arg)) {\n      /** @type {Record<any, any>} */\n      const newObject = {}\n\n      for (const key in arg) {\n        const value = arg[key]\n\n        newObject[key] = this.parseArg(value)\n      }\n\n      return newObject\n    }\n\n    return arg\n  }\n\n  /**\n   * Reads an attribute on a reference and returns a new reference\n   * @param {number} referenceId Reference identifier\n   * @param {string} attributeName Attribute name to read\n   * @returns {Promise<Reference>} Reference to the attribute value\n   */\n  async readAttributeOnReferenceWithReference(referenceId, attributeName) {\n    const result = await this.sendCommand(\"read_attribute\", {\n      attribute_name: attributeName,\n      reference_id: referenceId,\n      with: \"reference\"\n    })\n    const id = result.response\n\n    return this.spawnReference(id)\n  }\n\n  /**\n   * Reads an attribute on a reference and returns the result directly\n   * @param {number} referenceId Reference identifier\n   * @param {string} attributeName Attribute name to read\n   * @returns {Promise<any>} Attribute value\n   */\n  async readAttributeOnReference(referenceId, attributeName) {\n    const result = await this.sendCommand(\"read_attribute\", {\n      attribute_name: attributeName,\n      reference_id: referenceId,\n      with: \"result\"\n    })\n    return result.response\n  }\n\n  /**\n   * Registers a class by name\n   * @param {string} className Class name to register\n   * @param {any} classInstance Class constructor or instance\n   */\n  registerClass(className, classInstance) {\n    if (className in this._classes) throw new Error(`Class already exists: ${className}`)\n\n    this._classes[className] = classInstance\n  }\n\n  /**\n   * Unregisters a class by name\n   * @param {string} className Class name to remove\n   */\n  unregisterClass(className) {\n    if (!(className in this._classes)) throw new Error(`Class does not exist: ${className}`)\n\n    delete this._classes[className]\n  }\n\n  /**\n   * Gets a registered class by name\n   * @param {string} className Class name to look up\n   * @returns {any} Registered class or undefined\n   */\n  _getRegisteredClass(className) {\n    return this._classes[className]\n  }\n\n  /**\n   * Gets a registered class by name\n   * @param {string} className Class name to look up\n   * @returns {any} Registered class or undefined\n   */\n  getClass(className) {\n    return this._classes[className]\n  }\n\n  /**\n   * Registers an object by name\n   * @param {string} objectName Object name to register\n   * @param {any} objectInstance Object instance\n   */\n  registerObject(objectName, objectInstance) {\n    if (objectName in this._objects) throw new Error(`Object already exists: ${objectName}`)\n\n    this._objects[objectName] = objectInstance\n  }\n\n  /**\n   * Unregisters an object by name\n   * @param {string} objectName Object name to remove\n   */\n  unregisterObject(objectName) {\n    if (!(objectName in this._objects)) throw new Error(`Object does not exist: ${objectName}`)\n\n    delete this._objects[objectName]\n  }\n\n  /**\n   * Gets a registered object by name\n   * @param {string} objectName Object name to look up\n   * @returns {any} Registered object or undefined\n   */\n  _getRegisteredObject(objectName) {\n    return this._objects[objectName]\n  }\n\n  /**\n   * Responds to a command from the backend\n   * @param {number} commandId Command identifier\n   * @param {any} data Response payload\n   */\n  respondToCommand(commandId, data) {\n    this.send({command: \"command_response\", command_id: commandId, data: {command_id: commandId, data}})\n  }\n\n  /**\n   * Sends a command to the backend and returns a promise that resolves with the response\n   * @param {string} command Command name\n   * @param {any} data Command payload\n   * @returns {Promise<any>} Response from the backend\n   */\n  sendCommand(command, data) {\n    return new Promise((resolve, reject) => {\n      const outgoingCommandCount = ++this.outgoingCommandsCount\n      const originError = new Error(`Command '${command}' dispatched`)\n      // Strip the sendCommand frame to highlight the caller site.\n      if (Error.captureStackTrace) Error.captureStackTrace(originError, this.sendCommand)\n      const commandData = {\n        command,\n        command_id: outgoingCommandCount,\n        data\n      }\n\n      this.outgoingCommands[outgoingCommandCount] = {resolve, reject, originStack: originError.stack}\n      logger.log(() => [\"Sending\", commandData])\n      this.send(commandData)\n    })\n  }\n\n  /**\n   * Sends data to the backend\n   * @param {any} data Payload to send\n   */\n  send(data) {\n    this.backend.send(data)\n  }\n\n  /**\n   * Serializes a reference and returns the result directly\n   * @param {number} referenceId Reference identifier\n   * @returns {Promise<any>} Parsed JSON representation\n   */\n  async serializeReference(referenceId) {\n    const json = await this.sendCommand(\"serialize_reference\", {reference_id: referenceId})\n\n    return JSON.parse(json)\n  }\n\n  /**\n   * Spawns a new reference to an object\n   * @param {string} id Reference identifier\n   * @returns {Reference} Reference instance\n   */\n  spawnReference(id) {\n    const reference = new Reference(this, id)\n\n    this.references[id] = reference\n\n    return reference\n  }\n\n  enableServerControl() {\n    this.serverControlEnabled = true\n  }\n}\n"]}
@@ -9,11 +9,36 @@ export default class Reference {
9
9
  id: string;
10
10
  /**
11
11
  * Calls a method on the reference
12
+ * @overload
12
13
  * @param {string} methodName Method name to invoke
13
14
  * @param {...any} args Arguments to pass to the method
14
15
  * @returns {Promise<any>} Result from the method call
15
16
  */
16
17
  callMethod(methodName: string, ...args: any[]): Promise<any>;
18
+ /**
19
+ * Calls a method on the reference
20
+ * @overload
21
+ * @param {string} methodName Method name to invoke
22
+ * @param {{returnReference?: boolean, returnResult?: false}} options Options for the call
23
+ * @param {...any} args Arguments to pass to the method
24
+ * @returns {Promise<Reference>} Reference to the return value
25
+ */
26
+ callMethod(methodName: string, options: {
27
+ returnReference?: boolean;
28
+ returnResult?: false;
29
+ }, ...args: any[]): Promise<Reference>;
30
+ /**
31
+ * Calls a method on the reference
32
+ * @overload
33
+ * @param {string} methodName Method name to invoke
34
+ * @param {{returnResult: true, returnReference?: false}} options Options for the call
35
+ * @param {...any} args Arguments to pass to the method
36
+ * @returns {Promise<any>} Result from the method call
37
+ */
38
+ callMethod(methodName: string, options: {
39
+ returnResult: true;
40
+ returnReference?: false;
41
+ }, ...args: any[]): Promise<any>;
17
42
  /**
18
43
  * Calls a method on the reference using another reference as argument
19
44
  * @param {string} methodName Method name to invoke
@@ -1 +1 @@
1
- {"version":3,"file":"reference.d.ts","sourceRoot":"","sources":["../../src/client/reference.js"],"names":[],"mappings":"AAEA;IACE;;;;OAIG;IACH,oBAHW,GAAG,MACH,MAAM,EAOhB;IAJC,YAAoB;IACpB,WAAY;IAKd;;;;;OAKG;IACH,uBAJW,MAAM,WACF,GAAG,EAAA,GACL,OAAO,CAAC,GAAG,CAAC,CAIxB;IAED;;;;;OAKG;IACH,oCAJW,MAAM,WACF,GAAG,EAAA,GACL,OAAO,CAAC,GAAG,CAAC,CAIxB;IAED;;;;;OAKG;IACH,6BAJW,MAAM,WACF,GAAG,EAAA,GACL,OAAO,CAAC,GAAG,CAAC,CAIxB;IAED;;;;;OAKG;IACH,0CAJW,MAAM,WACF,GAAG,EAAA,GACL,OAAO,CAAC,GAAG,CAAC,CAIxB;IAED;;;OAGG;IACH,aAFa,OAAO,CAAC,GAAG,CAAC,CAIxB;CACF"}
1
+ {"version":3,"file":"reference.d.ts","sourceRoot":"","sources":["../../src/client/reference.js"],"names":[],"mappings":"AAEA;IACE;;;;OAIG;IACH,oBAHW,GAAG,MACH,MAAM,EAOhB;IAJC,YAAoB;IACpB,WAAY;;;;;;;;IAOX,uBACQ,MAAM,WACF,GAAG,EAAA,GACL,OAAO,CAAC,GAAG,CAAC,CACxB;;;;;;;;;IAGE,uBACQ,MAAM,WACN;QAAC,eAAe,CAAC,EAAE,OAAO,CAAC;QAAC,YAAY,CAAC,EAAE,KAAK,CAAA;KAAC,WAC7C,GAAG,EAAA,GACL,OAAO,CAAC,SAAS,CAAC,CAC9B;;;;;;;;;IAGE,uBACQ,MAAM,WACN;QAAC,YAAY,EAAE,IAAI,CAAC;QAAC,eAAe,CAAC,EAAE,KAAK,CAAA;KAAC,WACzC,GAAG,EAAA,GACL,OAAO,CAAC,GAAG,CAAC,CACxB;IAYD;;;;;OAKG;IACH,oCAJW,MAAM,WACF,GAAG,EAAA,GACL,OAAO,CAAC,GAAG,CAAC,CAIxB;IAED;;;;;OAKG;IACH,6BAJW,MAAM,WACF,GAAG,EAAA,GACL,OAAO,CAAC,GAAG,CAAC,CAIxB;IAED;;;;;OAKG;IACH,0CAJW,MAAM,WACF,GAAG,EAAA,GACL,OAAO,CAAC,GAAG,CAAC,CAIxB;IAED;;;OAGG;IACH,aAFa,OAAO,CAAC,GAAG,CAAC,CAIxB;CACF"}
@@ -13,12 +13,36 @@ export default class Reference {
13
13
  }
14
14
  /**
15
15
  * Calls a method on the reference
16
+ * @overload
16
17
  * @param {string} methodName Method name to invoke
17
18
  * @param {...any} args Arguments to pass to the method
18
19
  * @returns {Promise<any>} Result from the method call
19
20
  */
20
- async callMethod(methodName, ...args) {
21
- return await this.client.callMethodOnReference(this.id, methodName, ...args);
21
+ /**
22
+ * Calls a method on the reference
23
+ * @overload
24
+ * @param {string} methodName Method name to invoke
25
+ * @param {{returnReference?: boolean, returnResult?: false}} options Options for the call
26
+ * @param {...any} args Arguments to pass to the method
27
+ * @returns {Promise<Reference>} Reference to the return value
28
+ */
29
+ /**
30
+ * Calls a method on the reference
31
+ * @overload
32
+ * @param {string} methodName Method name to invoke
33
+ * @param {{returnResult: true, returnReference?: false}} options Options for the call
34
+ * @param {...any} args Arguments to pass to the method
35
+ * @returns {Promise<any>} Result from the method call
36
+ */
37
+ /**
38
+ * Calls a method on the reference
39
+ * @param {string} methodName Method name to invoke
40
+ * @param {any} [optionsOrArg] Options for the call or first argument
41
+ * @param {...any} args Arguments to pass to the method
42
+ * @returns {Promise<Reference | any>} Result or reference from the method call
43
+ */
44
+ async callMethod(methodName, optionsOrArg, ...args) {
45
+ return await this.client.callMethodOnReference(this.id, methodName, optionsOrArg, ...args);
22
46
  }
23
47
  /**
24
48
  * Calls a method on the reference using another reference as argument
@@ -27,7 +51,7 @@ export default class Reference {
27
51
  * @returns {Promise<any>} Result from the method call
28
52
  */
29
53
  async callMethodWithReference(methodName, ...args) {
30
- return await this.client.callMethodOnReferenceWithReference(this.id, methodName, ...args);
54
+ return await this.client.callMethodOnReference(this.id, methodName, { returnReference: true }, ...args);
31
55
  }
32
56
  /**
33
57
  * Reads an attribute from the reference
@@ -55,4 +79,4 @@ export default class Reference {
55
79
  return await this.client.serializeReference(this.id);
56
80
  }
57
81
  }
58
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVmZXJlbmNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NsaWVudC9yZWZlcmVuY2UuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsWUFBWTtBQUVaLE1BQU0sQ0FBQyxPQUFPLE9BQU8sU0FBUztJQUM1Qjs7OztPQUlHO0lBQ0gsWUFBWSxNQUFNLEVBQUUsRUFBRTtRQUNwQixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQTtRQUNwQixJQUFJLENBQUMsRUFBRSxHQUFHLEVBQUUsQ0FBQTtRQUVaLElBQUksQ0FBQyxFQUFFO1lBQUUsTUFBTSxJQUFJLEtBQUssQ0FBQyxxQkFBcUIsRUFBRSxFQUFFLENBQUMsQ0FBQTtJQUNyRCxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSCxLQUFLLENBQUMsVUFBVSxDQUFDLFVBQVUsRUFBRSxHQUFHLElBQUk7UUFDbEMsT0FBTyxNQUFNLElBQUksQ0FBQyxNQUFNLENBQUMscUJBQXFCLENBQUMsSUFBSSxDQUFDLEVBQUUsRUFBRSxVQUFVLEVBQUUsR0FBRyxJQUFJLENBQUMsQ0FBQTtJQUM5RSxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSCxLQUFLLENBQUMsdUJBQXVCLENBQUMsVUFBVSxFQUFFLEdBQUcsSUFBSTtRQUMvQyxPQUFPLE1BQU0sSUFBSSxDQUFDLE1BQU0sQ0FBQyxrQ0FBa0MsQ0FBQyxJQUFJLENBQUMsRUFBRSxFQUFFLFVBQVUsRUFBRSxHQUFHLElBQUksQ0FBQyxDQUFBO0lBQzNGLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNILEtBQUssQ0FBQyxhQUFhLENBQUMsYUFBYSxFQUFFLEdBQUcsSUFBSTtRQUN4QyxPQUFPLE1BQU0sSUFBSSxDQUFDLE1BQU0sQ0FBQyx3QkFBd0IsQ0FBQyxJQUFJLENBQUMsRUFBRSxFQUFFLGFBQWEsRUFBRSxHQUFHLElBQUksQ0FBQyxDQUFBO0lBQ3BGLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNILEtBQUssQ0FBQywwQkFBMEIsQ0FBQyxhQUFhLEVBQUUsR0FBRyxJQUFJO1FBQ3JELE9BQU8sTUFBTSxJQUFJLENBQUMsTUFBTSxDQUFDLHFDQUFxQyxDQUFDLElBQUksQ0FBQyxFQUFFLEVBQUUsYUFBYSxFQUFFLEdBQUcsSUFBSSxDQUFDLENBQUE7SUFDakcsQ0FBQztJQUVEOzs7T0FHRztJQUNILEtBQUssQ0FBQyxTQUFTO1FBQ2IsT0FBTyxNQUFNLElBQUksQ0FBQyxNQUFNLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFBO0lBQ3RELENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbIi8vIEB0cy1jaGVja1xuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBSZWZlcmVuY2Uge1xuICAvKipcbiAgICogQ3JlYXRlcyBhIG5ldyBSZWZlcmVuY2VcbiAgICogQHBhcmFtIHthbnl9IGNsaWVudCBUaGUgY2xpZW50IGluc3RhbmNlXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBpZCBUaGUgcmVmZXJlbmNlIElEXG4gICAqL1xuICBjb25zdHJ1Y3RvcihjbGllbnQsIGlkKSB7XG4gICAgdGhpcy5jbGllbnQgPSBjbGllbnRcbiAgICB0aGlzLmlkID0gaWRcblxuICAgIGlmICghaWQpIHRocm93IG5ldyBFcnJvcihgSW52YWxpZCBJRCBnaXZlbjogJHtpZH1gKVxuICB9XG5cbiAgLyoqXG4gICAqIENhbGxzIGEgbWV0aG9kIG9uIHRoZSByZWZlcmVuY2VcbiAgICogQHBhcmFtIHtzdHJpbmd9IG1ldGhvZE5hbWUgTWV0aG9kIG5hbWUgdG8gaW52b2tlXG4gICAqIEBwYXJhbSAgey4uLmFueX0gYXJncyBBcmd1bWVudHMgdG8gcGFzcyB0byB0aGUgbWV0aG9kXG4gICAqIEByZXR1cm5zIHtQcm9taXNlPGFueT59IFJlc3VsdCBmcm9tIHRoZSBtZXRob2QgY2FsbFxuICAgKi9cbiAgYXN5bmMgY2FsbE1ldGhvZChtZXRob2ROYW1lLCAuLi5hcmdzKSB7XG4gICAgcmV0dXJuIGF3YWl0IHRoaXMuY2xpZW50LmNhbGxNZXRob2RPblJlZmVyZW5jZSh0aGlzLmlkLCBtZXRob2ROYW1lLCAuLi5hcmdzKVxuICB9XG5cbiAgLyoqXG4gICAqIENhbGxzIGEgbWV0aG9kIG9uIHRoZSByZWZlcmVuY2UgdXNpbmcgYW5vdGhlciByZWZlcmVuY2UgYXMgYXJndW1lbnRcbiAgICogQHBhcmFtIHtzdHJpbmd9IG1ldGhvZE5hbWUgTWV0aG9kIG5hbWUgdG8gaW52b2tlXG4gICAqIEBwYXJhbSAgey4uLmFueX0gYXJncyBBcmd1bWVudHMgdG8gcGFzcyB0byB0aGUgbWV0aG9kXG4gICAqIEByZXR1cm5zIHtQcm9taXNlPGFueT59IFJlc3VsdCBmcm9tIHRoZSBtZXRob2QgY2FsbFxuICAgKi9cbiAgYXN5bmMgY2FsbE1ldGhvZFdpdGhSZWZlcmVuY2UobWV0aG9kTmFtZSwgLi4uYXJncykge1xuICAgIHJldHVybiBhd2FpdCB0aGlzLmNsaWVudC5jYWxsTWV0aG9kT25SZWZlcmVuY2VXaXRoUmVmZXJlbmNlKHRoaXMuaWQsIG1ldGhvZE5hbWUsIC4uLmFyZ3MpXG4gIH1cblxuICAvKipcbiAgICogUmVhZHMgYW4gYXR0cmlidXRlIGZyb20gdGhlIHJlZmVyZW5jZVxuICAgKiBAcGFyYW0ge3N0cmluZ30gYXR0cmlidXRlTmFtZSBBdHRyaWJ1dGUgbmFtZSB0byByZWFkXG4gICAqIEBwYXJhbSAgey4uLmFueX0gYXJncyBBZGRpdGlvbmFsIGFyZ3VtZW50c1xuICAgKiBAcmV0dXJucyB7UHJvbWlzZTxhbnk+fSBBdHRyaWJ1dGUgdmFsdWVcbiAgICovXG4gIGFzeW5jIHJlYWRBdHRyaWJ1dGUoYXR0cmlidXRlTmFtZSwgLi4uYXJncykge1xuICAgIHJldHVybiBhd2FpdCB0aGlzLmNsaWVudC5yZWFkQXR0cmlidXRlT25SZWZlcmVuY2UodGhpcy5pZCwgYXR0cmlidXRlTmFtZSwgLi4uYXJncylcbiAgfVxuXG4gIC8qKlxuICAgKiBSZWFkcyBhbiBhdHRyaWJ1dGUgZnJvbSB0aGUgcmVmZXJlbmNlIHVzaW5nIGFub3RoZXIgcmVmZXJlbmNlIGFzIGFyZ3VtZW50XG4gICAqIEBwYXJhbSB7c3RyaW5nfSBhdHRyaWJ1dGVOYW1lIEF0dHJpYnV0ZSBuYW1lIHRvIHJlYWRcbiAgICogQHBhcmFtICB7Li4uYW55fSBhcmdzIEFkZGl0aW9uYWwgYXJndW1lbnRzXG4gICAqIEByZXR1cm5zIHtQcm9taXNlPGFueT59IEF0dHJpYnV0ZSB2YWx1ZVxuICAgKi9cbiAgYXN5bmMgcmVhZEF0dHJpYnV0ZVdpdGhSZWZlcmVuY2UoYXR0cmlidXRlTmFtZSwgLi4uYXJncykge1xuICAgIHJldHVybiBhd2FpdCB0aGlzLmNsaWVudC5yZWFkQXR0cmlidXRlT25SZWZlcmVuY2VXaXRoUmVmZXJlbmNlKHRoaXMuaWQsIGF0dHJpYnV0ZU5hbWUsIC4uLmFyZ3MpXG4gIH1cblxuICAvKipcbiAgICogU2VyaWFsaXplcyB0aGUgcmVmZXJlbmNlIGFuZCByZXR1cm5zIHRoZSByZXN1bHQgZGlyZWN0bHlcbiAgICogQHJldHVybnMge1Byb21pc2U8YW55Pn0gUGFyc2VkIEpTT04gcmVwcmVzZW50YXRpb25cbiAgICovXG4gIGFzeW5jIHNlcmlhbGl6ZSgpIHtcbiAgICByZXR1cm4gYXdhaXQgdGhpcy5jbGllbnQuc2VyaWFsaXplUmVmZXJlbmNlKHRoaXMuaWQpXG4gIH1cbn1cbiJdfQ==
82
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVmZXJlbmNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NsaWVudC9yZWZlcmVuY2UuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsWUFBWTtBQUVaLE1BQU0sQ0FBQyxPQUFPLE9BQU8sU0FBUztJQUM1Qjs7OztPQUlHO0lBQ0gsWUFBWSxNQUFNLEVBQUUsRUFBRTtRQUNwQixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQTtRQUNwQixJQUFJLENBQUMsRUFBRSxHQUFHLEVBQUUsQ0FBQTtRQUVaLElBQUksQ0FBQyxFQUFFO1lBQUUsTUFBTSxJQUFJLEtBQUssQ0FBQyxxQkFBcUIsRUFBRSxFQUFFLENBQUMsQ0FBQTtJQUNyRCxDQUFDO0lBRUQ7Ozs7OztPQU1HO0lBQ0g7Ozs7Ozs7T0FPRztJQUNIOzs7Ozs7O09BT0c7SUFDSDs7Ozs7O09BTUc7SUFDSCxLQUFLLENBQUMsVUFBVSxDQUFDLFVBQVUsRUFBRSxZQUFZLEVBQUUsR0FBRyxJQUFJO1FBQ2hELE9BQU8sTUFBTSxJQUFJLENBQUMsTUFBTSxDQUFDLHFCQUFxQixDQUFDLElBQUksQ0FBQyxFQUFFLEVBQUUsVUFBVSxFQUFFLFlBQVksRUFBRSxHQUFHLElBQUksQ0FBQyxDQUFBO0lBQzVGLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNILEtBQUssQ0FBQyx1QkFBdUIsQ0FBQyxVQUFVLEVBQUUsR0FBRyxJQUFJO1FBQy9DLE9BQU8sTUFBTSxJQUFJLENBQUMsTUFBTSxDQUFDLHFCQUFxQixDQUFDLElBQUksQ0FBQyxFQUFFLEVBQUUsVUFBVSxFQUFFLEVBQUMsZUFBZSxFQUFFLElBQUksRUFBQyxFQUFFLEdBQUcsSUFBSSxDQUFDLENBQUE7SUFDdkcsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0gsS0FBSyxDQUFDLGFBQWEsQ0FBQyxhQUFhLEVBQUUsR0FBRyxJQUFJO1FBQ3hDLE9BQU8sTUFBTSxJQUFJLENBQUMsTUFBTSxDQUFDLHdCQUF3QixDQUFDLElBQUksQ0FBQyxFQUFFLEVBQUUsYUFBYSxFQUFFLEdBQUcsSUFBSSxDQUFDLENBQUE7SUFDcEYsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0gsS0FBSyxDQUFDLDBCQUEwQixDQUFDLGFBQWEsRUFBRSxHQUFHLElBQUk7UUFDckQsT0FBTyxNQUFNLElBQUksQ0FBQyxNQUFNLENBQUMscUNBQXFDLENBQUMsSUFBSSxDQUFDLEVBQUUsRUFBRSxhQUFhLEVBQUUsR0FBRyxJQUFJLENBQUMsQ0FBQTtJQUNqRyxDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsS0FBSyxDQUFDLFNBQVM7UUFDYixPQUFPLE1BQU0sSUFBSSxDQUFDLE1BQU0sQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUE7SUFDdEQsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQHRzLWNoZWNrXG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFJlZmVyZW5jZSB7XG4gIC8qKlxuICAgKiBDcmVhdGVzIGEgbmV3IFJlZmVyZW5jZVxuICAgKiBAcGFyYW0ge2FueX0gY2xpZW50IFRoZSBjbGllbnQgaW5zdGFuY2VcbiAgICogQHBhcmFtIHtzdHJpbmd9IGlkIFRoZSByZWZlcmVuY2UgSURcbiAgICovXG4gIGNvbnN0cnVjdG9yKGNsaWVudCwgaWQpIHtcbiAgICB0aGlzLmNsaWVudCA9IGNsaWVudFxuICAgIHRoaXMuaWQgPSBpZFxuXG4gICAgaWYgKCFpZCkgdGhyb3cgbmV3IEVycm9yKGBJbnZhbGlkIElEIGdpdmVuOiAke2lkfWApXG4gIH1cblxuICAvKipcbiAgICogQ2FsbHMgYSBtZXRob2Qgb24gdGhlIHJlZmVyZW5jZVxuICAgKiBAb3ZlcmxvYWRcbiAgICogQHBhcmFtIHtzdHJpbmd9IG1ldGhvZE5hbWUgTWV0aG9kIG5hbWUgdG8gaW52b2tlXG4gICAqIEBwYXJhbSAgey4uLmFueX0gYXJncyBBcmd1bWVudHMgdG8gcGFzcyB0byB0aGUgbWV0aG9kXG4gICAqIEByZXR1cm5zIHtQcm9taXNlPGFueT59IFJlc3VsdCBmcm9tIHRoZSBtZXRob2QgY2FsbFxuICAgKi9cbiAgLyoqXG4gICAqIENhbGxzIGEgbWV0aG9kIG9uIHRoZSByZWZlcmVuY2VcbiAgICogQG92ZXJsb2FkXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBtZXRob2ROYW1lIE1ldGhvZCBuYW1lIHRvIGludm9rZVxuICAgKiBAcGFyYW0ge3tyZXR1cm5SZWZlcmVuY2U/OiBib29sZWFuLCByZXR1cm5SZXN1bHQ/OiBmYWxzZX19IG9wdGlvbnMgT3B0aW9ucyBmb3IgdGhlIGNhbGxcbiAgICogQHBhcmFtICB7Li4uYW55fSBhcmdzIEFyZ3VtZW50cyB0byBwYXNzIHRvIHRoZSBtZXRob2RcbiAgICogQHJldHVybnMge1Byb21pc2U8UmVmZXJlbmNlPn0gUmVmZXJlbmNlIHRvIHRoZSByZXR1cm4gdmFsdWVcbiAgICovXG4gIC8qKlxuICAgKiBDYWxscyBhIG1ldGhvZCBvbiB0aGUgcmVmZXJlbmNlXG4gICAqIEBvdmVybG9hZFxuICAgKiBAcGFyYW0ge3N0cmluZ30gbWV0aG9kTmFtZSBNZXRob2QgbmFtZSB0byBpbnZva2VcbiAgICogQHBhcmFtIHt7cmV0dXJuUmVzdWx0OiB0cnVlLCByZXR1cm5SZWZlcmVuY2U/OiBmYWxzZX19IG9wdGlvbnMgT3B0aW9ucyBmb3IgdGhlIGNhbGxcbiAgICogQHBhcmFtICB7Li4uYW55fSBhcmdzIEFyZ3VtZW50cyB0byBwYXNzIHRvIHRoZSBtZXRob2RcbiAgICogQHJldHVybnMge1Byb21pc2U8YW55Pn0gUmVzdWx0IGZyb20gdGhlIG1ldGhvZCBjYWxsXG4gICAqL1xuICAvKipcbiAgICogQ2FsbHMgYSBtZXRob2Qgb24gdGhlIHJlZmVyZW5jZVxuICAgKiBAcGFyYW0ge3N0cmluZ30gbWV0aG9kTmFtZSBNZXRob2QgbmFtZSB0byBpbnZva2VcbiAgICogQHBhcmFtIHthbnl9IFtvcHRpb25zT3JBcmddIE9wdGlvbnMgZm9yIHRoZSBjYWxsIG9yIGZpcnN0IGFyZ3VtZW50XG4gICAqIEBwYXJhbSAgey4uLmFueX0gYXJncyBBcmd1bWVudHMgdG8gcGFzcyB0byB0aGUgbWV0aG9kXG4gICAqIEByZXR1cm5zIHtQcm9taXNlPFJlZmVyZW5jZSB8IGFueT59IFJlc3VsdCBvciByZWZlcmVuY2UgZnJvbSB0aGUgbWV0aG9kIGNhbGxcbiAgICovXG4gIGFzeW5jIGNhbGxNZXRob2QobWV0aG9kTmFtZSwgb3B0aW9uc09yQXJnLCAuLi5hcmdzKSB7XG4gICAgcmV0dXJuIGF3YWl0IHRoaXMuY2xpZW50LmNhbGxNZXRob2RPblJlZmVyZW5jZSh0aGlzLmlkLCBtZXRob2ROYW1lLCBvcHRpb25zT3JBcmcsIC4uLmFyZ3MpXG4gIH1cblxuICAvKipcbiAgICogQ2FsbHMgYSBtZXRob2Qgb24gdGhlIHJlZmVyZW5jZSB1c2luZyBhbm90aGVyIHJlZmVyZW5jZSBhcyBhcmd1bWVudFxuICAgKiBAcGFyYW0ge3N0cmluZ30gbWV0aG9kTmFtZSBNZXRob2QgbmFtZSB0byBpbnZva2VcbiAgICogQHBhcmFtICB7Li4uYW55fSBhcmdzIEFyZ3VtZW50cyB0byBwYXNzIHRvIHRoZSBtZXRob2RcbiAgICogQHJldHVybnMge1Byb21pc2U8YW55Pn0gUmVzdWx0IGZyb20gdGhlIG1ldGhvZCBjYWxsXG4gICAqL1xuICBhc3luYyBjYWxsTWV0aG9kV2l0aFJlZmVyZW5jZShtZXRob2ROYW1lLCAuLi5hcmdzKSB7XG4gICAgcmV0dXJuIGF3YWl0IHRoaXMuY2xpZW50LmNhbGxNZXRob2RPblJlZmVyZW5jZSh0aGlzLmlkLCBtZXRob2ROYW1lLCB7cmV0dXJuUmVmZXJlbmNlOiB0cnVlfSwgLi4uYXJncylcbiAgfVxuXG4gIC8qKlxuICAgKiBSZWFkcyBhbiBhdHRyaWJ1dGUgZnJvbSB0aGUgcmVmZXJlbmNlXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBhdHRyaWJ1dGVOYW1lIEF0dHJpYnV0ZSBuYW1lIHRvIHJlYWRcbiAgICogQHBhcmFtICB7Li4uYW55fSBhcmdzIEFkZGl0aW9uYWwgYXJndW1lbnRzXG4gICAqIEByZXR1cm5zIHtQcm9taXNlPGFueT59IEF0dHJpYnV0ZSB2YWx1ZVxuICAgKi9cbiAgYXN5bmMgcmVhZEF0dHJpYnV0ZShhdHRyaWJ1dGVOYW1lLCAuLi5hcmdzKSB7XG4gICAgcmV0dXJuIGF3YWl0IHRoaXMuY2xpZW50LnJlYWRBdHRyaWJ1dGVPblJlZmVyZW5jZSh0aGlzLmlkLCBhdHRyaWJ1dGVOYW1lLCAuLi5hcmdzKVxuICB9XG5cbiAgLyoqXG4gICAqIFJlYWRzIGFuIGF0dHJpYnV0ZSBmcm9tIHRoZSByZWZlcmVuY2UgdXNpbmcgYW5vdGhlciByZWZlcmVuY2UgYXMgYXJndW1lbnRcbiAgICogQHBhcmFtIHtzdHJpbmd9IGF0dHJpYnV0ZU5hbWUgQXR0cmlidXRlIG5hbWUgdG8gcmVhZFxuICAgKiBAcGFyYW0gIHsuLi5hbnl9IGFyZ3MgQWRkaXRpb25hbCBhcmd1bWVudHNcbiAgICogQHJldHVybnMge1Byb21pc2U8YW55Pn0gQXR0cmlidXRlIHZhbHVlXG4gICAqL1xuICBhc3luYyByZWFkQXR0cmlidXRlV2l0aFJlZmVyZW5jZShhdHRyaWJ1dGVOYW1lLCAuLi5hcmdzKSB7XG4gICAgcmV0dXJuIGF3YWl0IHRoaXMuY2xpZW50LnJlYWRBdHRyaWJ1dGVPblJlZmVyZW5jZVdpdGhSZWZlcmVuY2UodGhpcy5pZCwgYXR0cmlidXRlTmFtZSwgLi4uYXJncylcbiAgfVxuXG4gIC8qKlxuICAgKiBTZXJpYWxpemVzIHRoZSByZWZlcmVuY2UgYW5kIHJldHVybnMgdGhlIHJlc3VsdCBkaXJlY3RseVxuICAgKiBAcmV0dXJucyB7UHJvbWlzZTxhbnk+fSBQYXJzZWQgSlNPTiByZXByZXNlbnRhdGlvblxuICAgKi9cbiAgYXN5bmMgc2VyaWFsaXplKCkge1xuICAgIHJldHVybiBhd2FpdCB0aGlzLmNsaWVudC5zZXJpYWxpemVSZWZlcmVuY2UodGhpcy5pZClcbiAgfVxufVxuIl19
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "scoundrel-remote-eval",
3
3
  "type": "module",
4
- "version": "1.0.19",
4
+ "version": "1.0.20",
5
5
  "description": "",
6
6
  "main": "build/index.js",
7
7
  "types": "build/index.d.ts",
@@ -35,7 +35,7 @@
35
35
  "@types/jasmine": "^5.1.13",
36
36
  "@types/node": "^25.0.2",
37
37
  "eslint": "^9.39.2",
38
- "eslint-plugin-jsdoc": "^50.6.0",
38
+ "eslint-plugin-jsdoc": "^61.5.0",
39
39
  "globals": "^16.5.0",
40
40
  "jasmine": "^5.1.0",
41
41
  "typescript": "^5.9.3"