@skipruntime/helpers 0.0.1 → 0.0.3
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/dist/external.d.ts +41 -23
- package/dist/external.d.ts.map +1 -1
- package/dist/external.js +18 -19
- package/dist/external.js.map +1 -1
- package/dist/index.d.ts +2 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -1
- package/dist/index.js.map +1 -1
- package/dist/remote.d.ts +14 -15
- package/dist/remote.d.ts.map +1 -1
- package/dist/remote.js +50 -62
- package/dist/remote.js.map +1 -1
- package/dist/rest.d.ts +16 -14
- package/dist/rest.d.ts.map +1 -1
- package/dist/rest.js +13 -54
- package/dist/rest.js.map +1 -1
- package/dist/utils.d.ts +12 -14
- package/dist/utils.d.ts.map +1 -1
- package/dist/utils.js +6 -24
- package/dist/utils.js.map +1 -1
- package/package.json +6 -3
- package/src/external.ts +34 -58
- package/src/index.ts +2 -8
- package/src/remote.ts +56 -120
- package/src/rest.ts +31 -87
- package/src/utils.ts +13 -43
package/dist/external.d.ts
CHANGED
|
@@ -1,43 +1,61 @@
|
|
|
1
|
-
import type { Entry, ExternalService,
|
|
1
|
+
import type { Entry, ExternalService, Json } from "@skipruntime/api";
|
|
2
2
|
export interface ExternalResource {
|
|
3
|
-
open(params:
|
|
4
|
-
|
|
5
|
-
|
|
3
|
+
open(params: {
|
|
4
|
+
[param: string]: string | number;
|
|
5
|
+
}, callbacks: {
|
|
6
|
+
update: (updates: Entry<Json, Json>[], isInit: boolean) => void;
|
|
7
|
+
error: (error: Json) => void;
|
|
6
8
|
loading: () => void;
|
|
7
|
-
}
|
|
8
|
-
close(params:
|
|
9
|
+
}): void;
|
|
10
|
+
close(params: {
|
|
11
|
+
[param: string]: string | number;
|
|
12
|
+
}): void;
|
|
9
13
|
}
|
|
10
14
|
export declare class GenericExternalService implements ExternalService {
|
|
11
15
|
private resources;
|
|
12
|
-
constructor(resources:
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
+
constructor(resources: {
|
|
17
|
+
[name: string]: ExternalResource;
|
|
18
|
+
});
|
|
19
|
+
subscribe(resourceName: string, params: {
|
|
20
|
+
[param: string]: string | number;
|
|
21
|
+
}, callbacks: {
|
|
22
|
+
update: (updates: Entry<Json, Json>[], isInit: boolean) => void;
|
|
23
|
+
error: (error: Json) => void;
|
|
16
24
|
loading: () => void;
|
|
17
|
-
}
|
|
18
|
-
unsubscribe(resourceName: string, params:
|
|
25
|
+
}): void;
|
|
26
|
+
unsubscribe(resourceName: string, params: {
|
|
27
|
+
[param: string]: string;
|
|
28
|
+
}): void;
|
|
19
29
|
shutdown(): void;
|
|
20
30
|
}
|
|
21
31
|
export declare class TimerResource implements ExternalResource {
|
|
22
32
|
private intervals;
|
|
23
|
-
open(params:
|
|
24
|
-
|
|
25
|
-
|
|
33
|
+
open(params: {
|
|
34
|
+
[param: string]: string | number;
|
|
35
|
+
}, callbacks: {
|
|
36
|
+
update: (updates: Entry<Json, Json>[], isInit: boolean) => void;
|
|
37
|
+
error: (error: Json) => void;
|
|
26
38
|
loading: () => void;
|
|
27
|
-
}
|
|
28
|
-
close(params:
|
|
39
|
+
}): void;
|
|
40
|
+
close(params: {
|
|
41
|
+
[param: string]: string | number;
|
|
42
|
+
}): void;
|
|
29
43
|
}
|
|
30
|
-
export declare class Polled<S extends
|
|
44
|
+
export declare class Polled<S extends Json, K extends Json, V extends Json> implements ExternalResource {
|
|
31
45
|
private url;
|
|
32
46
|
private duration;
|
|
33
47
|
private conv;
|
|
34
48
|
private intervals;
|
|
35
49
|
constructor(url: string, duration: number, conv: (data: S) => Entry<K, V>[]);
|
|
36
|
-
open(params:
|
|
37
|
-
|
|
38
|
-
|
|
50
|
+
open(params: {
|
|
51
|
+
[param: string]: string | number;
|
|
52
|
+
}, callbacks: {
|
|
53
|
+
update: (updates: Entry<Json, Json>[], isInit: boolean) => void;
|
|
54
|
+
error: (error: Json) => void;
|
|
39
55
|
loading: () => void;
|
|
40
|
-
}
|
|
41
|
-
close(params:
|
|
56
|
+
}): void;
|
|
57
|
+
close(params: {
|
|
58
|
+
[param: string]: string | number;
|
|
59
|
+
}): void;
|
|
42
60
|
}
|
|
43
61
|
//# sourceMappingURL=external.d.ts.map
|
package/dist/external.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"external.d.ts","sourceRoot":"","sources":["../src/external.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,eAAe,EAAE,
|
|
1
|
+
{"version":3,"file":"external.d.ts","sourceRoot":"","sources":["../src/external.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,eAAe,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAC;AAGrE,MAAM,WAAW,gBAAgB;IAC/B,IAAI,CACF,MAAM,EAAE;QAAE,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAAA;KAAE,EAC5C,SAAS,EAAE;QACT,MAAM,EAAE,CAAC,OAAO,EAAE,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,EAAE,MAAM,EAAE,OAAO,KAAK,IAAI,CAAC;QAChE,KAAK,EAAE,CAAC,KAAK,EAAE,IAAI,KAAK,IAAI,CAAC;QAC7B,OAAO,EAAE,MAAM,IAAI,CAAC;KACrB,GACA,IAAI,CAAC;IAER,KAAK,CAAC,MAAM,EAAE;QAAE,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC;CAC3D;AAED,qBAAa,sBAAuB,YAAW,eAAe;IAChD,OAAO,CAAC,SAAS;gBAAT,SAAS,EAAE;QAAE,CAAC,IAAI,EAAE,MAAM,GAAG,gBAAgB,CAAA;KAAE;IAEnE,SAAS,CACP,YAAY,EAAE,MAAM,EACpB,MAAM,EAAE;QAAE,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAAA;KAAE,EAC5C,SAAS,EAAE;QACT,MAAM,EAAE,CAAC,OAAO,EAAE,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,EAAE,MAAM,EAAE,OAAO,KAAK,IAAI,CAAC;QAChE,KAAK,EAAE,CAAC,KAAK,EAAE,IAAI,KAAK,IAAI,CAAC;QAC7B,OAAO,EAAE,MAAM,IAAI,CAAC;KACrB,GACA,IAAI;IAUP,WAAW,CAAC,YAAY,EAAE,MAAM,EAAE,MAAM,EAAE;QAAE,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,CAAA;KAAE;IAUrE,QAAQ,IAAI,IAAI;CAGjB;AAID,qBAAa,aAAc,YAAW,gBAAgB;IACpD,OAAO,CAAC,SAAS,CAAkD;IAEnE,IAAI,CACF,MAAM,EAAE;QAAE,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAAA;KAAE,EAC5C,SAAS,EAAE;QACT,MAAM,EAAE,CAAC,OAAO,EAAE,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,EAAE,MAAM,EAAE,OAAO,KAAK,IAAI,CAAC;QAChE,KAAK,EAAE,CAAC,KAAK,EAAE,IAAI,KAAK,IAAI,CAAC;QAC7B,OAAO,EAAE,MAAM,IAAI,CAAC;KACrB;IAsBH,KAAK,CAAC,MAAM,EAAE;QAAE,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAAA;KAAE,GAAG,IAAI;CAQ1D;AAED,qBAAa,MAAM,CAAC,CAAC,SAAS,IAAI,EAAE,CAAC,SAAS,IAAI,EAAE,CAAC,SAAS,IAAI,CAChE,YAAW,gBAAgB;IAKzB,OAAO,CAAC,GAAG;IACX,OAAO,CAAC,QAAQ;IAChB,OAAO,CAAC,IAAI;IALd,OAAO,CAAC,SAAS,CAA8B;gBAGrC,GAAG,EAAE,MAAM,EACX,QAAQ,EAAE,MAAM,EAChB,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE;IAG1C,IAAI,CACF,MAAM,EAAE;QAAE,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAAA;KAAE,EAC5C,SAAS,EAAE;QACT,MAAM,EAAE,CAAC,OAAO,EAAE,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,EAAE,MAAM,EAAE,OAAO,KAAK,IAAI,CAAC;QAChE,KAAK,EAAE,CAAC,KAAK,EAAE,IAAI,KAAK,IAAI,CAAC;QAC7B,OAAO,EAAE,MAAM,IAAI,CAAC;KACrB,GACA,IAAI;IAuBP,KAAK,CAAC,MAAM,EAAE;QAAE,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAAA;KAAE,GAAG,IAAI;CAM1D"}
|
package/dist/external.js
CHANGED
|
@@ -3,19 +3,19 @@ export class GenericExternalService {
|
|
|
3
3
|
constructor(resources) {
|
|
4
4
|
this.resources = resources;
|
|
5
5
|
}
|
|
6
|
-
subscribe(resourceName, params, callbacks
|
|
6
|
+
subscribe(resourceName, params, callbacks) {
|
|
7
7
|
const resource = this.resources[resourceName];
|
|
8
8
|
if (!resource) {
|
|
9
9
|
throw new Error(`Unkonwn resource named '${resourceName}'`);
|
|
10
10
|
}
|
|
11
|
-
resource.open(params, callbacks
|
|
11
|
+
resource.open(params, callbacks);
|
|
12
12
|
}
|
|
13
|
-
unsubscribe(resourceName, params
|
|
13
|
+
unsubscribe(resourceName, params) {
|
|
14
14
|
const resource = this.resources[resourceName];
|
|
15
15
|
if (!resource) {
|
|
16
16
|
throw new Error(`Unkonwn resource named '${resourceName}'`);
|
|
17
17
|
}
|
|
18
|
-
resource.close(params
|
|
18
|
+
resource.close(params);
|
|
19
19
|
}
|
|
20
20
|
shutdown() {
|
|
21
21
|
return;
|
|
@@ -25,14 +25,14 @@ export class TimerResource {
|
|
|
25
25
|
constructor() {
|
|
26
26
|
this.intervals = new Map();
|
|
27
27
|
}
|
|
28
|
-
open(params, callbacks
|
|
28
|
+
open(params, callbacks) {
|
|
29
29
|
const time = new Date().getTime();
|
|
30
30
|
const values = [];
|
|
31
31
|
for (const name of Object.keys(params)) {
|
|
32
32
|
values.push([name, [time]]);
|
|
33
33
|
}
|
|
34
34
|
callbacks.update(values, true);
|
|
35
|
-
const id = toId(params
|
|
35
|
+
const id = toId(params);
|
|
36
36
|
const intervals = {};
|
|
37
37
|
for (const [name, duration] of Object.entries(params)) {
|
|
38
38
|
const ms = Number(duration);
|
|
@@ -45,8 +45,8 @@ export class TimerResource {
|
|
|
45
45
|
}
|
|
46
46
|
this.intervals.set(id, intervals);
|
|
47
47
|
}
|
|
48
|
-
close(params
|
|
49
|
-
const intervals = this.intervals.get(toId(params
|
|
48
|
+
close(params) {
|
|
49
|
+
const intervals = this.intervals.get(toId(params));
|
|
50
50
|
if (intervals != null) {
|
|
51
51
|
for (const interval of Object.values(intervals)) {
|
|
52
52
|
clearInterval(interval);
|
|
@@ -61,13 +61,13 @@ export class Polled {
|
|
|
61
61
|
this.conv = conv;
|
|
62
62
|
this.intervals = new Map();
|
|
63
63
|
}
|
|
64
|
-
open(params, callbacks
|
|
65
|
-
this.close(params
|
|
66
|
-
const
|
|
64
|
+
open(params, callbacks) {
|
|
65
|
+
this.close(params);
|
|
66
|
+
const queryParams = {};
|
|
67
67
|
for (const [key, value] of Object.entries(params)) {
|
|
68
|
-
|
|
68
|
+
queryParams[key] = value.toString();
|
|
69
69
|
}
|
|
70
|
-
const strParams = new URLSearchParams(
|
|
70
|
+
const strParams = new URLSearchParams(queryParams).toString();
|
|
71
71
|
const url = `${this.url}?${strParams}`;
|
|
72
72
|
const call = () => {
|
|
73
73
|
callbacks.loading();
|
|
@@ -81,20 +81,19 @@ export class Polled {
|
|
|
81
81
|
});
|
|
82
82
|
};
|
|
83
83
|
call();
|
|
84
|
-
this.intervals.set(toId(params
|
|
84
|
+
this.intervals.set(toId(params), setInterval(call, this.duration));
|
|
85
85
|
}
|
|
86
|
-
close(params
|
|
87
|
-
const interval = this.intervals.get(toId(params
|
|
86
|
+
close(params) {
|
|
87
|
+
const interval = this.intervals.get(toId(params));
|
|
88
88
|
if (interval) {
|
|
89
89
|
clearInterval(interval);
|
|
90
90
|
}
|
|
91
91
|
}
|
|
92
92
|
}
|
|
93
|
-
function toId(params
|
|
93
|
+
function toId(params) {
|
|
94
94
|
const strparams = Object.entries(params)
|
|
95
95
|
.map(([key, value]) => `${key}:${value.toString()}`)
|
|
96
96
|
.sort();
|
|
97
|
-
|
|
98
|
-
return `[${strparams.join(",")}]${hex}`;
|
|
97
|
+
return `[${strparams.join(",")}]`;
|
|
99
98
|
}
|
|
100
99
|
//# sourceMappingURL=external.js.map
|
package/dist/external.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"external.js","sourceRoot":"","sources":["../src/external.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"external.js","sourceRoot":"","sources":["../src/external.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAetC,MAAM,OAAO,sBAAsB;IACjC,YAAoB,SAA+C;QAA/C,cAAS,GAAT,SAAS,CAAsC;IAAG,CAAC;IAEvE,SAAS,CACP,YAAoB,EACpB,MAA4C,EAC5C,SAIC;QAED,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAE/B,CAAC;QACd,IAAI,CAAC,QAAQ,EAAE,CAAC;YACd,MAAM,IAAI,KAAK,CAAC,2BAA2B,YAAY,GAAG,CAAC,CAAC;QAC9D,CAAC;QACD,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IACnC,CAAC;IAED,WAAW,CAAC,YAAoB,EAAE,MAAmC;QACnE,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAE/B,CAAC;QACd,IAAI,CAAC,QAAQ,EAAE,CAAC;YACd,MAAM,IAAI,KAAK,CAAC,2BAA2B,YAAY,GAAG,CAAC,CAAC;QAC9D,CAAC;QACD,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IACzB,CAAC;IAED,QAAQ;QACN,OAAO;IACT,CAAC;CACF;AAID,MAAM,OAAO,aAAa;IAA1B;QACU,cAAS,GAAG,IAAI,GAAG,EAAuC,CAAC;IAsCrE,CAAC;IApCC,IAAI,CACF,MAA4C,EAC5C,SAIC;QAED,MAAM,IAAI,GAAG,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,CAAC;QAClC,MAAM,MAAM,GAA4B,EAAE,CAAC;QAC3C,KAAK,MAAM,IAAI,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;YACvC,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC9B,CAAC;QACD,SAAS,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAC/B,MAAM,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC;QACxB,MAAM,SAAS,GAAgC,EAAE,CAAC;QAClD,KAAK,MAAM,CAAC,IAAI,EAAE,QAAQ,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;YACtD,MAAM,EAAE,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;YAC5B,IAAI,EAAE,GAAG,CAAC,EAAE,CAAC;gBACX,SAAS,CAAC,IAAI,CAAC,GAAG,WAAW,CAAC,GAAG,EAAE;oBACjC,MAAM,QAAQ,GAAsB,CAAC,IAAI,EAAE,CAAC,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;oBACnE,SAAS,CAAC,MAAM,CAAC,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC,CAAC;gBACrC,CAAC,EAAE,EAAE,CAAC,CAAC;YACT,CAAC;QACH,CAAC;QACD,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,EAAE,SAAS,CAAC,CAAC;IACpC,CAAC;IAED,KAAK,CAAC,MAA4C;QAChD,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;QACnD,IAAI,SAAS,IAAI,IAAI,EAAE,CAAC;YACtB,KAAK,MAAM,QAAQ,IAAI,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE,CAAC;gBAChD,aAAa,CAAC,QAAQ,CAAC,CAAC;YAC1B,CAAC;QACH,CAAC;IACH,CAAC;CACF;AAED,MAAM,OAAO,MAAM;IAKjB,YACU,GAAW,EACX,QAAgB,EAChB,IAAgC;QAFhC,QAAG,GAAH,GAAG,CAAQ;QACX,aAAQ,GAAR,QAAQ,CAAQ;QAChB,SAAI,GAAJ,IAAI,CAA4B;QALlC,cAAS,GAAG,IAAI,GAAG,EAAmB,CAAC;IAM5C,CAAC;IAEJ,IAAI,CACF,MAA4C,EAC5C,SAIC;QAED,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QACnB,MAAM,WAAW,GAAgC,EAAE,CAAC;QACpD,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;YAClD,WAAW,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAC;QACtC,CAAC;QACD,MAAM,SAAS,GAAG,IAAI,eAAe,CAAC,WAAW,CAAC,CAAC,QAAQ,EAAE,CAAC;QAC9D,MAAM,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,IAAI,SAAS,EAAE,CAAC;QACvC,MAAM,IAAI,GAAG,GAAG,EAAE;YAChB,SAAS,CAAC,OAAO,EAAE,CAAC;YACpB,SAAS,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,CAAC;iBACtB,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE;gBACV,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAM,CAAC,EAAE,IAAI,CAAC,CAAC;YAC/C,CAAC,CAAC;iBACD,KAAK,CAAC,CAAC,CAAU,EAAE,EAAE;gBACpB,SAAS,CAAC,KAAK,CAAC,CAAC,YAAY,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;gBACpE,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YACnB,CAAC,CAAC,CAAC;QACP,CAAC,CAAC;QACF,IAAI,EAAE,CAAC;QACP,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,WAAW,CAAC,IAAI,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;IACrE,CAAC;IAED,KAAK,CAAC,MAA4C;QAChD,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;QAClD,IAAI,QAAQ,EAAE,CAAC;YACb,aAAa,CAAC,QAAQ,CAAC,CAAC;QAC1B,CAAC;IACH,CAAC;CACF;AAED,SAAS,IAAI,CAAC,MAA4C;IACxD,MAAM,SAAS,GAAG,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC;SACrC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,KAAK,CAAC,QAAQ,EAAE,EAAE,CAAC;SACnD,IAAI,EAAE,CAAC;IACV,OAAO,IAAI,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC;AACpC,CAAC"}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
export { SkipExternalService } from "./remote.js";
|
|
2
2
|
export { type ExternalResource, GenericExternalService, Polled, } from "./external.js";
|
|
3
|
-
export { Sum, Min, Max, CountMapper
|
|
3
|
+
export { Sum, Min, Max, CountMapper } from "./utils.js";
|
|
4
|
+
export { RESTWrapperOfSkipService } from "./rest.js";
|
|
4
5
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAClD,OAAO,EACL,KAAK,gBAAgB,EACrB,sBAAsB,EACtB,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAClD,OAAO,EACL,KAAK,gBAAgB,EACrB,sBAAsB,EACtB,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACxD,OAAO,EAAE,wBAAwB,EAAE,MAAM,WAAW,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
export { SkipExternalService } from "./remote.js";
|
|
2
2
|
export { GenericExternalService, Polled, } from "./external.js";
|
|
3
|
-
export { Sum, Min, Max, CountMapper
|
|
3
|
+
export { Sum, Min, Max, CountMapper } from "./utils.js";
|
|
4
|
+
export { RESTWrapperOfSkipService } from "./rest.js";
|
|
4
5
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAClD,OAAO,EAEL,sBAAsB,EACtB,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAClD,OAAO,EAEL,sBAAsB,EACtB,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACxD,OAAO,EAAE,wBAAwB,EAAE,MAAM,WAAW,CAAC"}
|
package/dist/remote.d.ts
CHANGED
|
@@ -1,23 +1,22 @@
|
|
|
1
|
-
import type { Entry, ExternalService,
|
|
2
|
-
import {
|
|
3
|
-
import { type Entrypoint } from "./rest.js";
|
|
1
|
+
import type { Entry, ExternalService, Json } from "@skipruntime/api";
|
|
2
|
+
import type { Entrypoint } from "./rest.js";
|
|
4
3
|
export declare class SkipExternalService implements ExternalService {
|
|
5
4
|
private url;
|
|
6
|
-
private
|
|
7
|
-
private creds?;
|
|
8
|
-
private client?;
|
|
5
|
+
private control_url;
|
|
9
6
|
private resources;
|
|
10
|
-
constructor(url: string,
|
|
11
|
-
static
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
7
|
+
constructor(url: string, control_url: string);
|
|
8
|
+
static direct(entrypoint: Entrypoint): SkipExternalService;
|
|
9
|
+
subscribe(resource: string, params: {
|
|
10
|
+
[param: string]: string;
|
|
11
|
+
}, callbacks: {
|
|
12
|
+
update: (updates: Entry<Json, Json>[], isInitial: boolean) => void;
|
|
13
|
+
error: (error: Json) => void;
|
|
16
14
|
loading: () => void;
|
|
17
|
-
}
|
|
18
|
-
unsubscribe(resource: string, params:
|
|
15
|
+
}): void;
|
|
16
|
+
unsubscribe(resource: string, params: {
|
|
17
|
+
[param: string]: string;
|
|
18
|
+
}): void;
|
|
19
19
|
shutdown(): void;
|
|
20
|
-
private subscribe_;
|
|
21
20
|
private toId;
|
|
22
21
|
}
|
|
23
22
|
//# sourceMappingURL=remote.d.ts.map
|
package/dist/remote.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"remote.d.ts","sourceRoot":"","sources":["../src/remote.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"remote.d.ts","sourceRoot":"","sources":["../src/remote.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,KAAK,EAAE,eAAe,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAC;AAErE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AAM5C,qBAAa,mBAAoB,YAAW,eAAe;IAIvD,OAAO,CAAC,GAAG;IACX,OAAO,CAAC,WAAW;IAJrB,OAAO,CAAC,SAAS,CAA+B;gBAGtC,GAAG,EAAE,MAAM,EACX,WAAW,EAAE,MAAM;IAI7B,MAAM,CAAC,MAAM,CAAC,UAAU,EAAE,UAAU,GAAG,mBAAmB;IAU1D,SAAS,CACP,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE;QAAE,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,CAAA;KAAE,EACnC,SAAS,EAAE;QACT,MAAM,EAAE,CAAC,OAAO,EAAE,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,EAAE,SAAS,EAAE,OAAO,KAAK,IAAI,CAAC;QAEnE,KAAK,EAAE,CAAC,KAAK,EAAE,IAAI,KAAK,IAAI,CAAC;QAE7B,OAAO,EAAE,MAAM,IAAI,CAAC;KACrB,GACA,IAAI;IAiCP,WAAW,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE;QAAE,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,CAAA;KAAE;IAKjE,QAAQ,IAAI,IAAI;IAMhB,OAAO,CAAC,IAAI;CAQb"}
|
package/dist/remote.js
CHANGED
|
@@ -1,83 +1,71 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
import
|
|
1
|
+
// TODO: Remove once global `EventSource` makes it out of experimental
|
|
2
|
+
// in nodejs LTS.
|
|
3
|
+
import EventSource from "eventsource";
|
|
4
4
|
export class SkipExternalService {
|
|
5
|
-
constructor(url,
|
|
5
|
+
constructor(url, control_url) {
|
|
6
6
|
this.url = url;
|
|
7
|
-
this.
|
|
8
|
-
this.creds = creds;
|
|
7
|
+
this.control_url = control_url;
|
|
9
8
|
this.resources = new Map();
|
|
10
9
|
}
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
10
|
+
// TODO: Support Skip external services going through a gateway.
|
|
11
|
+
static direct(entrypoint) {
|
|
12
|
+
let url = `http://${entrypoint.host}:${entrypoint.streaming_port.toString()}`;
|
|
13
|
+
let control_url = `http://${entrypoint.host}:${entrypoint.control_port.toString()}`;
|
|
14
|
+
if (entrypoint.secured) {
|
|
15
|
+
url = `https://${entrypoint.host}:${entrypoint.streaming_port.toString()}`;
|
|
16
|
+
control_url = `https://${entrypoint.host}:${entrypoint.control_port.toString()}`;
|
|
17
|
+
}
|
|
18
|
+
return new SkipExternalService(url, control_url);
|
|
16
19
|
}
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
20
|
+
subscribe(resource, params, callbacks) {
|
|
21
|
+
// TODO Manage Status
|
|
22
|
+
fetch(`${this.control_url}/v1/streams`, {
|
|
23
|
+
method: "POST",
|
|
24
|
+
headers: {
|
|
25
|
+
"Content-Type": "application/json",
|
|
26
|
+
},
|
|
27
|
+
body: JSON.stringify({
|
|
28
|
+
resource,
|
|
29
|
+
params,
|
|
30
|
+
}),
|
|
31
|
+
})
|
|
32
|
+
.then((resp) => resp.json())
|
|
33
|
+
.then((uuid) => {
|
|
34
|
+
const evSource = new EventSource(`${this.url}/v1/streams/${uuid}`);
|
|
35
|
+
evSource.addEventListener("init", (e) => {
|
|
36
|
+
const updates = JSON.parse(e.data);
|
|
37
|
+
callbacks.update(updates, true);
|
|
38
|
+
});
|
|
39
|
+
evSource.addEventListener("update", (e) => {
|
|
40
|
+
const updates = JSON.parse(e.data);
|
|
41
|
+
callbacks.update(updates, false);
|
|
42
|
+
});
|
|
43
|
+
evSource.onerror = (e) => {
|
|
44
|
+
console.log(e);
|
|
25
45
|
};
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
return reactiveResponse;
|
|
31
|
-
};
|
|
32
|
-
return new SkipExternalService(url, auth, creds);
|
|
33
|
-
}
|
|
34
|
-
subscribe(resource, params, callbacks, reactiveAuth) {
|
|
35
|
-
if (!this.client) {
|
|
36
|
-
if (!this.creds) {
|
|
37
|
-
this.client = Protocol.generateCredentials().then((creds) => {
|
|
38
|
-
this.creds = creds;
|
|
39
|
-
return connect(this.url, this.creds).then((c) => [c, creds]);
|
|
40
|
-
});
|
|
41
|
-
}
|
|
42
|
-
else {
|
|
43
|
-
this.client = connect(this.url, this.creds).then((c) => {
|
|
44
|
-
return [c, this.creds];
|
|
45
|
-
});
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
this.subscribe_(resource, params, callbacks, reactiveAuth).catch((e) => {
|
|
49
|
-
console.error(e);
|
|
46
|
+
this.resources.set(this.toId(resource, params), evSource);
|
|
47
|
+
})
|
|
48
|
+
.catch((e) => {
|
|
49
|
+
console.log(e);
|
|
50
50
|
});
|
|
51
51
|
}
|
|
52
|
-
unsubscribe(resource, params
|
|
53
|
-
const closable = this.resources.get(this.toId(resource, params
|
|
52
|
+
unsubscribe(resource, params) {
|
|
53
|
+
const closable = this.resources.get(this.toId(resource, params));
|
|
54
54
|
if (closable)
|
|
55
55
|
closable.close();
|
|
56
56
|
}
|
|
57
57
|
shutdown() {
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
.then((client) => {
|
|
61
|
-
client[0].close();
|
|
62
|
-
})
|
|
63
|
-
.catch((e) => console.error(e));
|
|
58
|
+
for (const res of this.resources.values()) {
|
|
59
|
+
res.close();
|
|
64
60
|
}
|
|
65
61
|
}
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
const publicKey = new Uint8Array(await Protocol.exportKey(creds.publicKey));
|
|
69
|
-
const reactive = await this.auth(resource, params, publicKey);
|
|
70
|
-
// TODO Manage Status
|
|
71
|
-
const close = client.subscribe(reactive.collection, BigInt(reactive.watermark), callbacks.update);
|
|
72
|
-
this.resources.set(this.toId(resource, params, reactiveAuth), close);
|
|
73
|
-
}
|
|
74
|
-
toId(resource, params, reactiveAuth) {
|
|
62
|
+
toId(resource, params) {
|
|
63
|
+
// TODO: This is equivalent to `querystring.encode(params, ',', ':')`.
|
|
75
64
|
const strparams = [];
|
|
76
65
|
for (const key of Object.keys(params).sort()) {
|
|
77
66
|
strparams.push(`${key}:${params[key]}`);
|
|
78
67
|
}
|
|
79
|
-
|
|
80
|
-
return `${resource}[${strparams.join(",")}]${hex}`;
|
|
68
|
+
return `${resource}[${strparams.join(",")}]`;
|
|
81
69
|
}
|
|
82
70
|
}
|
|
83
71
|
//# sourceMappingURL=remote.js.map
|
package/dist/remote.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"remote.js","sourceRoot":"","sources":["../src/remote.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"remote.js","sourceRoot":"","sources":["../src/remote.ts"],"names":[],"mappings":"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"}
|
package/dist/rest.d.ts
CHANGED
|
@@ -1,22 +1,24 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type { Json, Entry } from "@skipruntime/api";
|
|
2
2
|
export type Entrypoint = {
|
|
3
3
|
host: string;
|
|
4
|
-
|
|
4
|
+
streaming_port: number;
|
|
5
|
+
control_port: number;
|
|
5
6
|
secured?: boolean;
|
|
6
7
|
};
|
|
7
|
-
export declare function fetchJSON<V>(url: string, method?: "POST" | "GET" | "PUT" | "PATCH" | "HEAD" | "DELETE", headers?:
|
|
8
|
-
|
|
8
|
+
export declare function fetchJSON<V>(url: string, method?: "POST" | "GET" | "PUT" | "PATCH" | "HEAD" | "DELETE", headers?: {
|
|
9
|
+
[header: string]: string;
|
|
10
|
+
}, data?: Json): Promise<[V | null, Headers]>;
|
|
11
|
+
export declare class RESTWrapperOfSkipService {
|
|
9
12
|
private entrypoint;
|
|
10
13
|
constructor(entrypoint?: Entrypoint);
|
|
11
|
-
getAll<K extends
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
put<V extends
|
|
18
|
-
patch<K extends
|
|
19
|
-
deleteKey(collection: string, key:
|
|
20
|
-
private header;
|
|
14
|
+
getAll<K extends Json, V extends Json>(resource: string, params: {
|
|
15
|
+
[param: string]: string;
|
|
16
|
+
}): Promise<Entry<K, V>[]>;
|
|
17
|
+
getArray<V extends Json>(resource: string, params: {
|
|
18
|
+
[param: string]: string;
|
|
19
|
+
}, key: string): Promise<V[]>;
|
|
20
|
+
put<K extends Json, V extends Json>(collection: string, key: K, value: V[]): Promise<void>;
|
|
21
|
+
patch<K extends Json, V extends Json>(collection: string, values: Entry<K, V>[]): Promise<void>;
|
|
22
|
+
deleteKey<K extends Json>(collection: string, key: K): Promise<void>;
|
|
21
23
|
}
|
|
22
24
|
//# sourceMappingURL=rest.d.ts.map
|
package/dist/rest.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"rest.d.ts","sourceRoot":"","sources":["../src/rest.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,
|
|
1
|
+
{"version":3,"file":"rest.d.ts","sourceRoot":"","sources":["../src/rest.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AAEpD,MAAM,MAAM,UAAU,GAAG;IACvB,IAAI,EAAE,MAAM,CAAC;IACb,cAAc,EAAE,MAAM,CAAC;IACvB,YAAY,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB,CAAC;AAQF,wBAAsB,SAAS,CAAC,CAAC,EAC/B,GAAG,EAAE,MAAM,EACX,MAAM,GAAE,MAAM,GAAG,KAAK,GAAG,KAAK,GAAG,OAAO,GAAG,MAAM,GAAG,QAAgB,EACpE,OAAO,GAAE;IAAE,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAAA;CAAO,EAC1C,IAAI,CAAC,EAAE,IAAI,GACV,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI,EAAE,OAAO,CAAC,CAAC,CAqB9B;AAED,qBAAa,wBAAwB;IACnC,OAAO,CAAC,UAAU,CAAS;gBAGzB,UAAU,GAAE,UAIX;IAKG,MAAM,CAAC,CAAC,SAAS,IAAI,EAAE,CAAC,SAAS,IAAI,EACzC,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE;QAAE,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,CAAA;KAAE,GAClC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC;IAUnB,QAAQ,CAAC,CAAC,SAAS,IAAI,EAC3B,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE;QAAE,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,CAAA;KAAE,EACnC,GAAG,EAAE,MAAM,GACV,OAAO,CAAC,CAAC,EAAE,CAAC;IAST,GAAG,CAAC,CAAC,SAAS,IAAI,EAAE,CAAC,SAAS,IAAI,EACtC,UAAU,EAAE,MAAM,EAClB,GAAG,EAAE,CAAC,EACN,KAAK,EAAE,CAAC,EAAE,GACT,OAAO,CAAC,IAAI,CAAC;IAIV,KAAK,CAAC,CAAC,SAAS,IAAI,EAAE,CAAC,SAAS,IAAI,EACxC,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,GACpB,OAAO,CAAC,IAAI,CAAC;IASV,SAAS,CAAC,CAAC,SAAS,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;CAG3E"}
|
package/dist/rest.js
CHANGED
|
@@ -1,8 +1,7 @@
|
|
|
1
|
-
import { parseReactiveResponse } from "./utils.js";
|
|
2
1
|
function toHttp(entrypoint) {
|
|
3
2
|
if (entrypoint.secured)
|
|
4
|
-
return `https://${entrypoint.host}:${entrypoint.
|
|
5
|
-
return `http://${entrypoint.host}:${entrypoint.
|
|
3
|
+
return `https://${entrypoint.host}:${entrypoint.control_port}`;
|
|
4
|
+
return `http://${entrypoint.host}:${entrypoint.control_port}`;
|
|
6
5
|
}
|
|
7
6
|
export async function fetchJSON(url, method = "GET", headers = {}, data) {
|
|
8
7
|
const body = data ? JSON.stringify(data) : undefined;
|
|
@@ -25,73 +24,33 @@ export async function fetchJSON(url, method = "GET", headers = {}, data) {
|
|
|
25
24
|
: null;
|
|
26
25
|
return [responseJSON, response.headers];
|
|
27
26
|
}
|
|
28
|
-
export class
|
|
27
|
+
export class RESTWrapperOfSkipService {
|
|
29
28
|
constructor(entrypoint = {
|
|
30
29
|
host: "localhost",
|
|
31
|
-
|
|
30
|
+
streaming_port: 8080,
|
|
31
|
+
control_port: 8081,
|
|
32
32
|
}) {
|
|
33
33
|
this.entrypoint = toHttp(entrypoint);
|
|
34
34
|
}
|
|
35
|
-
async getAll(resource, params
|
|
35
|
+
async getAll(resource, params) {
|
|
36
36
|
const qParams = new URLSearchParams(params).toString();
|
|
37
|
-
|
|
38
|
-
if (reactiveAuth) {
|
|
39
|
-
if (typeof reactiveAuth == "string") {
|
|
40
|
-
header = {
|
|
41
|
-
"X-Reactive-Auth": reactiveAuth,
|
|
42
|
-
};
|
|
43
|
-
}
|
|
44
|
-
else {
|
|
45
|
-
header = {
|
|
46
|
-
"X-Reactive-Auth": Buffer.from(reactiveAuth.buffer).toString("base64"),
|
|
47
|
-
};
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
const [optValues, headers] = await fetchJSON(`${this.entrypoint}/v1/${resource}?${qParams}`, "GET", header);
|
|
51
|
-
const reactive = parseReactiveResponse(headers);
|
|
37
|
+
const [optValues, _headers] = await fetchJSON(`${this.entrypoint}/v1/resources/${resource}?${qParams}`, "GET");
|
|
52
38
|
const values = optValues ?? [];
|
|
53
|
-
return
|
|
39
|
+
return values;
|
|
54
40
|
}
|
|
55
|
-
async
|
|
41
|
+
async getArray(resource, params, key) {
|
|
56
42
|
const qParams = new URLSearchParams(params).toString();
|
|
57
|
-
const
|
|
58
|
-
const [_data, headers] = await fetchJSON(`${this.entrypoint}/v1/${resource}?${qParams}`, "HEAD", header);
|
|
59
|
-
const reactiveResponse = parseReactiveResponse(headers);
|
|
60
|
-
if (!reactiveResponse)
|
|
61
|
-
throw new Error("Reactive response must be suplied.");
|
|
62
|
-
else {
|
|
63
|
-
return reactiveResponse;
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
async getArray(resource, params, key, reactiveAuth) {
|
|
67
|
-
const qParams = new URLSearchParams(params).toString();
|
|
68
|
-
const header = this.header(reactiveAuth);
|
|
69
|
-
const [data, _headers] = await fetchJSON(`${this.entrypoint}/v1/${resource}/${key}?${qParams}`, "GET", header);
|
|
43
|
+
const [data, _headers] = await fetchJSON(`${this.entrypoint}/v1/resources/${resource}/${key}?${qParams}`, "GET");
|
|
70
44
|
return data ?? [];
|
|
71
45
|
}
|
|
72
46
|
async put(collection, key, value) {
|
|
73
|
-
await
|
|
47
|
+
return await this.patch(collection, [[key, value]]);
|
|
74
48
|
}
|
|
75
49
|
async patch(collection, values) {
|
|
76
|
-
await fetchJSON(`${this.entrypoint}/v1/${collection}`, "PATCH", {}, values);
|
|
50
|
+
await fetchJSON(`${this.entrypoint}/v1/inputs/${collection}`, "PATCH", {}, values);
|
|
77
51
|
}
|
|
78
52
|
async deleteKey(collection, key) {
|
|
79
|
-
await
|
|
80
|
-
}
|
|
81
|
-
header(reactiveAuth) {
|
|
82
|
-
if (reactiveAuth) {
|
|
83
|
-
if (typeof reactiveAuth == "string") {
|
|
84
|
-
return {
|
|
85
|
-
"X-Reactive-Auth": reactiveAuth,
|
|
86
|
-
};
|
|
87
|
-
}
|
|
88
|
-
else {
|
|
89
|
-
return {
|
|
90
|
-
"X-Reactive-Auth": Buffer.from(reactiveAuth.buffer).toString("base64"),
|
|
91
|
-
};
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
return {};
|
|
53
|
+
return await this.patch(collection, [[key, []]]);
|
|
95
54
|
}
|
|
96
55
|
}
|
|
97
56
|
//# sourceMappingURL=rest.js.map
|