@chainlink/external-adapter-framework 0.0.111 → 0.2.0
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/adapter/basic.d.ts +37 -3
- package/adapter/basic.js +138 -2
- package/adapter/basic.js.map +1 -1
- package/adapter/price.d.ts +33 -5
- package/adapter/price.js +41 -2
- package/adapter/price.js.map +1 -1
- package/adapter/types.d.ts +18 -1
- package/cache/index.d.ts +3 -10
- package/cache/index.js +4 -46
- package/cache/index.js.map +1 -1
- package/cache/redis.d.ts +1 -8
- package/cache/redis.js +22 -39
- package/cache/redis.js.map +1 -1
- package/config/index.d.ts +6 -1
- package/config/index.js +20 -12
- package/config/index.js.map +1 -1
- package/examples/bank-frick/accounts.d.ts +2 -3
- package/examples/bank-frick/accounts.js +1 -4
- package/examples/bank-frick/accounts.js.map +1 -1
- package/examples/bank-frick/config/index.d.ts +1 -1
- package/examples/coingecko/src/crypto-utils.d.ts +5 -5
- package/examples/coingecko/src/crypto-utils.js +1 -2
- package/examples/coingecko/src/crypto-utils.js.map +1 -1
- package/examples/coingecko/src/endpoint/coins.js.map +1 -1
- package/examples/coingecko/src/endpoint/crypto-marketcap.d.ts +1 -1
- package/examples/coingecko/src/endpoint/crypto-marketcap.js +2 -2
- package/examples/coingecko/src/endpoint/crypto-marketcap.js.map +1 -1
- package/examples/coingecko/src/endpoint/crypto-volume.d.ts +1 -1
- package/examples/coingecko/src/endpoint/crypto-volume.js +2 -2
- package/examples/coingecko/src/endpoint/crypto-volume.js.map +1 -1
- package/examples/coingecko/src/endpoint/crypto.d.ts +1 -4
- package/examples/coingecko/src/endpoint/crypto.js +2 -2
- package/examples/coingecko/src/endpoint/crypto.js.map +1 -1
- package/examples/coingecko/src/endpoint/dominance.d.ts +1 -1
- package/examples/coingecko/src/endpoint/dominance.js +2 -2
- package/examples/coingecko/src/endpoint/dominance.js.map +1 -1
- package/examples/coingecko/src/endpoint/global-marketcap.d.ts +1 -1
- package/examples/coingecko/src/endpoint/global-marketcap.js +2 -2
- package/examples/coingecko/src/endpoint/global-marketcap.js.map +1 -1
- package/examples/coingecko/src/global-utils.d.ts +3 -3
- package/examples/coingecko/src/global-utils.js.map +1 -1
- package/examples/coingecko/src/index.d.ts +1 -1
- package/examples/coingecko-old/batch-warming.d.ts +1 -1
- package/examples/coingecko-old/batch-warming.js +2 -2
- package/examples/coingecko-old/batch-warming.js.map +1 -1
- package/examples/coingecko-old/rest.js.map +1 -1
- package/examples/cryptocompare/src/endpoints/crypto.d.ts +1 -1
- package/examples/cryptocompare/src/index.d.ts +1 -1
- package/examples/genesis/sseStream.d.ts +2 -2
- package/examples/genesis/sseStream.js +15 -8
- package/examples/genesis/sseStream.js.map +1 -1
- package/examples/ncfx/websocket.d.ts +1 -1
- package/index.d.ts +3 -1
- package/index.js +4 -6
- package/index.js.map +1 -1
- package/metrics/index.d.ts +2 -0
- package/metrics/index.js +5 -4
- package/metrics/index.js.map +1 -1
- package/package.json +4 -7
- package/rate-limiting/index.d.ts +2 -2
- package/transports/batch-warming.d.ts +9 -9
- package/transports/batch-warming.js +40 -13
- package/transports/batch-warming.js.map +1 -1
- package/transports/index.d.ts +23 -26
- package/transports/index.js +2 -59
- package/transports/index.js.map +1 -1
- package/transports/metrics.d.ts +1 -1
- package/transports/rest.d.ts +5 -4
- package/transports/rest.js +16 -22
- package/transports/rest.js.map +1 -1
- package/transports/sse.d.ts +6 -7
- package/transports/sse.js +2 -6
- package/transports/sse.js.map +1 -1
- package/transports/websocket.d.ts +6 -7
- package/transports/websocket.js +5 -9
- package/transports/websocket.js.map +1 -1
- package/util/logger.d.ts +4 -0
- package/util/logger.js +45 -4
- package/util/logger.js.map +1 -1
- package/util/subscription-set/subscription-set.d.ts +1 -1
- package/util/subscription-set/subscription-set.js +1 -1
- package/util/subscription-set/subscription-set.js.map +1 -1
- package/util/test-payload-loader.d.ts +1 -0
- package/util/test-payload-loader.js +2 -1
- package/util/test-payload-loader.js.map +1 -1
- package/validation/error.d.ts +1 -3
- package/validation/error.js +1 -3
- package/validation/error.js.map +1 -1
- package/validation/index.js +12 -14
- package/validation/index.js.map +1 -1
- package/validation/input-params.d.ts +0 -1
- package/validation/input-params.js +0 -28
- package/validation/input-params.js.map +1 -1
- package/validation/input-validator.js +1 -2
- package/validation/input-validator.js.map +1 -1
- package/adapter.d.ts +0 -156
- package/adapter.js +0 -200
- package/adapter.js.map +0 -1
- package/examples/coingecko/batch-warming.d.ts +0 -7
- package/examples/coingecko/batch-warming.js +0 -54
- package/examples/coingecko/batch-warming.js.map +0 -1
- package/examples/coingecko/index.d.ts +0 -2
- package/examples/coingecko/index.js +0 -12
- package/examples/coingecko/index.js.map +0 -1
- package/examples/coingecko/rest.d.ts +0 -12
- package/examples/coingecko/rest.js +0 -55
- package/examples/coingecko/rest.js.map +0 -1
- package/examples/coingecko/src/cryptoUtils.d.ts +0 -31
- package/examples/coingecko/src/cryptoUtils.js +0 -60
- package/examples/coingecko/src/globalUtils.d.ts +0 -27
- package/examples/coingecko/src/globalUtils.js +0 -46
- package/validation/override-functions.d.ts +0 -3
- package/validation/override-functions.js +0 -41
- package/validation/override-functions.js.map +0 -1
- package/validation/preset-tokens.json +0 -23
- package/validation/validator.d.ts +0 -47
- package/validation/validator.js +0 -303
package/cache/redis.js
CHANGED
|
@@ -25,52 +25,25 @@ var __importStar = (this && this.__importStar) || function (mod) {
|
|
|
25
25
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
26
|
exports.RedisCache = void 0;
|
|
27
27
|
const util_1 = require("../util");
|
|
28
|
-
const metrics_1 = require("./metrics");
|
|
29
28
|
const cacheMetrics = __importStar(require("./metrics"));
|
|
30
29
|
const logger = (0, util_1.makeLogger)('RedisCache');
|
|
31
|
-
const recordRedisCommandMetric = (status, functionName) => {
|
|
32
|
-
cacheMetrics.redisCommandsSentCount
|
|
33
|
-
.labels({ status: cacheMetrics.CMD_SENT_STATUS[status], function_name: functionName })
|
|
34
|
-
.inc();
|
|
35
|
-
};
|
|
36
|
-
/**
|
|
37
|
-
* Common callback for redis commands that logs success/fail and throws on fail
|
|
38
|
-
* @param {string} message - message to log on error
|
|
39
|
-
* @param {string} functionName - name of the redis function where this callback was used, used for metrics
|
|
40
|
-
*/
|
|
41
30
|
/**
|
|
42
31
|
* Redis implementation of a Cache. It uses a simple js Object, storing entries with both
|
|
43
32
|
* a value and an expiration timestamp. Expired entries are deleted on reads (i.e. no background gc/upkeep).
|
|
44
33
|
*
|
|
45
34
|
* @typeParam T - the type for the entries' values
|
|
46
|
-
* @param {boolean} alwaysFail - if true, error callback will always throw an error (used for testing)
|
|
47
35
|
*/
|
|
48
36
|
class RedisCache {
|
|
49
37
|
constructor(client) {
|
|
50
38
|
this.client = client;
|
|
51
|
-
// Global error handler in case one of the commands is missing a callback
|
|
52
|
-
this.client.on('error', (err) => {
|
|
53
|
-
logger.error(`Encountered unhandled error in RedisCache: ${err}`);
|
|
54
|
-
// Record error command sent to Redis
|
|
55
|
-
recordRedisCommandMetric(metrics_1.CMD_SENT_STATUS.FAIL, 'outermost');
|
|
56
|
-
throw err;
|
|
57
|
-
});
|
|
58
|
-
}
|
|
59
|
-
commandCallback(message, functionName) {
|
|
60
|
-
return (err) => {
|
|
61
|
-
if (err) {
|
|
62
|
-
logger.error(`${message}: ${err}`);
|
|
63
|
-
recordRedisCommandMetric(metrics_1.CMD_SENT_STATUS.FAIL, functionName);
|
|
64
|
-
throw err;
|
|
65
|
-
}
|
|
66
|
-
else {
|
|
67
|
-
recordRedisCommandMetric(metrics_1.CMD_SENT_STATUS.SUCCESS, functionName);
|
|
68
|
-
}
|
|
69
|
-
};
|
|
70
39
|
}
|
|
71
40
|
async get(key) {
|
|
72
41
|
logger.trace(`Getting key ${key}`);
|
|
73
|
-
const value = await this.client.get(key
|
|
42
|
+
const value = await this.client.get(key);
|
|
43
|
+
// Record get command sent to Redis
|
|
44
|
+
cacheMetrics.redisCommandsSentCount
|
|
45
|
+
.labels({ status: cacheMetrics.CMD_SENT_STATUS.SUCCESS, function_name: 'get' })
|
|
46
|
+
.inc();
|
|
74
47
|
if (!value) {
|
|
75
48
|
logger.debug(`No entry in redis cache for key "${key}", returning undefined`);
|
|
76
49
|
return undefined;
|
|
@@ -79,30 +52,38 @@ class RedisCache {
|
|
|
79
52
|
}
|
|
80
53
|
async delete(key) {
|
|
81
54
|
logger.trace(`Deleting key ${key}`);
|
|
82
|
-
await this.client.del(key
|
|
55
|
+
await this.client.del(key);
|
|
56
|
+
// Record delete command sent to Redis
|
|
57
|
+
cacheMetrics.redisCommandsSentCount
|
|
58
|
+
.labels({ status: cacheMetrics.CMD_SENT_STATUS.SUCCESS, function_name: 'delete' })
|
|
59
|
+
.inc();
|
|
83
60
|
}
|
|
84
61
|
async set(key, value, ttl) {
|
|
85
62
|
logger.trace(`Setting key ${key}`);
|
|
86
|
-
|
|
63
|
+
await this.client.set(key, JSON.stringify(value), 'PX', ttl);
|
|
64
|
+
// Only record metrics if feed Id is present, otherwise assuming value is not adapter response to record
|
|
87
65
|
const feedId = value.meta?.metrics?.feedId;
|
|
88
66
|
if (feedId) {
|
|
89
67
|
// Record cache set count, max age, and staleness (set to 0 for cache set)
|
|
90
68
|
const label = cacheMetrics.cacheMetricsLabel(key, feedId, cacheMetrics.CacheTypes.Redis);
|
|
91
69
|
cacheMetrics.cacheSet(label, ttl);
|
|
92
70
|
}
|
|
93
|
-
|
|
71
|
+
// Record set command sent to Redis
|
|
72
|
+
cacheMetrics.redisCommandsSentCount
|
|
73
|
+
.labels({ status: cacheMetrics.CMD_SENT_STATUS.SUCCESS, function_name: 'set' })
|
|
74
|
+
.inc();
|
|
94
75
|
}
|
|
95
76
|
async setMany(entries, ttl) {
|
|
96
77
|
logger.trace(`Setting a bunch of keys`);
|
|
97
78
|
// Unfortunately, there's no ttl for mset
|
|
98
79
|
let chain = this.client.multi();
|
|
99
80
|
for (const entry of entries) {
|
|
100
|
-
chain = chain.set(entry.key, JSON.stringify(entry.value), 'PX', ttl
|
|
81
|
+
chain = chain.set(entry.key, JSON.stringify(entry.value), 'PX', ttl);
|
|
101
82
|
}
|
|
102
|
-
await chain.exec(
|
|
83
|
+
await chain.exec();
|
|
103
84
|
// Loop again, but this time to record these in metrics
|
|
104
85
|
for (const entry of entries) {
|
|
105
|
-
// Only record metrics if feed
|
|
86
|
+
// Only record metrics if feed Id is present, otherwise assuming value is not adapter response to record
|
|
106
87
|
const feedId = entry.value.meta?.metrics?.feedId;
|
|
107
88
|
if (feedId) {
|
|
108
89
|
// Record cache set count, max age, and staleness (set to 0 for cache set)
|
|
@@ -111,7 +92,9 @@ class RedisCache {
|
|
|
111
92
|
}
|
|
112
93
|
}
|
|
113
94
|
// Record setMany command sent to Redis
|
|
114
|
-
|
|
95
|
+
cacheMetrics.redisCommandsSentCount
|
|
96
|
+
.labels({ status: cacheMetrics.CMD_SENT_STATUS.SUCCESS, function_name: 'exec' })
|
|
97
|
+
.inc();
|
|
115
98
|
}
|
|
116
99
|
}
|
|
117
100
|
exports.RedisCache = RedisCache;
|
package/cache/redis.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"redis.js","sourceRoot":"","sources":["../../../src/cache/redis.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AACA,kCAAqD;AAErD,
|
|
1
|
+
{"version":3,"file":"redis.js","sourceRoot":"","sources":["../../../src/cache/redis.ts"],"names":[],"mappings":"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"}
|
package/config/index.d.ts
CHANGED
|
@@ -23,6 +23,11 @@ export declare const BaseSettings: {
|
|
|
23
23
|
readonly type: "string";
|
|
24
24
|
readonly default: "/";
|
|
25
25
|
};
|
|
26
|
+
readonly BATCH_TRANSPORT_SETUP_VALIDATION: {
|
|
27
|
+
readonly description: "Flag to toggle batch transport setup validation";
|
|
28
|
+
readonly type: "boolean";
|
|
29
|
+
readonly default: false;
|
|
30
|
+
};
|
|
26
31
|
readonly CACHE_MAX_AGE: {
|
|
27
32
|
readonly description: "Maximum amount of time (in ms) that a response will stay cached";
|
|
28
33
|
readonly type: "number";
|
|
@@ -191,7 +196,7 @@ export declare const BaseSettings: {
|
|
|
191
196
|
readonly description: "Maximum amount of characters that the common part of the cache key or feed ID can have";
|
|
192
197
|
readonly type: "number";
|
|
193
198
|
readonly default: 300;
|
|
194
|
-
readonly validate: (value?: number
|
|
199
|
+
readonly validate: (value?: number) => "MAX_COMMON_KEY_SIZE must be a number between 150 and 500" | undefined;
|
|
195
200
|
};
|
|
196
201
|
readonly REST_TRANSPORT_MAX_RATE_LIMIT_RETRIES: {
|
|
197
202
|
readonly description: "Maximum amount of times the Rest Transport will attempt to set up a request when blocked by the rate limiter";
|
package/config/index.js
CHANGED
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
// Import { getRandomRequiredEnv, getRandomEnv, getEnv } from '../util'
|
|
3
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
3
|
exports.buildAdapterConfig = exports.BaseSettings = void 0;
|
|
5
4
|
exports.BaseSettings = {
|
|
@@ -32,6 +31,11 @@ exports.BaseSettings = {
|
|
|
32
31
|
type: 'string',
|
|
33
32
|
default: '/',
|
|
34
33
|
},
|
|
34
|
+
BATCH_TRANSPORT_SETUP_VALIDATION: {
|
|
35
|
+
description: 'Flag to toggle batch transport setup validation',
|
|
36
|
+
type: 'boolean',
|
|
37
|
+
default: false,
|
|
38
|
+
},
|
|
35
39
|
CACHE_MAX_AGE: {
|
|
36
40
|
description: 'Maximum amount of time (in ms) that a response will stay cached',
|
|
37
41
|
type: 'number',
|
|
@@ -296,6 +300,7 @@ const buildAdapterConfig = ({ overrides = {}, customSettings = {}, }) => {
|
|
|
296
300
|
// Iterate base adapter env vars
|
|
297
301
|
for (const [key, config] of Object.entries(exports.BaseSettings)) {
|
|
298
302
|
const value = getEnv(key, config) ?? overrides?.[key] ?? config.default;
|
|
303
|
+
validateConfig(key, value, config, validationErrors);
|
|
299
304
|
vars[key] = value;
|
|
300
305
|
}
|
|
301
306
|
// Iterate custom vars
|
|
@@ -304,17 +309,7 @@ const buildAdapterConfig = ({ overrides = {}, customSettings = {}, }) => {
|
|
|
304
309
|
throw new Error(`Custom env var "${key}" declared, but a base framework env var with that name already exists.`);
|
|
305
310
|
}
|
|
306
311
|
const value = getEnv(key, config) ?? config.default;
|
|
307
|
-
|
|
308
|
-
if (config.required && value === null) {
|
|
309
|
-
validationErrors.push(`${key}: Value is required, but none was provided`);
|
|
310
|
-
}
|
|
311
|
-
else if (config.validate) {
|
|
312
|
-
// Cast validate to unknown because TS can't select one of multiple variants of the validate function signature
|
|
313
|
-
const validationRes = config.validate(value);
|
|
314
|
-
if (validationRes) {
|
|
315
|
-
validationErrors.push(`${key}: ${validationRes}`);
|
|
316
|
-
}
|
|
317
|
-
}
|
|
312
|
+
validateConfig(key, value, config, validationErrors);
|
|
318
313
|
vars[key] = value;
|
|
319
314
|
}
|
|
320
315
|
if (validationErrors.length > 0) {
|
|
@@ -323,6 +318,19 @@ const buildAdapterConfig = ({ overrides = {}, customSettings = {}, }) => {
|
|
|
323
318
|
return vars;
|
|
324
319
|
};
|
|
325
320
|
exports.buildAdapterConfig = buildAdapterConfig;
|
|
321
|
+
const validateConfig = (key, value, config, validationErrors) => {
|
|
322
|
+
// Check if a required setting has been provided
|
|
323
|
+
if (config.required && (value === null || value === undefined)) {
|
|
324
|
+
validationErrors.push(`${key}: Value is required, but none was provided`);
|
|
325
|
+
}
|
|
326
|
+
else if (config.validate) {
|
|
327
|
+
// Cast validate to unknown because TS can't select one of multiple variants of the validate function signature
|
|
328
|
+
const validationRes = config.validate(value);
|
|
329
|
+
if (validationRes) {
|
|
330
|
+
validationErrors.push(`${key}: ${validationRes}`);
|
|
331
|
+
}
|
|
332
|
+
}
|
|
333
|
+
};
|
|
326
334
|
const getEnv = (name, config) => {
|
|
327
335
|
const value = process.env[name];
|
|
328
336
|
if (!value) {
|
package/config/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/config/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/config/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -16,9 +16,8 @@ import { AdapterDependencies, AdapterEndpoint } from '../../adapter';
|
|
|
16
16
|
*/
|
|
17
17
|
export declare class BankFrickAccountsTransport implements Transport<AdapterInputParameters, number, typeof customSettings> {
|
|
18
18
|
token: string;
|
|
19
|
-
cache: Cache
|
|
19
|
+
cache: Cache<AdapterResponse<number>>;
|
|
20
20
|
initialize(dependencies: AdapterDependencies): Promise<void>;
|
|
21
|
-
hasBeenSetUp(): Promise<boolean>;
|
|
22
21
|
/**
|
|
23
22
|
* Creates an AxiosRequestConfig object for fetching a page of accounts from the Bank Frick API
|
|
24
23
|
*/
|
|
@@ -34,7 +33,7 @@ export declare class BankFrickAccountsTransport implements Transport<AdapterInpu
|
|
|
34
33
|
* Fetches pages of data from the Bank Frick API, scans for accounts by IBAN, and returns the balance
|
|
35
34
|
* of all found accounts. Returns a 404 if any IBAN isn't found.
|
|
36
35
|
*/
|
|
37
|
-
|
|
36
|
+
foregroundExecute(req: AdapterRequest<AdapterInputParameters>, config: AdapterConfig<typeof customSettings>): Promise<AdapterResponse<number>>;
|
|
38
37
|
}
|
|
39
38
|
export declare const accountsRestEndpoint: AdapterEndpoint<AdapterInputParameters, number, {
|
|
40
39
|
readonly PAGE_SIZE: {
|
|
@@ -47,9 +47,6 @@ class BankFrickAccountsTransport {
|
|
|
47
47
|
async initialize(dependencies) {
|
|
48
48
|
this.cache = dependencies.cache;
|
|
49
49
|
}
|
|
50
|
-
async hasBeenSetUp() {
|
|
51
|
-
return false; // Return false since we aren't coalescing requests
|
|
52
|
-
}
|
|
53
50
|
/**
|
|
54
51
|
* Creates an AxiosRequestConfig object for fetching a page of accounts from the Bank Frick API
|
|
55
52
|
*/
|
|
@@ -123,7 +120,7 @@ class BankFrickAccountsTransport {
|
|
|
123
120
|
* Fetches pages of data from the Bank Frick API, scans for accounts by IBAN, and returns the balance
|
|
124
121
|
* of all found accounts. Returns a 404 if any IBAN isn't found.
|
|
125
122
|
*/
|
|
126
|
-
async
|
|
123
|
+
async foregroundExecute(req, config) {
|
|
127
124
|
const { ibanIDs, signingAlgorithm } = req.requestContext.data;
|
|
128
125
|
const { PAGE_SIZE = 500 } = config;
|
|
129
126
|
logger.debug(`Validating input: ${JSON.stringify(req.requestContext.data)}`);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"accounts.js","sourceRoot":"","sources":["../../../../src/examples/bank-frick/accounts.ts"],"names":[],"mappings":";;;;;;AAAA,kDAAgE;AAUhE,iCAAoC;AACpC,qCAA+E;AAE/E,kDAAqD;AAGrD,2CAAoE;AAEpE,MAAM,MAAM,GAAG,IAAA,iBAAU,EAAC,oBAAoB,CAAC,CAAA;AAE/C,6GAA6G;AAC7G,MAAM,WAAW,GAAG,0BAA0B,CAAA;AAC9C,MAAM,eAAe,GAAoB;IACvC,OAAO,EAAE;QACP,WAAW,EAAE,yDAAyD;QACtE,QAAQ,EAAE,IAAI;QACd,IAAI,EAAE,OAAO;KACd;IACD,gBAAgB,EAAE;QAChB,WAAW,EACT,oHAAoH;QACtH,QAAQ,EAAE,KAAK;QACf,IAAI,EAAE,QAAQ;QACd,OAAO,EAAE,YAAY;QACrB,OAAO,EAAE,CAAC,YAAY,EAAE,YAAY,EAAE,YAAY,CAAC;KACpD;CACF,CAAA;AAED,mGAAmG;AACnG,MAAM,UAAU,GAA8B;IAC5C,GAAG,EAAE,2CAA2C;IAChD,GAAG,EAAE,kEAAkE,EAAE,kCAAkC;CAC5G,CAAA;AACD,MAAM,WAAW,GAA8B;IAC7C,GAAG,EAAE,+CAA+C;IACpD,GAAG,EAAE,0DAA0D;CAChE,CAAA;AAED;;;;;;;GAOG;AACH,MAAa,0BAA0B;IAQrC,KAAK,CAAC,UAAU,CAAC,YAAiC;QAChD,IAAI,CAAC,KAAK,GAAG,YAAY,CAAC,
|
|
1
|
+
{"version":3,"file":"accounts.js","sourceRoot":"","sources":["../../../../src/examples/bank-frick/accounts.ts"],"names":[],"mappings":"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"}
|
|
@@ -6,7 +6,7 @@ export declare const customSettings: {
|
|
|
6
6
|
readonly type: "number";
|
|
7
7
|
readonly required: false;
|
|
8
8
|
readonly default: 500;
|
|
9
|
-
readonly validate: (value?: number
|
|
9
|
+
readonly validate: (value?: number) => string | undefined;
|
|
10
10
|
};
|
|
11
11
|
readonly PRIVATE_KEY: {
|
|
12
12
|
readonly description: "";
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { HttpRequestConfig, HttpResponse } from '../../../transports';
|
|
2
2
|
import { AdapterConfig } from '../../../config';
|
|
3
3
|
export interface CryptoRequestParams {
|
|
4
4
|
coinid?: string;
|
|
@@ -15,7 +15,7 @@ export declare const cryptoInputParams: {
|
|
|
15
15
|
readonly aliases: readonly ["from", "coin"];
|
|
16
16
|
readonly type: "string";
|
|
17
17
|
readonly description: "The symbol of symbols of the currency to query";
|
|
18
|
-
readonly required:
|
|
18
|
+
readonly required: false;
|
|
19
19
|
};
|
|
20
20
|
readonly quote: {
|
|
21
21
|
readonly aliases: readonly ["to", "market"];
|
|
@@ -35,7 +35,7 @@ export interface ProviderResponseBody {
|
|
|
35
35
|
[quote: string]: number;
|
|
36
36
|
};
|
|
37
37
|
}
|
|
38
|
-
interface
|
|
38
|
+
interface ResultEntry {
|
|
39
39
|
value: number;
|
|
40
40
|
params: {
|
|
41
41
|
quote: string;
|
|
@@ -43,6 +43,6 @@ interface ResultEntryWithoutOverrides {
|
|
|
43
43
|
coinid?: string;
|
|
44
44
|
};
|
|
45
45
|
}
|
|
46
|
-
export declare const buildBatchedRequestBody: (params: CryptoRequestParams[], config: AdapterConfig) =>
|
|
47
|
-
export declare const constructEntry: (res:
|
|
46
|
+
export declare const buildBatchedRequestBody: (params: CryptoRequestParams[], config: AdapterConfig) => HttpRequestConfig<ProviderRequestBody>;
|
|
47
|
+
export declare const constructEntry: (res: HttpResponse<ProviderResponseBody>, requestPayload: CryptoRequestParams, resultPath: string) => ResultEntry | undefined;
|
|
48
48
|
export {};
|
|
@@ -13,7 +13,7 @@ exports.cryptoInputParams = {
|
|
|
13
13
|
aliases: ['from', 'coin'],
|
|
14
14
|
type: 'string',
|
|
15
15
|
description: 'The symbol of symbols of the currency to query',
|
|
16
|
-
required:
|
|
16
|
+
required: false,
|
|
17
17
|
},
|
|
18
18
|
quote: {
|
|
19
19
|
aliases: ['to', 'market'],
|
|
@@ -54,7 +54,6 @@ const constructEntry = (res, requestPayload, resultPath) => {
|
|
|
54
54
|
else {
|
|
55
55
|
entry.params.base = requestPayload.base;
|
|
56
56
|
}
|
|
57
|
-
delete entry.params.overrides;
|
|
58
57
|
return entry;
|
|
59
58
|
};
|
|
60
59
|
exports.constructEntry = constructEntry;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"crypto-utils.js","sourceRoot":"","sources":["../../../../../src/examples/coingecko/src/crypto-utils.ts"],"names":[],"mappings":";;;AACA,qCAAiE;AAEjE,iDAAiD;
|
|
1
|
+
{"version":3,"file":"crypto-utils.js","sourceRoot":"","sources":["../../../../../src/examples/coingecko/src/crypto-utils.ts"],"names":[],"mappings":";;;AACA,qCAAiE;AAEjE,iDAAiD;AAQpC,QAAA,iBAAiB,GAAG;IAC/B,MAAM,EAAE;QACN,WAAW,EAAE,8BAA8B;QAC3C,IAAI,EAAE,QAAQ;QACd,QAAQ,EAAE,KAAK;KAChB;IACD,IAAI,EAAE;QACJ,OAAO,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;QACzB,IAAI,EAAE,QAAQ;QACd,WAAW,EAAE,gDAAgD;QAC7D,QAAQ,EAAE,KAAK;KAChB;IACD,KAAK,EAAE;QACL,OAAO,EAAE,CAAC,IAAI,EAAE,QAAQ,CAAC;QACzB,IAAI,EAAE,QAAQ;QACd,WAAW,EAAE,0CAA0C;QACvD,QAAQ,EAAE,IAAI;KACf;CACO,CAAA;AAwBH,MAAM,uBAAuB,GAAG,CACrC,MAA6B,EAC7B,MAAqB,EACmB,EAAE;IAC1C,OAAO;QACL,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,yBAAgB,CAAC,CAAC,CAAC,6BAAoB;QACjE,GAAG,EAAE,eAAe;QACpB,MAAM,EAAE,KAAK;QACb,MAAM,EAAE;YACN,GAAG,EAAE,CAAC,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC;YAClE,aAAa,EAAE,CAAC,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC;YACjE,gBAAgB,EAAE,MAAM,CAAC,OAAO;SACjC;KACF,CAAA;AACH,CAAC,CAAA;AAdY,QAAA,uBAAuB,2BAcnC;AAED,MAAM,MAAM,GAAG,IAAA,mBAAU,EAAC,0BAA0B,CAAC,CAAA;AAE9C,MAAM,cAAc,GAAG,CAC5B,GAAuC,EACvC,cAAmC,EACnC,UAAkB,EACO,EAAE;IAC3B,MAAM,MAAM,GAAG,cAAc,CAAC,MAAM,IAAK,cAAc,CAAC,IAAe,CAAA;IACvE,MAAM,WAAW,GAAG,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;IACpC,MAAM,YAAY,GAAG,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,SAAS,CAAA;IACtE,IAAI,CAAC,YAAY,EAAE;QACjB,MAAM,CAAC,IAAI,CAAC,aAAa,cAAc,CAAC,KAAK,0BAA0B,MAAM,EAAE,CAAC,CAAA;QAChF,OAAM;KACP;IACD,MAAM,KAAK,GAAG;QACZ,MAAM,EAAE,cAAc;QACtB,KAAK,EAAE,YAAY;KACL,CAAA;IAChB,IAAI,cAAc,CAAC,MAAM,EAAE;QACzB,KAAK,CAAC,MAAM,CAAC,MAAM,GAAG,cAAc,CAAC,MAAM,CAAA;KAC5C;SAAM;QACL,KAAK,CAAC,MAAM,CAAC,IAAI,GAAG,cAAc,CAAC,IAAI,CAAA;KACxC;IACD,OAAO,KAAK,CAAA;AACd,CAAC,CAAA;AAtBY,QAAA,cAAc,kBAsB1B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"coins.js","sourceRoot":"","sources":["../../../../../../src/examples/coingecko/src/endpoint/coins.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"coins.js","sourceRoot":"","sources":["../../../../../../src/examples/coingecko/src/endpoint/coins.ts"],"names":[],"mappings":";;;AACA,iDAAqD;AACrD,8DAA8F;AAG9F,sCAAkE;AAErD,QAAA,eAAe,GAAoB,EAAE,CAAA;AAQlD,MAAM,qBAAqB,GAAG,IAAI,0BAAa,CAAC;IAC9C,cAAc,EAAE,CAAC,CAAiB,EAAE,MAAqB,EAAoC,EAAE;QAC7F,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,yBAAgB,CAAC,CAAC,CAAC,6BAAoB,CAAA;QACxE,MAAM,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,gBAAgB,EAAE,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,SAAS,CAAA;QAChF,OAAO;YACL,OAAO;YACP,GAAG,EAAE,aAAa;YAClB,MAAM,EAAE,KAAK;YACb,MAAM;SACP,CAAA;IACH,CAAC;IACD,aAAa,EAAE,CACb,GAAmB,EACnB,GAAkC,EACA,EAAE;QACpC,OAAO;YACL,IAAI,EAAE,GAAG,CAAC,IAAI;YACd,UAAU,EAAE,GAAG;YACf,MAAM,EAAE,GAAG,CAAC,IAAI;SACmB,CAAA;IACvC,CAAC;IACD,OAAO,EAAE;QACP,iBAAiB,EAAE;YACjB,OAAO,EAAE,IAAI;SACd;KACF;CACF,CAAC,CAAA;AAEW,QAAA,QAAQ,GAAG,IAAI,yBAAe,CAAC;IAC1C,IAAI,EAAE,OAAO;IACb,SAAS,EAAE,qBAAqB;IAChC,eAAe,EAAf,uBAAe;CAChB,CAAC,CAAA"}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
import { AdapterEndpoint } from '../../../../adapter';
|
|
2
2
|
import { CryptoRequestParams } from '../crypto-utils';
|
|
3
|
-
export declare const endpoint: AdapterEndpoint<CryptoRequestParams,
|
|
3
|
+
export declare const endpoint: AdapterEndpoint<CryptoRequestParams, import("../../../../transports").BackgroundStoredResultType, import("../../../../config").SettingsMap>;
|
|
@@ -5,8 +5,8 @@ const adapter_1 = require("../../../../adapter");
|
|
|
5
5
|
const batch_warming_1 = require("../../../../transports/batch-warming");
|
|
6
6
|
const crypto_utils_1 = require("../crypto-utils");
|
|
7
7
|
const batchEndpointTransport = new batch_warming_1.BatchWarmingTransport({
|
|
8
|
-
prepareRequest: (params,
|
|
9
|
-
const requestBody = (0, crypto_utils_1.buildBatchedRequestBody)(params,
|
|
8
|
+
prepareRequest: (params, config) => {
|
|
9
|
+
const requestBody = (0, crypto_utils_1.buildBatchedRequestBody)(params, config);
|
|
10
10
|
requestBody.params.include_market_cap = true;
|
|
11
11
|
return requestBody;
|
|
12
12
|
},
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"crypto-marketcap.js","sourceRoot":"","sources":["../../../../../../src/examples/coingecko/src/endpoint/crypto-marketcap.ts"],"names":[],"mappings":";;;AACA,
|
|
1
|
+
{"version":3,"file":"crypto-marketcap.js","sourceRoot":"","sources":["../../../../../../src/examples/coingecko/src/endpoint/crypto-marketcap.ts"],"names":[],"mappings":";;;AACA,iDAAqD;AACrD,wEAA4E;AAE5E,kDAOwB;AAGxB,MAAM,sBAAsB,GAAG,IAAI,qCAAqB,CAAC;IACvD,cAAc,EAAE,CACd,MAA6B,EAC7B,MAAqB,EACmB,EAAE;QAC1C,MAAM,WAAW,GAAG,IAAA,sCAAuB,EAAC,MAAM,EAAE,MAAM,CAAC,CAAA;QAC3D,WAAW,CAAC,MAAM,CAAC,kBAAkB,GAAG,IAAI,CAAA;QAC5C,OAAO,WAAW,CAAA;IACpB,CAAC;IACD,aAAa,EAAE,CACb,MAA6B,EAC7B,GAAuC,EACA,EAAE;QACzC,MAAM,OAAO,GAAG,EAA2C,CAAA;QAC3D,KAAK,MAAM,cAAc,IAAI,MAAM,EAAE;YACnC,MAAM,KAAK,GAAG,IAAA,6BAAc,EAC1B,GAAG,EACH,cAAc,EACd,GAAG,cAAc,CAAC,KAAK,CAAC,WAAW,EAAE,aAAa,CACnD,CAAA;YACD,IAAI,KAAK,EAAE;gBACT,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;aACpB;SACF;QACD,OAAO,OAAO,CAAA;IAChB,CAAC;CACF,CAAC,CAAA;AAEW,QAAA,QAAQ,GAAG,IAAI,yBAAe,CAAC;IAC1C,IAAI,EAAE,WAAW;IACjB,OAAO,EAAE,CAAC,kBAAkB,CAAC;IAC7B,SAAS,EAAE,sBAAsB;IACjC,eAAe,EAAE,gCAAiB;CACnC,CAAC,CAAA"}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
import { AdapterEndpoint } from '../../../../adapter';
|
|
2
2
|
import { CryptoRequestParams } from '../crypto-utils';
|
|
3
|
-
export declare const endpoint: AdapterEndpoint<CryptoRequestParams,
|
|
3
|
+
export declare const endpoint: AdapterEndpoint<CryptoRequestParams, import("../../../../transports").BackgroundStoredResultType, import("../../../../config").SettingsMap>;
|
|
@@ -5,8 +5,8 @@ const adapter_1 = require("../../../../adapter");
|
|
|
5
5
|
const batch_warming_1 = require("../../../../transports/batch-warming");
|
|
6
6
|
const crypto_utils_1 = require("../crypto-utils");
|
|
7
7
|
const batchEndpointTransport = new batch_warming_1.BatchWarmingTransport({
|
|
8
|
-
prepareRequest: (params,
|
|
9
|
-
const requestBody = (0, crypto_utils_1.buildBatchedRequestBody)(params,
|
|
8
|
+
prepareRequest: (params, config) => {
|
|
9
|
+
const requestBody = (0, crypto_utils_1.buildBatchedRequestBody)(params, config);
|
|
10
10
|
requestBody.params.include_24hr_vol = true;
|
|
11
11
|
return requestBody;
|
|
12
12
|
},
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"crypto-volume.js","sourceRoot":"","sources":["../../../../../../src/examples/coingecko/src/endpoint/crypto-volume.ts"],"names":[],"mappings":";;;AACA,
|
|
1
|
+
{"version":3,"file":"crypto-volume.js","sourceRoot":"","sources":["../../../../../../src/examples/coingecko/src/endpoint/crypto-volume.ts"],"names":[],"mappings":";;;AACA,iDAAqD;AACrD,wEAA4E;AAE5E,kDAOwB;AAGxB,MAAM,sBAAsB,GAAG,IAAI,qCAAqB,CAAC;IACvD,cAAc,EAAE,CACd,MAA6B,EAC7B,MAAqB,EACmB,EAAE;QAC1C,MAAM,WAAW,GAAG,IAAA,sCAAuB,EAAC,MAAM,EAAE,MAAM,CAAC,CAAA;QAC3D,WAAW,CAAC,MAAM,CAAC,gBAAgB,GAAG,IAAI,CAAA;QAC1C,OAAO,WAAW,CAAA;IACpB,CAAC;IACD,aAAa,EAAE,CACb,MAA6B,EAC7B,GAAuC,EACA,EAAE;QACzC,MAAM,OAAO,GAAG,EAA2C,CAAA;QAC3D,KAAK,MAAM,cAAc,IAAI,MAAM,EAAE;YACnC,MAAM,KAAK,GAAG,IAAA,6BAAc,EAC1B,GAAG,EACH,cAAc,EACd,GAAG,cAAc,CAAC,KAAK,CAAC,WAAW,EAAE,UAAU,CAChD,CAAA;YACD,IAAI,KAAK,EAAE;gBACT,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;aACpB;SACF;QACD,OAAO,OAAO,CAAA;IAChB,CAAC;CACF,CAAC,CAAA;AAEW,QAAA,QAAQ,GAAG,IAAI,yBAAe,CAAC;IAC1C,IAAI,EAAE,QAAQ;IACd,OAAO,EAAE,CAAC,eAAe,CAAC;IAC1B,SAAS,EAAE,sBAAsB;IACjC,eAAe,EAAE,gCAAiB;CACnC,CAAC,CAAA"}
|
|
@@ -1,5 +1,2 @@
|
|
|
1
1
|
import { PriceEndpoint } from '../../../../adapter';
|
|
2
|
-
export declare const endpoint: PriceEndpoint<
|
|
3
|
-
base: string;
|
|
4
|
-
quote: string;
|
|
5
|
-
}, unknown, import("../../../../config").SettingsMap>;
|
|
2
|
+
export declare const endpoint: PriceEndpoint<import("../../../../adapter").PriceEndpointParams, import("../../../../transports").BackgroundStoredResultType, import("../../../../config").SettingsMap>;
|
|
@@ -5,8 +5,8 @@ const adapter_1 = require("../../../../adapter");
|
|
|
5
5
|
const batch_warming_1 = require("../../../../transports/batch-warming");
|
|
6
6
|
const crypto_utils_1 = require("../crypto-utils");
|
|
7
7
|
const batchEndpointTransport = new batch_warming_1.BatchWarmingTransport({
|
|
8
|
-
prepareRequest: (params,
|
|
9
|
-
return (0, crypto_utils_1.buildBatchedRequestBody)(params,
|
|
8
|
+
prepareRequest: (params, config) => {
|
|
9
|
+
return (0, crypto_utils_1.buildBatchedRequestBody)(params, config);
|
|
10
10
|
},
|
|
11
11
|
parseResponse: (params, res) => {
|
|
12
12
|
const entries = [];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"crypto.js","sourceRoot":"","sources":["../../../../../../src/examples/coingecko/src/endpoint/crypto.ts"],"names":[],"mappings":";;;AACA,
|
|
1
|
+
{"version":3,"file":"crypto.js","sourceRoot":"","sources":["../../../../../../src/examples/coingecko/src/endpoint/crypto.ts"],"names":[],"mappings":";;;AACA,iDAAoD;AACpD,wEAA4E;AAE5E,kDAOwB;AAGxB,MAAM,sBAAsB,GAAG,IAAI,qCAAqB,CAAC;IACvD,cAAc,EAAE,CACd,MAA6B,EAC7B,MAAqB,EACmB,EAAE;QAC1C,OAAO,IAAA,sCAAuB,EAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IAChD,CAAC;IACD,aAAa,EAAE,CACb,MAA6B,EAC7B,GAAuC,EACA,EAAE;QACzC,MAAM,OAAO,GAAG,EAA2C,CAAA;QAC3D,KAAK,MAAM,cAAc,IAAI,MAAM,EAAE;YACnC,MAAM,KAAK,GAAG,IAAA,6BAAc,EAAC,GAAG,EAAE,cAAc,EAAE,cAAc,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,CAAA;YACrF,IAAI,KAAK,EAAE;gBACT,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;aACpB;SACF;QACD,OAAO,OAAO,CAAA;IAChB,CAAC;CACF,CAAC,CAAA;AAEW,QAAA,QAAQ,GAAG,IAAI,uBAAa,CAAC;IACxC,IAAI,EAAE,QAAQ;IACd,OAAO,EAAE,CAAC,gBAAgB,EAAE,SAAS,EAAE,OAAO,CAAC;IAC/C,SAAS,EAAE,sBAAsB;IACjC,eAAe,EAAE,gCAAiB;CACnC,CAAC,CAAA"}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
import { AdapterEndpoint } from '../../../../adapter';
|
|
2
2
|
import { AdapterRequestParams } from '../global-utils';
|
|
3
|
-
export declare const endpoint: AdapterEndpoint<AdapterRequestParams,
|
|
3
|
+
export declare const endpoint: AdapterEndpoint<AdapterRequestParams, import("../../../../transports").BackgroundStoredResultType, import("../../../../config").SettingsMap>;
|
|
@@ -5,8 +5,8 @@ const adapter_1 = require("../../../../adapter");
|
|
|
5
5
|
const batch_warming_1 = require("../../../../transports/batch-warming");
|
|
6
6
|
const global_utils_1 = require("../global-utils");
|
|
7
7
|
const batchEndpointTransport = new batch_warming_1.BatchWarmingTransport({
|
|
8
|
-
prepareRequest: (params,
|
|
9
|
-
return (0, global_utils_1.buildGlobalRequestBody)(
|
|
8
|
+
prepareRequest: (params, config) => {
|
|
9
|
+
return (0, global_utils_1.buildGlobalRequestBody)(config.API_KEY);
|
|
10
10
|
},
|
|
11
11
|
parseResponse: (params, res) => {
|
|
12
12
|
const entries = [];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dominance.js","sourceRoot":"","sources":["../../../../../../src/examples/coingecko/src/endpoint/dominance.ts"],"names":[],"mappings":";;;AACA,
|
|
1
|
+
{"version":3,"file":"dominance.js","sourceRoot":"","sources":["../../../../../../src/examples/coingecko/src/endpoint/dominance.ts"],"names":[],"mappings":";;;AACA,iDAAqD;AACrD,wEAA4E;AAE5E,kDAMwB;AAGxB,MAAM,sBAAsB,GAAG,IAAI,qCAAqB,CAAC;IACvD,cAAc,EAAE,CACd,MAA8B,EAC9B,MAAqB,EACK,EAAE;QAC5B,OAAO,IAAA,qCAAsB,EAAC,MAAM,CAAC,OAAO,CAAC,CAAA;IAC/C,CAAC;IACD,aAAa,EAAE,CACb,MAA8B,EAC9B,GAAuC,EACC,EAAE;QAC1C,MAAM,OAAO,GAAG,EAA4C,CAAA;QAC5D,KAAK,MAAM,cAAc,IAAI,MAAM,EAAE;YACnC,MAAM,KAAK,GAAG,IAAA,6BAAc,EAAC,GAAG,EAAE,cAAc,EAAE,uBAAuB,CAAC,CAAA;YAC1E,IAAI,KAAK,EAAE;gBACT,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;aACpB;SACF;QACD,OAAO,OAAO,CAAA;IAChB,CAAC;CACF,CAAC,CAAA;AAEW,QAAA,QAAQ,GAAG,IAAI,yBAAe,CAAC;IAC1C,IAAI,EAAE,WAAW;IACjB,OAAO,EAAE,CAAC,uBAAuB,CAAC;IAClC,SAAS,EAAE,sBAAsB;IACjC,eAAe,EAAf,8BAAe;CAChB,CAAC,CAAA"}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
import { AdapterEndpoint } from '../../../../adapter';
|
|
2
2
|
import { AdapterRequestParams } from '../global-utils';
|
|
3
|
-
export declare const endpoint: AdapterEndpoint<AdapterRequestParams,
|
|
3
|
+
export declare const endpoint: AdapterEndpoint<AdapterRequestParams, import("../../../../transports").BackgroundStoredResultType, import("../../../../config").SettingsMap>;
|
|
@@ -5,8 +5,8 @@ const adapter_1 = require("../../../../adapter");
|
|
|
5
5
|
const batch_warming_1 = require("../../../../transports/batch-warming");
|
|
6
6
|
const global_utils_1 = require("../global-utils");
|
|
7
7
|
const batchEndpointTransport = new batch_warming_1.BatchWarmingTransport({
|
|
8
|
-
prepareRequest: (params,
|
|
9
|
-
return (0, global_utils_1.buildGlobalRequestBody)(
|
|
8
|
+
prepareRequest: (params, config) => {
|
|
9
|
+
return (0, global_utils_1.buildGlobalRequestBody)(config.API_KEY);
|
|
10
10
|
},
|
|
11
11
|
parseResponse: (params, res) => {
|
|
12
12
|
const entries = [];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"global-marketcap.js","sourceRoot":"","sources":["../../../../../../src/examples/coingecko/src/endpoint/global-marketcap.ts"],"names":[],"mappings":";;;AACA,
|
|
1
|
+
{"version":3,"file":"global-marketcap.js","sourceRoot":"","sources":["../../../../../../src/examples/coingecko/src/endpoint/global-marketcap.ts"],"names":[],"mappings":";;;AACA,iDAAqD;AACrD,wEAA4E;AAE5E,kDAMwB;AAGxB,MAAM,sBAAsB,GAAG,IAAI,qCAAqB,CAAC;IACvD,cAAc,EAAE,CACd,MAA8B,EAC9B,MAAqB,EACK,EAAE;QAC5B,OAAO,IAAA,qCAAsB,EAAC,MAAM,CAAC,OAAO,CAAC,CAAA;IAC/C,CAAC;IACD,aAAa,EAAE,CACb,MAA8B,EAC9B,GAAuC,EACC,EAAE;QAC1C,MAAM,OAAO,GAAG,EAA4C,CAAA;QAC5D,KAAK,MAAM,cAAc,IAAI,MAAM,EAAE;YACnC,MAAM,KAAK,GAAG,IAAA,6BAAc,EAAC,GAAG,EAAE,cAAc,EAAE,kBAAkB,CAAC,CAAA;YACrE,IAAI,KAAK,EAAE;gBACT,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;aACpB;SACF;QACD,OAAO,OAAO,CAAA;IAChB,CAAC;CACF,CAAC,CAAA;AAEW,QAAA,QAAQ,GAAG,IAAI,yBAAe,CAAC;IAC1C,IAAI,EAAE,iBAAiB;IACvB,OAAO,EAAE,CAAC,kBAAkB,CAAC;IAC7B,SAAS,EAAE,sBAAsB;IACjC,eAAe,EAAf,8BAAe;CAChB,CAAC,CAAA"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { HttpRequestConfig, HttpResponse } from '../../../transports';
|
|
2
2
|
import { InputParameters } from '../../../validation';
|
|
3
3
|
export declare const inputParameters: InputParameters;
|
|
4
4
|
export interface AdapterRequestParams {
|
|
@@ -22,6 +22,6 @@ interface ResultEntry {
|
|
|
22
22
|
value: number;
|
|
23
23
|
params: AdapterRequestParams;
|
|
24
24
|
}
|
|
25
|
-
export declare const buildGlobalRequestBody: (apiKey?: string
|
|
26
|
-
export declare const constructEntry: (res:
|
|
25
|
+
export declare const buildGlobalRequestBody: (apiKey?: string) => HttpRequestConfig<never>;
|
|
26
|
+
export declare const constructEntry: (res: HttpResponse<ProviderResponseBody>, requestPayload: AdapterRequestParams, resultPath: 'total_market_cap' | 'market_cap_percentage') => ResultEntry | undefined;
|
|
27
27
|
export {};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"global-utils.js","sourceRoot":"","sources":["../../../../../src/examples/coingecko/src/global-utils.ts"],"names":[],"mappings":";;;AACA,qCAAiE;AACjE,iDAAiD;AAGjD,MAAM,MAAM,GAAG,IAAA,mBAAU,EAAC,0BAA0B,CAAC,CAAA;AAExC,QAAA,eAAe,GAAoB;IAC9C,MAAM,EAAE;QACN,OAAO,EAAE,CAAC,IAAI,EAAE,OAAO,CAAC;QACxB,WAAW,EAAE,iCAAiC;QAC9C,QAAQ,EAAE,IAAI;KACf;CACF,CAAA;AA0BM,MAAM,sBAAsB,GAAG,CAAC,MAAe,
|
|
1
|
+
{"version":3,"file":"global-utils.js","sourceRoot":"","sources":["../../../../../src/examples/coingecko/src/global-utils.ts"],"names":[],"mappings":";;;AACA,qCAAiE;AACjE,iDAAiD;AAGjD,MAAM,MAAM,GAAG,IAAA,mBAAU,EAAC,0BAA0B,CAAC,CAAA;AAExC,QAAA,eAAe,GAAoB;IAC9C,MAAM,EAAE;QACN,OAAO,EAAE,CAAC,IAAI,EAAE,OAAO,CAAC;QACxB,WAAW,EAAE,iCAAiC;QAC9C,QAAQ,EAAE,IAAI;KACf;CACF,CAAA;AA0BM,MAAM,sBAAsB,GAAG,CAAC,MAAe,EAA4B,EAAE;IAClF,OAAO;QACL,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,yBAAgB,CAAC,CAAC,CAAC,6BAAoB;QACzD,GAAG,EAAE,SAAS;QACd,MAAM,EAAE,KAAK;QACb,MAAM,EAAE;YACN,gBAAgB,EAAE,MAAM;SACzB;KACF,CAAA;AACH,CAAC,CAAA;AATY,QAAA,sBAAsB,0BASlC;AAEM,MAAM,cAAc,GAAG,CAC5B,GAAuC,EACvC,cAAoC,EACpC,UAAwD,EAC/B,EAAE;IAC3B,MAAM,UAAU,GAAG,GAAG,CAAC,IAAI,CAAC,IAAI,CAAA;IAChC,IAAI,CAAC,UAAU,EAAE;QACf,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAA;QAC7B,OAAM;KACP;IAED,MAAM,kBAAkB,GAAG,UAAU,CAAC,UAAU,CAAC,CAAA;IACjD,IAAI,CAAC,kBAAkB,EAAE;QACvB,MAAM,CAAC,IAAI,CAAC,aAAa,UAAU,aAAa,CAAC,CAAA;QACjD,OAAM;KACP;IAED,MAAM,MAAM,GAAG,kBAAkB,CAAC,cAAc,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,CAAA;IACtE,IAAI,CAAC,MAAM,EAAE;QACX,MAAM,CAAC,IAAI,CAAC,aAAa,cAAc,CAAC,MAAM,aAAa,CAAC,CAAA;QAC5D,OAAM;KACP;IAED,OAAO;QACL,MAAM,EAAE,cAAc;QACtB,KAAK,EAAE,MAAM;KACd,CAAA;AACH,CAAC,CAAA;AA3BY,QAAA,cAAc,kBA2B1B"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
/// <reference types="node" />
|
|
2
2
|
import { PriceAdapter } from '../../../adapter';
|
|
3
3
|
export declare const adapter: PriceAdapter<import("../../../config").SettingsMap>;
|
|
4
|
-
export declare const server: () => Promise<import("fastify").FastifyInstance<import("
|
|
4
|
+
export declare const server: () => Promise<import("fastify/types/instance").FastifyInstance<import("fastify").RawServerDefault, import("http").IncomingMessage, import("http").ServerResponse<import("http").IncomingMessage>, import("fastify").FastifyBaseLogger, import("fastify").FastifyTypeProviderDefault> | undefined>;
|
|
@@ -3,5 +3,5 @@ interface AdapterRequestParams {
|
|
|
3
3
|
base: string;
|
|
4
4
|
quote: string;
|
|
5
5
|
}
|
|
6
|
-
export declare const batchEndpoint: AdapterEndpoint<AdapterRequestParams,
|
|
6
|
+
export declare const batchEndpoint: AdapterEndpoint<AdapterRequestParams, import("../../transports").BackgroundStoredResultType, import("../../config").SettingsMap>;
|
|
7
7
|
export {};
|
|
@@ -21,7 +21,7 @@ const inputParameters = {
|
|
|
21
21
|
},
|
|
22
22
|
};
|
|
23
23
|
const batchEndpointTransport = new batch_warming_1.BatchWarmingTransport({
|
|
24
|
-
prepareRequest: (params,
|
|
24
|
+
prepareRequest: (params, config) => {
|
|
25
25
|
return {
|
|
26
26
|
baseURL: DEFAULT_URL,
|
|
27
27
|
url: '/simple/price',
|
|
@@ -29,7 +29,7 @@ const batchEndpointTransport = new batch_warming_1.BatchWarmingTransport({
|
|
|
29
29
|
params: {
|
|
30
30
|
ids: [...new Set(params.map((p) => p.base))].join(','),
|
|
31
31
|
vs_currencies: [...new Set(params.map((p) => p.quote))].join(','),
|
|
32
|
-
x_cg_pro_api_key:
|
|
32
|
+
x_cg_pro_api_key: config.API_KEY,
|
|
33
33
|
},
|
|
34
34
|
};
|
|
35
35
|
},
|