@ellipticltd/aml-utils 0.16.26 → 0.16.27
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/.circleci/config.yml +87 -0
- package/.claude/settings.local.json +7 -0
- package/.eslintrc +45 -0
- package/.huskyrc +5 -0
- package/.mocharc.json +3 -0
- package/.nvmrc +1 -0
- package/.nycrc.json +11 -0
- package/.releaserc.json +18 -0
- package/.snyk +12 -0
- package/README.md +43 -11
- package/codecov.yml +29 -0
- package/commitlint.config.js +1 -0
- package/dist/errors/errors.js +42 -0
- package/dist/errors/errors.spec.d.ts +1 -0
- package/dist/errors/errors.spec.js +23 -0
- package/dist/file-parser/__tests/file-parser.spec.d.ts +1 -0
- package/dist/file-parser/__tests/file-parser.spec.js +109 -0
- package/dist/file-parser/__tests/parse-row.spec.d.ts +1 -0
- package/dist/file-parser/__tests/parse-row.spec.js +29 -0
- package/dist/file-parser/__tests/sanitize-rows.spec.d.ts +1 -0
- package/dist/file-parser/__tests/sanitize-rows.spec.js +78 -0
- package/{lib → dist}/file-parser/errors.js +1 -1
- package/{lib → dist}/file-parser/file-parser.d.ts +4 -2
- package/dist/file-parser/file-parser.js +55 -0
- package/{lib → dist}/file-parser/parse-row.js +1 -2
- package/{lib/file-parser/sanitizeRows.d.ts → dist/file-parser/sanitzeRows.d.ts} +1 -3
- package/dist/file-parser/sanitzeRows.js +18 -0
- package/dist/formatting/formatting.js +17 -0
- package/dist/formatting/formatting.spec.d.ts +1 -0
- package/dist/formatting/formatting.spec.js +37 -0
- package/{lib → dist}/index.d.ts +1 -1
- package/dist/index.js +22 -0
- package/dist/middleware/middleware.js +22 -0
- package/dist/orm-helpers/ormHelpers.js +17 -0
- package/dist/orm-helpers/ormHelpers.spec.d.ts +1 -0
- package/dist/orm-helpers/ormHelpers.spec.js +38 -0
- package/{lib → dist}/structured-file-parser/errors.js +0 -1
- package/{lib → dist}/structured-file-parser/parse-row.js +1 -2
- package/{lib → dist}/structured-file-parser/sanitize-rows.js +4 -3
- package/{lib → dist}/structured-file-parser/structured-file-parser.d.ts +2 -2
- package/dist/structured-file-parser/structured-file-parser.js +98 -0
- package/{lib → dist}/types/types.d.ts +6 -0
- package/dist/types/types.js +203 -0
- package/{lib → dist}/validations/validations.d.ts +110 -161
- package/dist/validations/validations.js +470 -0
- package/dist/validations/validations.spec.d.ts +1 -0
- package/dist/validations/validations.spec.js +463 -0
- package/lib/errors/errors.js +30 -19
- package/lib/errors/errors.spec.js +37 -0
- package/lib/file-parser/__tests/file-parser.spec.js +107 -0
- package/lib/file-parser/__tests/parse-row.spec.js +35 -0
- package/lib/file-parser/__tests/sanitize-rows.spec.js +88 -0
- package/lib/file-parser/errors.ts +7 -0
- package/lib/file-parser/file-parser.ts +84 -0
- package/lib/file-parser/parse-row.ts +52 -0
- package/lib/file-parser/sanitzeRows.ts +32 -0
- package/lib/formatting/formatting.js +12 -11
- package/lib/formatting/formatting.spec.js +45 -0
- package/lib/index.ts +19 -0
- package/lib/middleware/middleware.js +17 -14
- package/lib/orm-helpers/ormHelpers.js +13 -12
- package/lib/orm-helpers/ormHelpers.spec.js +41 -0
- package/lib/structured-file-parser/errors.ts +25 -0
- package/lib/structured-file-parser/parse-row.ts +52 -0
- package/lib/structured-file-parser/sanitize-rows.ts +24 -0
- package/lib/structured-file-parser/structured-file-parser.ts +155 -0
- package/lib/types/types.js +203 -191
- package/lib/validations/validations.js +461 -669
- package/lib/validations/validations.spec.js +603 -0
- package/package.json +61 -8
- package/tsconfig.json +26 -0
- package/lib/errors/errors.js.map +0 -1
- package/lib/file-parser/errors.js.map +0 -1
- package/lib/file-parser/file-parser.js +0 -59
- package/lib/file-parser/file-parser.js.map +0 -1
- package/lib/file-parser/parse-row.js.map +0 -1
- package/lib/file-parser/sanitizeRows.js +0 -15
- package/lib/file-parser/sanitizeRows.js.map +0 -1
- package/lib/formatting/formatting.js.map +0 -1
- package/lib/index.js +0 -21
- package/lib/index.js.map +0 -1
- package/lib/middleware/middleware.js.map +0 -1
- package/lib/orm-helpers/ormHelpers.js.map +0 -1
- package/lib/structured-file-parser/errors.js.map +0 -1
- package/lib/structured-file-parser/parse-row.js.map +0 -1
- package/lib/structured-file-parser/sanitize-rows.js.map +0 -1
- package/lib/structured-file-parser/structured-file-parser.js +0 -95
- package/lib/structured-file-parser/structured-file-parser.js.map +0 -1
- package/lib/types/types.js.map +0 -1
- package/lib/validations/validations.js.map +0 -1
- /package/{lib → dist}/errors/errors.d.ts +0 -0
- /package/{lib → dist}/file-parser/errors.d.ts +0 -0
- /package/{lib → dist}/file-parser/parse-row.d.ts +0 -0
- /package/{lib → dist}/formatting/formatting.d.ts +0 -0
- /package/{lib → dist}/middleware/middleware.d.ts +0 -0
- /package/{lib → dist}/orm-helpers/ormHelpers.d.ts +0 -0
- /package/{lib → dist}/structured-file-parser/errors.d.ts +0 -0
- /package/{lib → dist}/structured-file-parser/parse-row.d.ts +0 -0
- /package/{lib → dist}/structured-file-parser/sanitize-rows.d.ts +0 -0
|
@@ -0,0 +1,470 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
const V = require('validator');
|
|
3
|
+
const _ = require('lodash');
|
|
4
|
+
const { crypto: { Signature }, HDPrivateKey, HDPublicKey, PublicKey, Script, Transaction, } = require('bitcore-lib');
|
|
5
|
+
const addressValidator = require('multicoin-address-validator');
|
|
6
|
+
const eip55 = require('eip55');
|
|
7
|
+
const stellarSDK = require('stellar-sdk');
|
|
8
|
+
const E = require('../errors/errors');
|
|
9
|
+
const cryptoValidators = {
|
|
10
|
+
// Here we use our regex to validate the shape of the address, and eip55 to validate the checksum
|
|
11
|
+
isAddress(str) {
|
|
12
|
+
if (typeof str !== 'string' || !/^0x[0-9a-fA-F]{40}$/.test(str))
|
|
13
|
+
return false;
|
|
14
|
+
return eip55.verify(str, true);
|
|
15
|
+
},
|
|
16
|
+
isHexStrict(str) {
|
|
17
|
+
return typeof str === 'string' && /^0x[0-9a-fA-F]*$/.test(str);
|
|
18
|
+
},
|
|
19
|
+
isHex(str) {
|
|
20
|
+
return typeof str === 'string' && /^(0x)?[0-9a-fA-F]*$/.test(str);
|
|
21
|
+
},
|
|
22
|
+
isValidWeiAmount(str) {
|
|
23
|
+
return typeof str === 'string' && /^[0-9]+$/.test(str);
|
|
24
|
+
},
|
|
25
|
+
};
|
|
26
|
+
const validations = {
|
|
27
|
+
_validate(Err, pred, x, msg) {
|
|
28
|
+
if (pred(x)) {
|
|
29
|
+
return x;
|
|
30
|
+
}
|
|
31
|
+
throw new Err(msg);
|
|
32
|
+
},
|
|
33
|
+
_validateArg(pred, x, msg) {
|
|
34
|
+
return this._validate(E.InvalidArguments, pred, x, msg);
|
|
35
|
+
},
|
|
36
|
+
_tryCheck(fn, arg) {
|
|
37
|
+
try {
|
|
38
|
+
fn(arg);
|
|
39
|
+
return true;
|
|
40
|
+
}
|
|
41
|
+
catch (error) {
|
|
42
|
+
return false;
|
|
43
|
+
}
|
|
44
|
+
},
|
|
45
|
+
exists(x) {
|
|
46
|
+
return x != null;
|
|
47
|
+
},
|
|
48
|
+
nonEmpty(x) {
|
|
49
|
+
return (x != null ? x.length : undefined) > 0;
|
|
50
|
+
},
|
|
51
|
+
isNonEmptyString(x) {
|
|
52
|
+
return _.isString(x) && (x != null ? x.length : undefined) > 0;
|
|
53
|
+
},
|
|
54
|
+
isSafeString(str) {
|
|
55
|
+
// eslint-disable-next-line no-useless-escape
|
|
56
|
+
return RegExp(/^(\p{L}|[0-9]|-|=|!|\.|:|\s|@|\+|_|,|\$|£|&)+$/, 'u').test(str);
|
|
57
|
+
},
|
|
58
|
+
ensureShortEnough(limit, x) {
|
|
59
|
+
const l = x != null ? x.length : undefined;
|
|
60
|
+
if (l <= limit) {
|
|
61
|
+
return true;
|
|
62
|
+
}
|
|
63
|
+
throw new E.BadRequest(`Max query size exceeded: ${l} / ${limit}`);
|
|
64
|
+
},
|
|
65
|
+
ensure(crit, msg) {
|
|
66
|
+
if (crit) {
|
|
67
|
+
return true;
|
|
68
|
+
}
|
|
69
|
+
throw new E.BadRequest(msg);
|
|
70
|
+
},
|
|
71
|
+
argExists(x, msg) {
|
|
72
|
+
return this._validateArg(this.exists, x, msg);
|
|
73
|
+
},
|
|
74
|
+
check: {
|
|
75
|
+
matches(required, given, msg) {
|
|
76
|
+
const newGiven = _.uniq(given);
|
|
77
|
+
const crit = _.intersection(newGiven, required).length === given.length;
|
|
78
|
+
if (crit) {
|
|
79
|
+
return true;
|
|
80
|
+
}
|
|
81
|
+
throw new E.BadRequest(msg);
|
|
82
|
+
},
|
|
83
|
+
wasFound(type) {
|
|
84
|
+
return (item) => {
|
|
85
|
+
if (item == null) {
|
|
86
|
+
throw new E.NotFound(`Unknown ${type}`);
|
|
87
|
+
}
|
|
88
|
+
else {
|
|
89
|
+
return item;
|
|
90
|
+
}
|
|
91
|
+
};
|
|
92
|
+
},
|
|
93
|
+
wasCreated(msg) {
|
|
94
|
+
return (arr) => {
|
|
95
|
+
if (!arr[1]) {
|
|
96
|
+
throw new E.BadRequest(msg);
|
|
97
|
+
}
|
|
98
|
+
else {
|
|
99
|
+
return arr;
|
|
100
|
+
}
|
|
101
|
+
};
|
|
102
|
+
},
|
|
103
|
+
isTrue(crit, msg) {
|
|
104
|
+
if (crit) {
|
|
105
|
+
return true;
|
|
106
|
+
}
|
|
107
|
+
throw new E.BadRequest(msg);
|
|
108
|
+
},
|
|
109
|
+
isFalse(crit, msg) {
|
|
110
|
+
if (!crit) {
|
|
111
|
+
return true;
|
|
112
|
+
}
|
|
113
|
+
throw new E.BadRequest(msg);
|
|
114
|
+
},
|
|
115
|
+
},
|
|
116
|
+
isCustomerReference(x) {
|
|
117
|
+
return (_.isString(x)
|
|
118
|
+
&& (x != null ? x.length : undefined) > 0
|
|
119
|
+
&& (x != null ? x.length : undefined) <= 100);
|
|
120
|
+
},
|
|
121
|
+
isCustomerLabelName(x) {
|
|
122
|
+
return (_.isString(x)
|
|
123
|
+
&& (x != null ? x.length : undefined) > 0
|
|
124
|
+
&& (x != null ? x.length : undefined) <= 50);
|
|
125
|
+
},
|
|
126
|
+
binanceChain: {
|
|
127
|
+
isAddress(str) {
|
|
128
|
+
return /^(bnb)([a-z0-9]{39})$/.test(str);
|
|
129
|
+
},
|
|
130
|
+
isTxHash(str) {
|
|
131
|
+
if (!V.isHexadecimal(str)) {
|
|
132
|
+
return false;
|
|
133
|
+
}
|
|
134
|
+
return str.length === 64;
|
|
135
|
+
},
|
|
136
|
+
},
|
|
137
|
+
bitcoin: {
|
|
138
|
+
isAddress(str) {
|
|
139
|
+
const network = process.env.BITCOIN_NETWORK === 'testnet' ? 'testnet' : 'prod';
|
|
140
|
+
return typeof str === 'string' && addressValidator.validate(str.trim(), 'btc', network);
|
|
141
|
+
},
|
|
142
|
+
isBech32Address(str) {
|
|
143
|
+
return /^bc1[ac-hj-np-z02-9]{6,86}|^BC1[AC-HJ-NP-Z02-9]{6,86}/.test(str);
|
|
144
|
+
},
|
|
145
|
+
isHDPublicKey(str) {
|
|
146
|
+
try {
|
|
147
|
+
HDPublicKey(str);
|
|
148
|
+
return true;
|
|
149
|
+
}
|
|
150
|
+
catch (error) {
|
|
151
|
+
return false;
|
|
152
|
+
}
|
|
153
|
+
},
|
|
154
|
+
isPublicKey(str) {
|
|
155
|
+
try {
|
|
156
|
+
PublicKey(str);
|
|
157
|
+
return true;
|
|
158
|
+
}
|
|
159
|
+
catch (error) {
|
|
160
|
+
return false;
|
|
161
|
+
}
|
|
162
|
+
},
|
|
163
|
+
isTxHash(str) {
|
|
164
|
+
if (!V.isHexadecimal(str)) {
|
|
165
|
+
return false;
|
|
166
|
+
}
|
|
167
|
+
return str.length === 64;
|
|
168
|
+
},
|
|
169
|
+
isTxHex(str) {
|
|
170
|
+
if (!V.isHexadecimal(str)) {
|
|
171
|
+
return false;
|
|
172
|
+
}
|
|
173
|
+
try {
|
|
174
|
+
Transaction(str);
|
|
175
|
+
return true;
|
|
176
|
+
}
|
|
177
|
+
catch (error) {
|
|
178
|
+
return false;
|
|
179
|
+
}
|
|
180
|
+
},
|
|
181
|
+
isHDPath(str) {
|
|
182
|
+
return HDPrivateKey.isValidPath(str);
|
|
183
|
+
},
|
|
184
|
+
isScriptHex(str) {
|
|
185
|
+
if (!V.isHexadecimal(str)) {
|
|
186
|
+
return false;
|
|
187
|
+
}
|
|
188
|
+
try {
|
|
189
|
+
Script(str);
|
|
190
|
+
return true;
|
|
191
|
+
}
|
|
192
|
+
catch (error) {
|
|
193
|
+
return false;
|
|
194
|
+
}
|
|
195
|
+
},
|
|
196
|
+
isTxSignature(str) {
|
|
197
|
+
if (!V.isHexadecimal(str)) {
|
|
198
|
+
return false;
|
|
199
|
+
}
|
|
200
|
+
try {
|
|
201
|
+
const b = Buffer.from(str, 'hex');
|
|
202
|
+
Signature.fromTxFormat(b);
|
|
203
|
+
return true;
|
|
204
|
+
}
|
|
205
|
+
catch (error) {
|
|
206
|
+
return false;
|
|
207
|
+
}
|
|
208
|
+
},
|
|
209
|
+
isBlockHeight(obj) {
|
|
210
|
+
return _.isInteger(+obj) && parseInt(obj, 10) >= 0;
|
|
211
|
+
},
|
|
212
|
+
},
|
|
213
|
+
bitcoinCash: {
|
|
214
|
+
isAddress(str) {
|
|
215
|
+
return /^[13][a-km-zA-HJ-NP-Z1-9]{25,34}$|^(bitcoincash:)?[q|p][a-z0-9]{41}$|^(BITCOINCASH:)?[Q|P][A-Z0-9]{41}$/.test(str);
|
|
216
|
+
},
|
|
217
|
+
isTxHash(str) {
|
|
218
|
+
if (!V.isHexadecimal(str)) {
|
|
219
|
+
return false;
|
|
220
|
+
}
|
|
221
|
+
return str.length === 64;
|
|
222
|
+
},
|
|
223
|
+
},
|
|
224
|
+
ethereum: {
|
|
225
|
+
isAddress(str) {
|
|
226
|
+
return cryptoValidators.isAddress(str);
|
|
227
|
+
},
|
|
228
|
+
isBlockHash(str) {
|
|
229
|
+
return str.length === 66 && cryptoValidators.isHexStrict(str);
|
|
230
|
+
},
|
|
231
|
+
isTxHash(str) {
|
|
232
|
+
return str.length === 66 && cryptoValidators.isHexStrict(str);
|
|
233
|
+
},
|
|
234
|
+
isAddressCode(str) {
|
|
235
|
+
return cryptoValidators.isHexStrict(str);
|
|
236
|
+
},
|
|
237
|
+
isValidWeiAmount(str) {
|
|
238
|
+
return cryptoValidators.isValidWeiAmount(str);
|
|
239
|
+
},
|
|
240
|
+
},
|
|
241
|
+
horizen: {
|
|
242
|
+
isAddress(str) {
|
|
243
|
+
return addressValidator.validate(str, 'zen');
|
|
244
|
+
},
|
|
245
|
+
isTxHash(str) {
|
|
246
|
+
if (!V.isHexadecimal(str)) {
|
|
247
|
+
return false;
|
|
248
|
+
}
|
|
249
|
+
return str.length === 64;
|
|
250
|
+
},
|
|
251
|
+
},
|
|
252
|
+
litecoin: {
|
|
253
|
+
isAddress(str) {
|
|
254
|
+
return /^[3LM][a-km-zA-HJ-NP-Z1-9]{24,33}$|^ltc1[ac-hj-np-z02-9]{6,86}$|^LTC1[AC-HJ-NP-Z02-9]{6,86}$|^ltcmweb[a-zA-Z0-9]{114}$/.test(str);
|
|
255
|
+
},
|
|
256
|
+
isTxHash(str) {
|
|
257
|
+
if (!V.isHexadecimal(str)) {
|
|
258
|
+
return false;
|
|
259
|
+
}
|
|
260
|
+
return str.length === 64;
|
|
261
|
+
},
|
|
262
|
+
},
|
|
263
|
+
ripple: {
|
|
264
|
+
isAddress(str) {
|
|
265
|
+
return addressValidator.validate(str, 'xrp');
|
|
266
|
+
},
|
|
267
|
+
isTxHash(str) {
|
|
268
|
+
if (!V.isHexadecimal(str)) {
|
|
269
|
+
return false;
|
|
270
|
+
}
|
|
271
|
+
return str.length === 64;
|
|
272
|
+
},
|
|
273
|
+
},
|
|
274
|
+
stellar: {
|
|
275
|
+
isAddress(str) {
|
|
276
|
+
return stellarSDK.StrKey.isValidEd25519PublicKey(str);
|
|
277
|
+
},
|
|
278
|
+
isTxHash(str) {
|
|
279
|
+
if (!V.isHexadecimal(str)) {
|
|
280
|
+
return false;
|
|
281
|
+
}
|
|
282
|
+
return str.length === 64;
|
|
283
|
+
},
|
|
284
|
+
},
|
|
285
|
+
zcash: {
|
|
286
|
+
isAddress(str) {
|
|
287
|
+
return addressValidator.validate(str, 'zec');
|
|
288
|
+
},
|
|
289
|
+
isTxHash(str) {
|
|
290
|
+
if (!V.isHexadecimal(str)) {
|
|
291
|
+
return false;
|
|
292
|
+
}
|
|
293
|
+
return str.length === 64;
|
|
294
|
+
},
|
|
295
|
+
},
|
|
296
|
+
zilliqa: {
|
|
297
|
+
isAddress(str) {
|
|
298
|
+
// https://pub.dev/documentation/laksadart/latest/laksadart/isBech32.html
|
|
299
|
+
return !!str.match(/^zil1[qpzry9x8gf2tvdw0s3jn54khce6mua7l]{38}$/);
|
|
300
|
+
},
|
|
301
|
+
isTxHash(str) {
|
|
302
|
+
return str.length === 66 && cryptoValidators.isHexStrict(str);
|
|
303
|
+
},
|
|
304
|
+
},
|
|
305
|
+
algorand: {
|
|
306
|
+
isAddress(str) {
|
|
307
|
+
return addressValidator.validate(str, 'algo');
|
|
308
|
+
},
|
|
309
|
+
isTxHash(str) {
|
|
310
|
+
return str.length === 52;
|
|
311
|
+
},
|
|
312
|
+
},
|
|
313
|
+
tezos: {
|
|
314
|
+
isAddress(str) {
|
|
315
|
+
return str[0] !== 'o' && addressValidator.validate(str, 'xtz');
|
|
316
|
+
},
|
|
317
|
+
isTxHash(str) {
|
|
318
|
+
return str.length === 51;
|
|
319
|
+
},
|
|
320
|
+
},
|
|
321
|
+
polkadot: {
|
|
322
|
+
isAddress(str) {
|
|
323
|
+
return addressValidator.validate(str, 'dot');
|
|
324
|
+
},
|
|
325
|
+
isTxHash(str) {
|
|
326
|
+
return str.length === 66 && cryptoValidators.isHexStrict(str);
|
|
327
|
+
},
|
|
328
|
+
},
|
|
329
|
+
cardano: {
|
|
330
|
+
isAddress(str) {
|
|
331
|
+
return addressValidator.validate(str, 'ada');
|
|
332
|
+
},
|
|
333
|
+
isTxHash(str) {
|
|
334
|
+
if (!V.isHexadecimal(str)) {
|
|
335
|
+
return false;
|
|
336
|
+
}
|
|
337
|
+
return str.length === 64;
|
|
338
|
+
},
|
|
339
|
+
},
|
|
340
|
+
cryptocom: {
|
|
341
|
+
isAddress(str) {
|
|
342
|
+
return addressValidator.validate(str, 'cro');
|
|
343
|
+
},
|
|
344
|
+
isTxHash(str) {
|
|
345
|
+
if (!V.isHexadecimal(str)) {
|
|
346
|
+
return false;
|
|
347
|
+
}
|
|
348
|
+
return str.length === 64;
|
|
349
|
+
},
|
|
350
|
+
},
|
|
351
|
+
near: {
|
|
352
|
+
isAddress(str) {
|
|
353
|
+
// https://nomicon.io/DataStructures/Account
|
|
354
|
+
return /^(([a-z\d]+[-_])*[a-z\d]+\.)*([a-z\d]+[-_])*[a-z\d]+$/.test(str);
|
|
355
|
+
},
|
|
356
|
+
isTxHash(str) {
|
|
357
|
+
return str.length === 44 || str.length === 43;
|
|
358
|
+
},
|
|
359
|
+
},
|
|
360
|
+
doge: {
|
|
361
|
+
isAddress(str) {
|
|
362
|
+
return /^[a-zA-Z\d]{34}$/.test(str);
|
|
363
|
+
},
|
|
364
|
+
isTxHash(str) {
|
|
365
|
+
return str.length === 64;
|
|
366
|
+
},
|
|
367
|
+
},
|
|
368
|
+
cosmos: {
|
|
369
|
+
isAddress(str) {
|
|
370
|
+
return /^cosmos{1}[a-zA-Z\d]{39}$/.test(str);
|
|
371
|
+
},
|
|
372
|
+
isTxHash(str) {
|
|
373
|
+
return str.length === 64 && cryptoValidators.isHex(str);
|
|
374
|
+
},
|
|
375
|
+
},
|
|
376
|
+
solana: {
|
|
377
|
+
isAddress(str) {
|
|
378
|
+
return /^[1-9A-HJ-NP-Za-km-z]{32,44}$/.test(str);
|
|
379
|
+
},
|
|
380
|
+
isTxHash(str) {
|
|
381
|
+
return /^[1-9A-HJ-NP-Za-km-z]{77,88}$/.test(str);
|
|
382
|
+
},
|
|
383
|
+
},
|
|
384
|
+
binanceSmartChain: {
|
|
385
|
+
isAddress(str) {
|
|
386
|
+
return cryptoValidators.isAddress(str);
|
|
387
|
+
},
|
|
388
|
+
isTxHash(str) {
|
|
389
|
+
return str.length === 66 && cryptoValidators.isHexStrict(str);
|
|
390
|
+
},
|
|
391
|
+
},
|
|
392
|
+
polygon: {
|
|
393
|
+
isAddress(str) {
|
|
394
|
+
return cryptoValidators.isAddress(str);
|
|
395
|
+
},
|
|
396
|
+
isTxHash(str) {
|
|
397
|
+
return str.length === 66 && cryptoValidators.isHexStrict(str);
|
|
398
|
+
},
|
|
399
|
+
},
|
|
400
|
+
filecoin: {
|
|
401
|
+
isAddress(str) {
|
|
402
|
+
return /^(f0|f1|f2|f3)/.test(str);
|
|
403
|
+
},
|
|
404
|
+
isTxHash(str) {
|
|
405
|
+
return str.length === 62 && /^bafy2bza/.test(str);
|
|
406
|
+
},
|
|
407
|
+
},
|
|
408
|
+
optimism: {
|
|
409
|
+
isAddress(str) {
|
|
410
|
+
return cryptoValidators.isAddress(str);
|
|
411
|
+
},
|
|
412
|
+
isTxHash(str) {
|
|
413
|
+
return str.length === 66 && cryptoValidators.isHexStrict(str);
|
|
414
|
+
},
|
|
415
|
+
},
|
|
416
|
+
avalanche: {
|
|
417
|
+
isAddress(str) {
|
|
418
|
+
return cryptoValidators.isAddress(str);
|
|
419
|
+
},
|
|
420
|
+
isTxHash(str) {
|
|
421
|
+
return str.length === 66 && cryptoValidators.isHexStrict(str);
|
|
422
|
+
},
|
|
423
|
+
},
|
|
424
|
+
arbitrum: {
|
|
425
|
+
isAddress(str) {
|
|
426
|
+
return cryptoValidators.isAddress(str);
|
|
427
|
+
},
|
|
428
|
+
isTxHash(str) {
|
|
429
|
+
return str.length === 66 && cryptoValidators.isHexStrict(str);
|
|
430
|
+
},
|
|
431
|
+
},
|
|
432
|
+
tron: {
|
|
433
|
+
isAddress(str) {
|
|
434
|
+
return addressValidator.validate(str, 'tron');
|
|
435
|
+
},
|
|
436
|
+
isTxHash(str) {
|
|
437
|
+
return str.length === 64 && cryptoValidators.isHex(str);
|
|
438
|
+
},
|
|
439
|
+
},
|
|
440
|
+
fantom: {
|
|
441
|
+
isAddress(str) {
|
|
442
|
+
return cryptoValidators.isAddress(str);
|
|
443
|
+
},
|
|
444
|
+
isTxHash(str) {
|
|
445
|
+
return str.length === 66 && cryptoValidators.isHexStrict(str);
|
|
446
|
+
},
|
|
447
|
+
},
|
|
448
|
+
celo: {
|
|
449
|
+
isAddress(str) {
|
|
450
|
+
return cryptoValidators.isAddress(str);
|
|
451
|
+
},
|
|
452
|
+
isTxHash(str) {
|
|
453
|
+
return str.length === 66 && cryptoValidators.isHexStrict(str);
|
|
454
|
+
},
|
|
455
|
+
},
|
|
456
|
+
ethereumClassic: {
|
|
457
|
+
isAddress(str) {
|
|
458
|
+
return cryptoValidators.isAddress(str);
|
|
459
|
+
},
|
|
460
|
+
isTxHash(str) {
|
|
461
|
+
return str.length === 66 && cryptoValidators.isHexStrict(str);
|
|
462
|
+
},
|
|
463
|
+
},
|
|
464
|
+
};
|
|
465
|
+
Object.keys(V).forEach((k) => {
|
|
466
|
+
const v = V[k];
|
|
467
|
+
// don't trigger validation with null values (prevents swagger 500 error)
|
|
468
|
+
validations[k] = (x) => (x === null ? false : v(x));
|
|
469
|
+
});
|
|
470
|
+
module.exports = validations;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|