@yuants/vendor-coinex 0.2.55 → 0.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.js +0 -1
- package/dist/index.js.map +1 -1
- package/lib/index.d.ts +1 -1
- package/lib/index.d.ts.map +1 -1
- package/lib/index.js +0 -1
- package/lib/index.js.map +1 -1
- package/package.json +5 -5
- package/temp/build/typescript/ts_yMqt30qk.json +1 -1
- package/temp/package-deps.json +5 -6
- package/temp/test/jest/haste-map-f9e6d7f2f61a9a2ed86514b795962ab0-9feea4b494adda9e83642d00f3645f9e-ffc2214134e666f8bd9c8d79367fbdf0 +0 -0
- package/dist/interest_rate.js +0 -61
- package/dist/interest_rate.js.map +0 -1
- package/lib/interest_rate.d.ts +0 -2
- package/lib/interest_rate.d.ts.map +0 -1
- package/lib/interest_rate.js +0 -63
- package/lib/interest_rate.js.map +0 -1
package/temp/package-deps.json
CHANGED
|
@@ -1,15 +1,14 @@
|
|
|
1
1
|
{
|
|
2
|
-
"apps/vendor-coinex/CHANGELOG.json": "
|
|
3
|
-
"apps/vendor-coinex/CHANGELOG.md": "
|
|
2
|
+
"apps/vendor-coinex/CHANGELOG.json": "3c8affe73a0fec14c1662f9ae30936adbd9df09f",
|
|
3
|
+
"apps/vendor-coinex/CHANGELOG.md": "3b3c0197ac0d2a898ad00f5e4480f0d328528ed8",
|
|
4
4
|
"apps/vendor-coinex/config/api-extractor.json": "62f4fd324425b9a235f0c117975967aab09ced0c",
|
|
5
5
|
"apps/vendor-coinex/config/jest.config.json": "4bb17bde3ee911163a3edb36a6eb71491d80b1bd",
|
|
6
6
|
"apps/vendor-coinex/config/rig.json": "f6c7b5537dc77a3170ba9f008bae3b6c3ee11956",
|
|
7
7
|
"apps/vendor-coinex/config/typescript.json": "854907e8a821f2050f6533368db160c649c25348",
|
|
8
8
|
"apps/vendor-coinex/etc/vendor-coinex.api.md": "33941b70ac7469421ff8fb8c157181014a0ea655",
|
|
9
|
-
"apps/vendor-coinex/package.json": "
|
|
9
|
+
"apps/vendor-coinex/package.json": "dfc740a9249fcfa49f90b2e106449383b148e084",
|
|
10
10
|
"apps/vendor-coinex/src/api.ts": "2c912b4fcb8e849cef573c6cd7c26489a6ab0b70",
|
|
11
|
-
"apps/vendor-coinex/src/index.ts": "
|
|
12
|
-
"apps/vendor-coinex/src/interest_rate.ts": "ca8d750396697e81e60f609986bc1a676c7aeb41",
|
|
11
|
+
"apps/vendor-coinex/src/index.ts": "690dca686be2a7dce11efbd30fa3ffc45fc5010f",
|
|
13
12
|
"apps/vendor-coinex/src/product.ts": "c11fafeac162c0037299b79d4ce9594a931d7a96",
|
|
14
13
|
"apps/vendor-coinex/tsconfig.json": "81da8f78196974b5d15da0edb6b2d9f48641063c",
|
|
15
14
|
"apps/vendor-coinex/.rush/temp/shrinkwrap-deps.json": "ada1394af5597d99685478d44dcef1b1dd43b6df",
|
|
@@ -19,7 +18,7 @@
|
|
|
19
18
|
"libraries/sql/temp/package-deps.json": "88cd4d4a8648dfa8d3aeec991aa734f9ab3374dc",
|
|
20
19
|
"libraries/data-series/temp/package-deps.json": "ca8fb8d7fa67d7a77b7254eb785f4aa14c1d928c",
|
|
21
20
|
"libraries/data-product/temp/package-deps.json": "2b9736cd4a54002df2be4e72f9a4b9641aa71201",
|
|
22
|
-
"libraries/data-interest-rate/temp/package-deps.json": "
|
|
21
|
+
"libraries/data-interest-rate/temp/package-deps.json": "32d5320598b42e9bbf68d25ea982f8dc29b2bc74",
|
|
23
22
|
"libraries/extension/temp/package-deps.json": "454f577565ee01a0838c468fb1fc59e1f5d5f37c",
|
|
24
23
|
"tools/toolkit/temp/package-deps.json": "580f13201f076fa393117989256a2fee58e354f8"
|
|
25
24
|
}
|
|
Binary file
|
package/dist/interest_rate.js
DELETED
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
var __await = (this && this.__await) || function (v) { return this instanceof __await ? (this.v = v, this) : new __await(v); }
|
|
2
|
-
var __asyncGenerator = (this && this.__asyncGenerator) || function (thisArg, _arguments, generator) {
|
|
3
|
-
if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
|
|
4
|
-
var g = generator.apply(thisArg, _arguments || []), i, q = [];
|
|
5
|
-
return i = Object.create((typeof AsyncIterator === "function" ? AsyncIterator : Object).prototype), verb("next"), verb("throw"), verb("return", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;
|
|
6
|
-
function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }
|
|
7
|
-
function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }
|
|
8
|
-
function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }
|
|
9
|
-
function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }
|
|
10
|
-
function fulfill(value) { resume("next", value); }
|
|
11
|
-
function reject(value) { resume("throw", value); }
|
|
12
|
-
function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }
|
|
13
|
-
};
|
|
14
|
-
import { createSeriesProvider } from '@yuants/data-series';
|
|
15
|
-
import { Terminal } from '@yuants/protocol';
|
|
16
|
-
import { decodePath, formatTime } from '@yuants/utils';
|
|
17
|
-
import { firstValueFrom, timer } from 'rxjs';
|
|
18
|
-
import { client } from './api';
|
|
19
|
-
const terminal = Terminal.fromNodeEnv();
|
|
20
|
-
createSeriesProvider(terminal, {
|
|
21
|
-
tableName: 'interest_rate',
|
|
22
|
-
series_id_prefix_parts: ['coinex'],
|
|
23
|
-
reversed: true,
|
|
24
|
-
serviceOptions: { concurrent: 1 },
|
|
25
|
-
queryFn: function (_a) {
|
|
26
|
-
return __asyncGenerator(this, arguments, function* ({ series_id, started_at, ended_at }) {
|
|
27
|
-
const [, instType, instId] = decodePath(series_id);
|
|
28
|
-
let current_page = 0;
|
|
29
|
-
while (true) {
|
|
30
|
-
const res = yield __await(client.getFuturesFundingRateHistory({
|
|
31
|
-
market: instId,
|
|
32
|
-
start_time: started_at,
|
|
33
|
-
end_time: ended_at,
|
|
34
|
-
page: current_page,
|
|
35
|
-
limit: 100,
|
|
36
|
-
}));
|
|
37
|
-
if (res.code !== 0) {
|
|
38
|
-
throw `API failed: ${res.code} ${res.message}`;
|
|
39
|
-
}
|
|
40
|
-
if (res.data.length === 0)
|
|
41
|
-
break;
|
|
42
|
-
yield yield __await(res.data.map((v) => ({
|
|
43
|
-
series_id,
|
|
44
|
-
datasource_id: 'COINEX',
|
|
45
|
-
product_id: series_id,
|
|
46
|
-
created_at: formatTime(+v.funding_time),
|
|
47
|
-
long_rate: `${-v.actual_funding_rate}`,
|
|
48
|
-
short_rate: `${v.actual_funding_rate}`,
|
|
49
|
-
settlement_price: '',
|
|
50
|
-
})));
|
|
51
|
-
if (!res.pagination.has_next)
|
|
52
|
-
break;
|
|
53
|
-
if (+res.data[res.data.length - 1].funding_time <= started_at)
|
|
54
|
-
break;
|
|
55
|
-
current_page++;
|
|
56
|
-
yield __await(firstValueFrom(timer(1000)));
|
|
57
|
-
}
|
|
58
|
-
});
|
|
59
|
-
},
|
|
60
|
-
});
|
|
61
|
-
//# sourceMappingURL=interest_rate.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"interest_rate.js","sourceRoot":"","sources":["../src/interest_rate.ts"],"names":[],"mappings":";;;;;;;;;;;;;AACA,OAAO,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AAC3D,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AACvD,OAAO,EAAE,cAAc,EAAE,KAAK,EAAE,MAAM,MAAM,CAAC;AAC7C,OAAO,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AAE/B,MAAM,QAAQ,GAAG,QAAQ,CAAC,WAAW,EAAE,CAAC;AAExC,oBAAoB,CAAgB,QAAQ,EAAE;IAC5C,SAAS,EAAE,eAAe;IAC1B,sBAAsB,EAAE,CAAC,QAAQ,CAAC;IAClC,QAAQ,EAAE,IAAI;IACd,cAAc,EAAE,EAAE,UAAU,EAAE,CAAC,EAAE;IACjC,OAAO,EAAE;4DAAiB,EAAE,SAAS,EAAE,UAAU,EAAE,QAAQ,EAAE;YAC3D,MAAM,CAAC,EAAE,QAAQ,EAAE,MAAM,CAAC,GAAG,UAAU,CAAC,SAAS,CAAC,CAAC;YACnD,IAAI,YAAY,GAAG,CAAC,CAAC;YAErB,OAAO,IAAI,EAAE,CAAC;gBACZ,MAAM,GAAG,GAAG,cAAM,MAAM,CAAC,4BAA4B,CAAC;oBACpD,MAAM,EAAE,MAAM;oBACd,UAAU,EAAE,UAAU;oBACtB,QAAQ,EAAE,QAAQ;oBAClB,IAAI,EAAE,YAAY;oBAClB,KAAK,EAAE,GAAG;iBACX,CAAC,CAAA,CAAC;gBACH,IAAI,GAAG,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC;oBACnB,MAAM,eAAe,GAAG,CAAC,IAAI,IAAI,GAAG,CAAC,OAAO,EAAE,CAAC;gBACjD,CAAC;gBACD,IAAI,GAAG,CAAC,IAAI,CAAC,MAAM,KAAK,CAAC;oBAAE,MAAM;gBAEjC,oBAAM,GAAG,CAAC,IAAI,CAAC,GAAG,CAChB,CAAC,CAAC,EAAiB,EAAE,CAAC,CAAC;oBACrB,SAAS;oBACT,aAAa,EAAE,QAAQ;oBACvB,UAAU,EAAE,SAAS;oBACrB,UAAU,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC;oBACvC,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,mBAAmB,EAAE;oBACtC,UAAU,EAAE,GAAG,CAAC,CAAC,mBAAmB,EAAE;oBACtC,gBAAgB,EAAE,EAAE;iBACrB,CAAC,CACH,CAAA,CAAC;gBACF,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,QAAQ;oBAAE,MAAM;gBACpC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,YAAY,IAAI,UAAU;oBAAE,MAAM;gBACrE,YAAY,EAAE,CAAC;gBACf,cAAM,cAAc,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAA,CAAC;YACpC,CAAC;QACH,CAAC;KAAA;CACF,CAAC,CAAC","sourcesContent":["import { IInterestRate } from '@yuants/data-interest-rate';\nimport { createSeriesProvider } from '@yuants/data-series';\nimport { Terminal } from '@yuants/protocol';\nimport { decodePath, formatTime } from '@yuants/utils';\nimport { firstValueFrom, timer } from 'rxjs';\nimport { client } from './api';\n\nconst terminal = Terminal.fromNodeEnv();\n\ncreateSeriesProvider<IInterestRate>(terminal, {\n tableName: 'interest_rate',\n series_id_prefix_parts: ['coinex'],\n reversed: true,\n serviceOptions: { concurrent: 1 },\n queryFn: async function* ({ series_id, started_at, ended_at }) {\n const [, instType, instId] = decodePath(series_id);\n let current_page = 0;\n\n while (true) {\n const res = await client.getFuturesFundingRateHistory({\n market: instId,\n start_time: started_at,\n end_time: ended_at,\n page: current_page,\n limit: 100,\n });\n if (res.code !== 0) {\n throw `API failed: ${res.code} ${res.message}`;\n }\n if (res.data.length === 0) break;\n\n yield res.data.map(\n (v): IInterestRate => ({\n series_id,\n datasource_id: 'COINEX',\n product_id: series_id,\n created_at: formatTime(+v.funding_time),\n long_rate: `${-v.actual_funding_rate}`,\n short_rate: `${v.actual_funding_rate}`,\n settlement_price: '',\n }),\n );\n if (!res.pagination.has_next) break;\n if (+res.data[res.data.length - 1].funding_time <= started_at) break;\n current_page++;\n await firstValueFrom(timer(1000));\n }\n },\n});\n"]}
|
package/lib/interest_rate.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"interest_rate.d.ts","sourceRoot":"","sources":["../src/interest_rate.ts"],"names":[],"mappings":""}
|
package/lib/interest_rate.js
DELETED
|
@@ -1,63 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __await = (this && this.__await) || function (v) { return this instanceof __await ? (this.v = v, this) : new __await(v); }
|
|
3
|
-
var __asyncGenerator = (this && this.__asyncGenerator) || function (thisArg, _arguments, generator) {
|
|
4
|
-
if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
|
|
5
|
-
var g = generator.apply(thisArg, _arguments || []), i, q = [];
|
|
6
|
-
return i = Object.create((typeof AsyncIterator === "function" ? AsyncIterator : Object).prototype), verb("next"), verb("throw"), verb("return", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;
|
|
7
|
-
function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }
|
|
8
|
-
function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }
|
|
9
|
-
function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }
|
|
10
|
-
function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }
|
|
11
|
-
function fulfill(value) { resume("next", value); }
|
|
12
|
-
function reject(value) { resume("throw", value); }
|
|
13
|
-
function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }
|
|
14
|
-
};
|
|
15
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
-
const data_series_1 = require("@yuants/data-series");
|
|
17
|
-
const protocol_1 = require("@yuants/protocol");
|
|
18
|
-
const utils_1 = require("@yuants/utils");
|
|
19
|
-
const rxjs_1 = require("rxjs");
|
|
20
|
-
const api_1 = require("./api");
|
|
21
|
-
const terminal = protocol_1.Terminal.fromNodeEnv();
|
|
22
|
-
(0, data_series_1.createSeriesProvider)(terminal, {
|
|
23
|
-
tableName: 'interest_rate',
|
|
24
|
-
series_id_prefix_parts: ['coinex'],
|
|
25
|
-
reversed: true,
|
|
26
|
-
serviceOptions: { concurrent: 1 },
|
|
27
|
-
queryFn: function (_a) {
|
|
28
|
-
return __asyncGenerator(this, arguments, function* ({ series_id, started_at, ended_at }) {
|
|
29
|
-
const [, instType, instId] = (0, utils_1.decodePath)(series_id);
|
|
30
|
-
let current_page = 0;
|
|
31
|
-
while (true) {
|
|
32
|
-
const res = yield __await(api_1.client.getFuturesFundingRateHistory({
|
|
33
|
-
market: instId,
|
|
34
|
-
start_time: started_at,
|
|
35
|
-
end_time: ended_at,
|
|
36
|
-
page: current_page,
|
|
37
|
-
limit: 100,
|
|
38
|
-
}));
|
|
39
|
-
if (res.code !== 0) {
|
|
40
|
-
throw `API failed: ${res.code} ${res.message}`;
|
|
41
|
-
}
|
|
42
|
-
if (res.data.length === 0)
|
|
43
|
-
break;
|
|
44
|
-
yield yield __await(res.data.map((v) => ({
|
|
45
|
-
series_id,
|
|
46
|
-
datasource_id: 'COINEX',
|
|
47
|
-
product_id: series_id,
|
|
48
|
-
created_at: (0, utils_1.formatTime)(+v.funding_time),
|
|
49
|
-
long_rate: `${-v.actual_funding_rate}`,
|
|
50
|
-
short_rate: `${v.actual_funding_rate}`,
|
|
51
|
-
settlement_price: '',
|
|
52
|
-
})));
|
|
53
|
-
if (!res.pagination.has_next)
|
|
54
|
-
break;
|
|
55
|
-
if (+res.data[res.data.length - 1].funding_time <= started_at)
|
|
56
|
-
break;
|
|
57
|
-
current_page++;
|
|
58
|
-
yield __await((0, rxjs_1.firstValueFrom)((0, rxjs_1.timer)(1000)));
|
|
59
|
-
}
|
|
60
|
-
});
|
|
61
|
-
},
|
|
62
|
-
});
|
|
63
|
-
//# sourceMappingURL=interest_rate.js.map
|
package/lib/interest_rate.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"interest_rate.js","sourceRoot":"","sources":["../src/interest_rate.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AACA,qDAA2D;AAC3D,+CAA4C;AAC5C,yCAAuD;AACvD,+BAA6C;AAC7C,+BAA+B;AAE/B,MAAM,QAAQ,GAAG,mBAAQ,CAAC,WAAW,EAAE,CAAC;AAExC,IAAA,kCAAoB,EAAgB,QAAQ,EAAE;IAC5C,SAAS,EAAE,eAAe;IAC1B,sBAAsB,EAAE,CAAC,QAAQ,CAAC;IAClC,QAAQ,EAAE,IAAI;IACd,cAAc,EAAE,EAAE,UAAU,EAAE,CAAC,EAAE;IACjC,OAAO,EAAE;4DAAiB,EAAE,SAAS,EAAE,UAAU,EAAE,QAAQ,EAAE;YAC3D,MAAM,CAAC,EAAE,QAAQ,EAAE,MAAM,CAAC,GAAG,IAAA,kBAAU,EAAC,SAAS,CAAC,CAAC;YACnD,IAAI,YAAY,GAAG,CAAC,CAAC;YAErB,OAAO,IAAI,EAAE,CAAC;gBACZ,MAAM,GAAG,GAAG,cAAM,YAAM,CAAC,4BAA4B,CAAC;oBACpD,MAAM,EAAE,MAAM;oBACd,UAAU,EAAE,UAAU;oBACtB,QAAQ,EAAE,QAAQ;oBAClB,IAAI,EAAE,YAAY;oBAClB,KAAK,EAAE,GAAG;iBACX,CAAC,CAAA,CAAC;gBACH,IAAI,GAAG,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC;oBACnB,MAAM,eAAe,GAAG,CAAC,IAAI,IAAI,GAAG,CAAC,OAAO,EAAE,CAAC;gBACjD,CAAC;gBACD,IAAI,GAAG,CAAC,IAAI,CAAC,MAAM,KAAK,CAAC;oBAAE,MAAM;gBAEjC,oBAAM,GAAG,CAAC,IAAI,CAAC,GAAG,CAChB,CAAC,CAAC,EAAiB,EAAE,CAAC,CAAC;oBACrB,SAAS;oBACT,aAAa,EAAE,QAAQ;oBACvB,UAAU,EAAE,SAAS;oBACrB,UAAU,EAAE,IAAA,kBAAU,EAAC,CAAC,CAAC,CAAC,YAAY,CAAC;oBACvC,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,mBAAmB,EAAE;oBACtC,UAAU,EAAE,GAAG,CAAC,CAAC,mBAAmB,EAAE;oBACtC,gBAAgB,EAAE,EAAE;iBACrB,CAAC,CACH,CAAA,CAAC;gBACF,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,QAAQ;oBAAE,MAAM;gBACpC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,YAAY,IAAI,UAAU;oBAAE,MAAM;gBACrE,YAAY,EAAE,CAAC;gBACf,cAAM,IAAA,qBAAc,EAAC,IAAA,YAAK,EAAC,IAAI,CAAC,CAAC,CAAA,CAAC;YACpC,CAAC;QACH,CAAC;KAAA;CACF,CAAC,CAAC","sourcesContent":["import { IInterestRate } from '@yuants/data-interest-rate';\nimport { createSeriesProvider } from '@yuants/data-series';\nimport { Terminal } from '@yuants/protocol';\nimport { decodePath, formatTime } from '@yuants/utils';\nimport { firstValueFrom, timer } from 'rxjs';\nimport { client } from './api';\n\nconst terminal = Terminal.fromNodeEnv();\n\ncreateSeriesProvider<IInterestRate>(terminal, {\n tableName: 'interest_rate',\n series_id_prefix_parts: ['coinex'],\n reversed: true,\n serviceOptions: { concurrent: 1 },\n queryFn: async function* ({ series_id, started_at, ended_at }) {\n const [, instType, instId] = decodePath(series_id);\n let current_page = 0;\n\n while (true) {\n const res = await client.getFuturesFundingRateHistory({\n market: instId,\n start_time: started_at,\n end_time: ended_at,\n page: current_page,\n limit: 100,\n });\n if (res.code !== 0) {\n throw `API failed: ${res.code} ${res.message}`;\n }\n if (res.data.length === 0) break;\n\n yield res.data.map(\n (v): IInterestRate => ({\n series_id,\n datasource_id: 'COINEX',\n product_id: series_id,\n created_at: formatTime(+v.funding_time),\n long_rate: `${-v.actual_funding_rate}`,\n short_rate: `${v.actual_funding_rate}`,\n settlement_price: '',\n }),\n );\n if (!res.pagination.has_next) break;\n if (+res.data[res.data.length - 1].funding_time <= started_at) break;\n current_page++;\n await firstValueFrom(timer(1000));\n }\n },\n});\n"]}
|