@human-protocol/sdk 3.0.5 → 3.0.7
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/constants.d.ts +1 -0
- package/dist/constants.d.ts.map +1 -1
- package/dist/constants.js +16 -15
- package/dist/decorators.js +1 -2
- package/dist/encryption.d.ts +5 -3
- package/dist/encryption.d.ts.map +1 -1
- package/dist/encryption.js +34 -8
- package/dist/enums.js +2 -2
- package/dist/escrow.js +1 -1
- package/dist/graphql/queries/operator.d.ts.map +1 -1
- package/dist/graphql/queries/operator.js +5 -1
- package/dist/graphql/queries/transaction.d.ts.map +1 -1
- package/dist/graphql/queries/transaction.js +3 -1
- package/dist/interfaces.d.ts +4 -0
- package/dist/interfaces.d.ts.map +1 -1
- package/dist/kvstore.js +1 -1
- package/dist/staking.js +1 -1
- package/dist/types.js +1 -1
- package/package.json +2 -2
- package/src/constants.ts +15 -14
- package/src/encryption.ts +46 -14
- package/src/graphql/queries/operator.ts +5 -1
- package/src/graphql/queries/transaction.ts +5 -1
- package/src/interfaces.ts +4 -0
package/dist/constants.d.ts
CHANGED
package/dist/constants.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../src/constants.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAEtC;;GAEG;AACH,eAAO,MAAM,qBAAqB,0BAA0B,CAAC;AAE7D;;GAEG;AACH,eAAO,MAAM,gBAAgB,cAAc,CAAC;AAE5C;;GAEG;AACH,eAAO,MAAM,cAAc,OAAO,CAAC;AAEnC;;GAEG;AACH,eAAO,MAAM,YAAY,OAAO,CAAC;AAEjC;;GAEG;AACH,eAAO,MAAM,eAAe,QAAQ,CAAC;AAErC;;GAEG;AACH,eAAO,MAAM,aAAa,IAAI,CAAC;AAE/B;;GAEG;AACH,oBAAY,UAAU;IACpB,EAAE,MAAM;IACR,OAAO,MAAM;IACb,WAAW,MAAM;IACjB,YAAY,MAAM;IAClB,gBAAgB,MAAM;IACtB,SAAS,MAAM;IACf,SAAS,MAAM;IACf,qBAAqB,MAAM;CAC5B;AAED;;GAEG;AACH,eAAO,MAAM,QAAQ,EAAE;KACpB,OAAO,IAAI,OAAO,CAAC,CAAC,EAAE,WAAW;CAmSnC,CAAC;AAEF,eAAO,MAAM,WAAW
|
|
1
|
+
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../src/constants.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAEtC;;GAEG;AACH,eAAO,MAAM,qBAAqB,0BAA0B,CAAC;AAE7D;;GAEG;AACH,eAAO,MAAM,gBAAgB,cAAc,CAAC;AAE5C;;GAEG;AACH,eAAO,MAAM,cAAc,OAAO,CAAC;AAEnC;;GAEG;AACH,eAAO,MAAM,YAAY,OAAO,CAAC;AAEjC;;GAEG;AACH,eAAO,MAAM,eAAe,QAAQ,CAAC;AAErC;;GAEG;AACH,eAAO,MAAM,aAAa,IAAI,CAAC;AAE/B;;GAEG;AACH,oBAAY,UAAU;IACpB,EAAE,MAAM;IACR,OAAO,MAAM;IACb,WAAW,MAAM;IACjB,YAAY,MAAM;IAClB,gBAAgB,MAAM;IACtB,SAAS,MAAM;IACf,SAAS,MAAM;IACf,qBAAqB,MAAM;CAC5B;AAED;;GAEG;AACH,eAAO,MAAM,QAAQ,EAAE;KACpB,OAAO,IAAI,OAAO,CAAC,CAAC,EAAE,WAAW;CAmSnC,CAAC;AAEF,eAAO,MAAM,WAAW;;;;;;;;;CASvB,CAAC;AAEF,eAAO,MAAM,IAAI;;;;;CAKhB,CAAC;AAEF,eAAO,MAAM,4BAA4B,uBAAuB,CAAC"}
|
package/dist/constants.js
CHANGED
|
@@ -39,7 +39,7 @@ var HttpStatus;
|
|
|
39
39
|
HttpStatus[HttpStatus["FORBIDDEN"] = 403] = "FORBIDDEN";
|
|
40
40
|
HttpStatus[HttpStatus["NOT_FOUND"] = 404] = "NOT_FOUND";
|
|
41
41
|
HttpStatus[HttpStatus["INTERNAL_SERVER_ERROR"] = 500] = "INTERNAL_SERVER_ERROR";
|
|
42
|
-
})(HttpStatus
|
|
42
|
+
})(HttpStatus || (exports.HttpStatus = HttpStatus = {}));
|
|
43
43
|
/**
|
|
44
44
|
* @constant Default network parameters
|
|
45
45
|
*/
|
|
@@ -54,7 +54,7 @@ exports.NETWORKS = {
|
|
|
54
54
|
rewardPoolAddress: '0x4A5963Dd6792692e9147EdC7659936b96251917a',
|
|
55
55
|
kvstoreAddress: '0xB6d36B1CDaD50302BCB3DB43bAb0D349458e1b8D',
|
|
56
56
|
subgraphUrl: 'https://api.studio.thegraph.com/query/74256/ethereum/version/latest',
|
|
57
|
-
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
57
|
+
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/QmaTcYR8NCzZuxwY7tBkMJAo1Q64BMqNNSzqjxd7FH9s2p',
|
|
58
58
|
oldSubgraphUrl: '',
|
|
59
59
|
oldFactoryAddress: '',
|
|
60
60
|
},
|
|
@@ -96,7 +96,7 @@ exports.NETWORKS = {
|
|
|
96
96
|
rewardPoolAddress: '0xAFf5a986A530ff839d49325A5dF69F96627E8D29',
|
|
97
97
|
kvstoreAddress: '0xCc0AF0635aa19fE799B6aFDBe28fcFAeA7f00a60',
|
|
98
98
|
subgraphUrl: 'https://api.studio.thegraph.com/query/74256/sepolia/version/latest',
|
|
99
|
-
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
99
|
+
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/QmadNQBBzcfJHTmzLezZGbwvLux7HmnmfByBHubS2cmLUr',
|
|
100
100
|
oldSubgraphUrl: '',
|
|
101
101
|
oldFactoryAddress: '',
|
|
102
102
|
},
|
|
@@ -110,7 +110,7 @@ exports.NETWORKS = {
|
|
|
110
110
|
rewardPoolAddress: '0xf376443BCc6d4d4D63eeC086bc4A9E4a83878e0e',
|
|
111
111
|
kvstoreAddress: '0x21A0C4CED7aE447fCf87D9FE3A29FA9B3AB20Ff1',
|
|
112
112
|
subgraphUrl: 'https://api.studio.thegraph.com/query/74256/bsc/version/latest',
|
|
113
|
-
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
113
|
+
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/QmXZ4QJMi8kyfXDEJwtdizyKf5JdJui89iYCLCE79N8Xf5',
|
|
114
114
|
oldSubgraphUrl: 'https://api.thegraph.com/subgraphs/name/humanprotocol/bsc',
|
|
115
115
|
oldFactoryAddress: '0xc88bC422cAAb2ac8812de03176402dbcA09533f4',
|
|
116
116
|
},
|
|
@@ -124,7 +124,7 @@ exports.NETWORKS = {
|
|
|
124
124
|
rewardPoolAddress: '0xB0A0500103eCEc431b73F6BAd923F0a2774E6e29',
|
|
125
125
|
kvstoreAddress: '0x32e27177BA6Ea91cf28dfd91a0Da9822A4b74EcF',
|
|
126
126
|
subgraphUrl: 'https://api.studio.thegraph.com/query/74256/bsc-testnet/version/latest',
|
|
127
|
-
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
127
|
+
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/Qmdq449rn4WKDf7NLvRZgt7CedZRrvpDzPqcvSmhvuu16D',
|
|
128
128
|
oldSubgraphUrl: 'https://api.thegraph.com/subgraphs/name/humanprotocol/bsctest',
|
|
129
129
|
oldFactoryAddress: '0xaae6a2646c1f88763e62e0cd08ad050ea66ac46f',
|
|
130
130
|
},
|
|
@@ -138,7 +138,7 @@ exports.NETWORKS = {
|
|
|
138
138
|
rewardPoolAddress: '0xa8e32d777a3839440cc7c24D591A64B9481753B3',
|
|
139
139
|
kvstoreAddress: '0xbcB28672F826a50B03EE91B28145EAbddA73B2eD',
|
|
140
140
|
subgraphUrl: 'https://api.studio.thegraph.com/query/74256/polygon/version/latest',
|
|
141
|
-
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
141
|
+
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/QmNdsofT4Cj2KRwr8vgyKgCWpZNmrMN41zUdygRz7eSGC9',
|
|
142
142
|
oldSubgraphUrl: 'https://api.thegraph.com/subgraphs/name/humanprotocol/polygon',
|
|
143
143
|
oldFactoryAddress: '0x45eBc3eAE6DA485097054ae10BA1A0f8e8c7f794',
|
|
144
144
|
},
|
|
@@ -166,7 +166,7 @@ exports.NETWORKS = {
|
|
|
166
166
|
rewardPoolAddress: '0xd866bCEFf6D0F77E1c3EAE28230AE6C79b03fDa7',
|
|
167
167
|
kvstoreAddress: '0x724AeFC243EdacCA27EAB86D3ec5a76Af4436Fc7',
|
|
168
168
|
subgraphUrl: 'https://api.studio.thegraph.com/query/74256/amoy/version/latest',
|
|
169
|
-
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
169
|
+
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/Qmbwio5UnvDn5GQRJ5kLJfK27fqHK9nkEh4YXXYKWCc9rH',
|
|
170
170
|
oldSubgraphUrl: '',
|
|
171
171
|
oldFactoryAddress: '',
|
|
172
172
|
},
|
|
@@ -180,7 +180,7 @@ exports.NETWORKS = {
|
|
|
180
180
|
rewardPoolAddress: '0x4A5963Dd6792692e9147EdC7659936b96251917a',
|
|
181
181
|
kvstoreAddress: '0x2B95bEcb6EBC4589f64CB000dFCF716b4aeF8aA6',
|
|
182
182
|
subgraphUrl: 'https://api.studio.thegraph.com/query/74256/moonbeam/version/latest',
|
|
183
|
-
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
183
|
+
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/QmYe9hsFYuVgQsH719AsqRNqgVM8YBYfCuhBNYjXtBqQru',
|
|
184
184
|
oldSubgraphUrl: 'https://api.thegraph.com/subgraphs/name/humanprotocol/moonbeam',
|
|
185
185
|
oldFactoryAddress: '0x98108c28B7767a52BE38B4860832dd4e11A7ecad',
|
|
186
186
|
},
|
|
@@ -194,7 +194,7 @@ exports.NETWORKS = {
|
|
|
194
194
|
rewardPoolAddress: '0xf46B45Df3d956369726d8Bd93Ba33963Ab692920',
|
|
195
195
|
kvstoreAddress: '0xcC561f4482f4Ff051D2Dcc65c2cE1A0f291bbA46',
|
|
196
196
|
subgraphUrl: 'https://api.studio.thegraph.com/query/74256/moonbase-alpha/version/latest',
|
|
197
|
-
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
197
|
+
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/QmeC4JrotcrXWJtJU519RX3KkxE5879wveRJJ58EheH3j1',
|
|
198
198
|
oldSubgraphUrl: '',
|
|
199
199
|
oldFactoryAddress: '',
|
|
200
200
|
},
|
|
@@ -208,7 +208,7 @@ exports.NETWORKS = {
|
|
|
208
208
|
rewardPoolAddress: '0x5517fE916Fe9F8dB15B0DDc76ebDf0BdDCd4ed18',
|
|
209
209
|
kvstoreAddress: '0x3aD4B091E054f192a822D1406f4535eAd38580e4',
|
|
210
210
|
subgraphUrl: 'https://api.studio.thegraph.com/query/74256/fuji/version/latest',
|
|
211
|
-
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
211
|
+
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/QmcFhecY6w3AhKGSg8XeidXwwuXCV9DAQ5SYGE1sTzydgR',
|
|
212
212
|
oldSubgraphUrl: 'https://api.thegraph.com/subgraphs/name/humanprotocol/fuji',
|
|
213
213
|
oldFactoryAddress: '0xfb4469201951C3B9a7F1996c477cb7BDBEcE0A88',
|
|
214
214
|
},
|
|
@@ -222,7 +222,7 @@ exports.NETWORKS = {
|
|
|
222
222
|
rewardPoolAddress: '0x4A5963Dd6792692e9147EdC7659936b96251917a',
|
|
223
223
|
kvstoreAddress: '0x9Bc7bff35B2Be2413708d48c3B0aEF5c43646728',
|
|
224
224
|
subgraphUrl: 'https://api.studio.thegraph.com/query/74256/avalanche/version/latest',
|
|
225
|
-
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
225
|
+
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/QmYR8NUuAQVoGmGSwKanUJLjX9iZxrEyGH39HjUuXLmsum',
|
|
226
226
|
oldSubgraphUrl: 'https://api.thegraph.com/subgraphs/name/humanprotocol/avalanche',
|
|
227
227
|
oldFactoryAddress: '0x9767a578ba7a5FA1563c8229943cB01cd8446BB4',
|
|
228
228
|
},
|
|
@@ -236,7 +236,7 @@ exports.NETWORKS = {
|
|
|
236
236
|
rewardPoolAddress: '0xA9545C2530BD5bdb464d5E274F59ACceAa73eD86',
|
|
237
237
|
kvstoreAddress: '0x938335006ea6F9Eb0e8020969cFF94404425e298',
|
|
238
238
|
subgraphUrl: 'https://api.studio.thegraph.com/query/74256/celo-alfajores/version/latest',
|
|
239
|
-
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
239
|
+
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/Qmb2WKCFFhT7REAjTuMd9pZvGw7rRpzeZSPJ3KRztD2pMM',
|
|
240
240
|
oldSubgraphUrl: '',
|
|
241
241
|
oldFactoryAddress: '',
|
|
242
242
|
},
|
|
@@ -250,7 +250,7 @@ exports.NETWORKS = {
|
|
|
250
250
|
rewardPoolAddress: '0xb9344bAD98E3d26a4d83900922baf395a2Ec154c',
|
|
251
251
|
kvstoreAddress: '0x86Af9f6Cd34B69Db1B202223C6d6D109f2491569',
|
|
252
252
|
subgraphUrl: 'https://api.studio.thegraph.com/query/74256/celo/version/latest',
|
|
253
|
-
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
253
|
+
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/Qmeeb5zshw1z9Q38NNPun2Pd7P951Mkzz5ywK171tauNRY',
|
|
254
254
|
oldSubgraphUrl: '',
|
|
255
255
|
oldFactoryAddress: '',
|
|
256
256
|
},
|
|
@@ -264,7 +264,7 @@ exports.NETWORKS = {
|
|
|
264
264
|
rewardPoolAddress: '0x7ABa5F75b2b530cB0c8927C86591c21dF44f06b6',
|
|
265
265
|
kvstoreAddress: '0x6512d894cc3d3FE93Da9d0420430136fA889FaB9',
|
|
266
266
|
subgraphUrl: 'https://api.studio.thegraph.com/query/74256/xlayer/version/latest',
|
|
267
|
-
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
267
|
+
subgraphUrlApiKey: 'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/QmWTggMrB5sRSs2fePuqQG9WbLMk8HtnfLH3VbRhmVdF8s',
|
|
268
268
|
oldSubgraphUrl: '',
|
|
269
269
|
oldFactoryAddress: '',
|
|
270
270
|
},
|
|
@@ -278,7 +278,7 @@ exports.NETWORKS = {
|
|
|
278
278
|
rewardPoolAddress: '0x6daccd1f3a68945f8a7ac6d20260953f7a97fae4',
|
|
279
279
|
kvstoreAddress: '0xdE8BE9E3C12E9F546309A429cd88d026a25EaF8C',
|
|
280
280
|
subgraphUrl: 'https://api.studio.thegraph.com/query/74256/xlayer-testnet/version/latest',
|
|
281
|
-
subgraphUrlApiKey: 'https://gateway-testnet-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
281
|
+
subgraphUrlApiKey: 'https://gateway-testnet-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/QmQrTmq89ZCdVABsFpLHtQUWuyyVzbcARoan9eztHd21oP',
|
|
282
282
|
oldSubgraphUrl: '',
|
|
283
283
|
oldFactoryAddress: '',
|
|
284
284
|
},
|
|
@@ -305,6 +305,7 @@ exports.KVStoreKeys = {
|
|
|
305
305
|
url: 'url',
|
|
306
306
|
jobTypes: 'job_types',
|
|
307
307
|
registrationNeeded: 'registration_needed',
|
|
308
|
+
registrationInstructions: 'registration_instructions',
|
|
308
309
|
};
|
|
309
310
|
exports.Role = {
|
|
310
311
|
JobLauncher: 'Job Launcher',
|
package/dist/decorators.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.requiresSigner =
|
|
3
|
+
exports.requiresSigner = requiresSigner;
|
|
4
4
|
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
5
5
|
const error_1 = require("./error");
|
|
6
6
|
function requiresSigner(target, propertyKey, descriptor) {
|
|
@@ -16,4 +16,3 @@ function requiresSigner(target, propertyKey, descriptor) {
|
|
|
16
16
|
};
|
|
17
17
|
return descriptor;
|
|
18
18
|
}
|
|
19
|
-
exports.requiresSigner = requiresSigner;
|
package/dist/encryption.d.ts
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import * as openpgp from 'openpgp';
|
|
2
2
|
import { IKeyPair } from './interfaces';
|
|
3
|
+
type MessageDataType = string | Uint8Array;
|
|
3
4
|
/**
|
|
4
5
|
* ## Introduction
|
|
5
6
|
*
|
|
@@ -100,7 +101,7 @@ export declare class Encryption {
|
|
|
100
101
|
* const resultMessage = await encription.signAndEncrypt('message', publicKeys);
|
|
101
102
|
* ```
|
|
102
103
|
*/
|
|
103
|
-
signAndEncrypt(message:
|
|
104
|
+
signAndEncrypt(message: MessageDataType, publicKeys: string[]): Promise<string>;
|
|
104
105
|
/**
|
|
105
106
|
* This function decrypts messages using the private key. In addition, the public key can be added for signature verification.
|
|
106
107
|
*
|
|
@@ -132,7 +133,7 @@ export declare class Encryption {
|
|
|
132
133
|
* const resultMessage = await encription.decrypt('message');
|
|
133
134
|
* ```
|
|
134
135
|
*/
|
|
135
|
-
decrypt(message: string, publicKey?: string): Promise<
|
|
136
|
+
decrypt(message: string, publicKey?: string): Promise<Uint8Array>;
|
|
136
137
|
/**
|
|
137
138
|
* This function signs a message using the private key used to initialize the client.
|
|
138
139
|
*
|
|
@@ -294,7 +295,7 @@ export declare class EncryptionUtils {
|
|
|
294
295
|
* const result = await EncriptionUtils.encrypt('message', publicKeys);
|
|
295
296
|
* ```
|
|
296
297
|
*/
|
|
297
|
-
static encrypt(message:
|
|
298
|
+
static encrypt(message: MessageDataType, publicKeys: string[]): Promise<string>;
|
|
298
299
|
/**
|
|
299
300
|
* Verifies if a message appears to be encrypted with OpenPGP.
|
|
300
301
|
*
|
|
@@ -327,4 +328,5 @@ export declare class EncryptionUtils {
|
|
|
327
328
|
*/
|
|
328
329
|
static isEncrypted(message: string): boolean;
|
|
329
330
|
}
|
|
331
|
+
export {};
|
|
330
332
|
//# sourceMappingURL=encryption.d.ts.map
|
package/dist/encryption.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"encryption.d.ts","sourceRoot":"","sources":["../src/encryption.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,SAAS,CAAC;AACnC,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AAExC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuCG;AACH,qBAAa,UAAU;IACrB,OAAO,CAAC,UAAU,CAAqB;IAEvC;;;;OAIG;gBACS,UAAU,EAAE,OAAO,CAAC,UAAU;IAI1C;;;;;;OAMG;WACiB,KAAK,CACvB,iBAAiB,EAAE,MAAM,EACzB,UAAU,CAAC,EAAE,MAAM,GAClB,OAAO,CAAC,UAAU,CAAC;IAkBtB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA2CG;IACU,cAAc,CACzB,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"encryption.d.ts","sourceRoot":"","sources":["../src/encryption.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,SAAS,CAAC;AACnC,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AAExC,KAAK,eAAe,GAAG,MAAM,GAAG,UAAU,CAAC;AAU3C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuCG;AACH,qBAAa,UAAU;IACrB,OAAO,CAAC,UAAU,CAAqB;IAEvC;;;;OAIG;gBACS,UAAU,EAAE,OAAO,CAAC,UAAU;IAI1C;;;;;;OAMG;WACiB,KAAK,CACvB,iBAAiB,EAAE,MAAM,EACzB,UAAU,CAAC,EAAE,MAAM,GAClB,OAAO,CAAC,UAAU,CAAC;IAkBtB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA2CG;IACU,cAAc,CACzB,OAAO,EAAE,eAAe,EACxB,UAAU,EAAE,MAAM,EAAE,GACnB,OAAO,CAAC,MAAM,CAAC;IAkBlB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA8BG;IACU,OAAO,CAClB,OAAO,EAAE,MAAM,EACf,SAAS,CAAC,EAAE,MAAM,GACjB,OAAO,CAAC,UAAU,CAAC;IAoCtB;;;;;;;;;;;;;;;;;OAiBG;IACU,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;CAYpD;AAED;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AACH,qBAAa,eAAe;IAC1B;;;;;;;;;;;;;;;;;;;;;;;;;;OA0BG;WACiB,MAAM,CACxB,OAAO,EAAE,MAAM,EACf,SAAS,EAAE,MAAM,GAChB,OAAO,CAAC,OAAO,CAAC;IAgBnB;;;;;;;;;;;;;OAaG;WACiB,aAAa,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAYnE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA8BG;WACiB,eAAe,CACjC,IAAI,EAAE,MAAM,EACZ,KAAK,EAAE,MAAM,EACb,UAAU,SAAK,GACd,OAAO,CAAC,QAAQ,CAAC;IAkBpB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAuCG;WACiB,OAAO,CACzB,OAAO,EAAE,eAAe,EACxB,UAAU,EAAE,MAAM,EAAE,GACnB,OAAO,CAAC,MAAM,CAAC;IAiBlB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA6BG;WACW,WAAW,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;CASpD"}
|
package/dist/encryption.js
CHANGED
|
@@ -25,6 +25,12 @@ var __importStar = (this && this.__importStar) || function (mod) {
|
|
|
25
25
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
26
|
exports.EncryptionUtils = exports.Encryption = void 0;
|
|
27
27
|
const openpgp = __importStar(require("openpgp"));
|
|
28
|
+
function makeMessageDataBinary(message) {
|
|
29
|
+
if (typeof message === 'string') {
|
|
30
|
+
return Buffer.from(message);
|
|
31
|
+
}
|
|
32
|
+
return message;
|
|
33
|
+
}
|
|
28
34
|
/**
|
|
29
35
|
* ## Introduction
|
|
30
36
|
*
|
|
@@ -139,13 +145,15 @@ class Encryption {
|
|
|
139
145
|
* ```
|
|
140
146
|
*/
|
|
141
147
|
async signAndEncrypt(message, publicKeys) {
|
|
142
|
-
const plaintext = message;
|
|
143
148
|
const pgpPublicKeys = await Promise.all(publicKeys.map((armoredKey) => openpgp.readKey({ armoredKey })));
|
|
144
|
-
const pgpMessage = await openpgp.createMessage({
|
|
149
|
+
const pgpMessage = await openpgp.createMessage({
|
|
150
|
+
binary: makeMessageDataBinary(message),
|
|
151
|
+
});
|
|
145
152
|
const encrypted = await openpgp.encrypt({
|
|
146
153
|
message: pgpMessage,
|
|
147
154
|
encryptionKeys: pgpPublicKeys,
|
|
148
155
|
signingKeys: this.privateKey,
|
|
156
|
+
format: 'armored',
|
|
149
157
|
});
|
|
150
158
|
return encrypted;
|
|
151
159
|
}
|
|
@@ -181,17 +189,33 @@ class Encryption {
|
|
|
181
189
|
* ```
|
|
182
190
|
*/
|
|
183
191
|
async decrypt(message, publicKey) {
|
|
184
|
-
const pgpMessage = await openpgp.readMessage({
|
|
192
|
+
const pgpMessage = await openpgp.readMessage({
|
|
193
|
+
armoredMessage: message,
|
|
194
|
+
});
|
|
185
195
|
const decryptionOptions = {
|
|
186
196
|
message: pgpMessage,
|
|
187
197
|
decryptionKeys: this.privateKey,
|
|
188
|
-
|
|
198
|
+
format: 'binary',
|
|
189
199
|
};
|
|
190
|
-
|
|
200
|
+
const shouldVerifySignature = !!publicKey;
|
|
201
|
+
if (shouldVerifySignature) {
|
|
191
202
|
const pgpPublicKey = await openpgp.readKey({ armoredKey: publicKey });
|
|
192
203
|
decryptionOptions.verificationKeys = pgpPublicKey;
|
|
193
204
|
}
|
|
194
|
-
const { data: decrypted } = await openpgp.decrypt(decryptionOptions);
|
|
205
|
+
const { data: decrypted, signatures } = await openpgp.decrypt(decryptionOptions);
|
|
206
|
+
/**
|
|
207
|
+
* There is an option to automatically verify signatures - `expectSigned`,
|
|
208
|
+
* but atm it has a bug - https://github.com/openpgpjs/openpgpjs/issues/1803,
|
|
209
|
+
* so we have to verify it manually till it's fixed.
|
|
210
|
+
*/
|
|
211
|
+
try {
|
|
212
|
+
if (shouldVerifySignature) {
|
|
213
|
+
await signatures[0].verified;
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
catch {
|
|
217
|
+
throw new Error('Signature could not be verified');
|
|
218
|
+
}
|
|
195
219
|
return decrypted;
|
|
196
220
|
}
|
|
197
221
|
/**
|
|
@@ -404,12 +428,14 @@ class EncryptionUtils {
|
|
|
404
428
|
* ```
|
|
405
429
|
*/
|
|
406
430
|
static async encrypt(message, publicKeys) {
|
|
407
|
-
const plaintext = message;
|
|
408
431
|
const pgpPublicKeys = await Promise.all(publicKeys.map((armoredKey) => openpgp.readKey({ armoredKey })));
|
|
409
|
-
const pgpMessage = await openpgp.createMessage({
|
|
432
|
+
const pgpMessage = await openpgp.createMessage({
|
|
433
|
+
binary: makeMessageDataBinary(message),
|
|
434
|
+
});
|
|
410
435
|
const encrypted = await openpgp.encrypt({
|
|
411
436
|
message: pgpMessage,
|
|
412
437
|
encryptionKeys: pgpPublicKeys,
|
|
438
|
+
format: 'armored',
|
|
413
439
|
});
|
|
414
440
|
return encrypted;
|
|
415
441
|
}
|
package/dist/enums.js
CHANGED
|
@@ -22,9 +22,9 @@ var ChainId;
|
|
|
22
22
|
ChainId[ChainId["XLAYER_TESTNET"] = 195] = "XLAYER_TESTNET";
|
|
23
23
|
ChainId[ChainId["LOCALHOST"] = 1338] = "LOCALHOST";
|
|
24
24
|
ChainId[ChainId["XLAYER"] = 196] = "XLAYER";
|
|
25
|
-
})(ChainId
|
|
25
|
+
})(ChainId || (exports.ChainId = ChainId = {}));
|
|
26
26
|
var OrderDirection;
|
|
27
27
|
(function (OrderDirection) {
|
|
28
28
|
OrderDirection["ASC"] = "asc";
|
|
29
29
|
OrderDirection["DESC"] = "desc";
|
|
30
|
-
})(OrderDirection
|
|
30
|
+
})(OrderDirection || (exports.OrderDirection = OrderDirection = {}));
|
package/dist/escrow.js
CHANGED
|
@@ -1128,6 +1128,7 @@ class EscrowClient extends base_1.BaseEthersClient {
|
|
|
1128
1128
|
}
|
|
1129
1129
|
}
|
|
1130
1130
|
}
|
|
1131
|
+
exports.EscrowClient = EscrowClient;
|
|
1131
1132
|
__decorate([
|
|
1132
1133
|
decorators_1.requiresSigner,
|
|
1133
1134
|
__metadata("design:type", Function),
|
|
@@ -1188,7 +1189,6 @@ __decorate([
|
|
|
1188
1189
|
__metadata("design:paramtypes", [String, Array, Object]),
|
|
1189
1190
|
__metadata("design:returntype", Promise)
|
|
1190
1191
|
], EscrowClient.prototype, "addTrustedHandlers", null);
|
|
1191
|
-
exports.EscrowClient = EscrowClient;
|
|
1192
1192
|
/**
|
|
1193
1193
|
* ## Introduction
|
|
1194
1194
|
*
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"operator.d.ts","sourceRoot":"","sources":["../../../src/graphql/queries/operator.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"operator.d.ts","sourceRoot":"","sources":["../../../src/graphql/queries/operator.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AA0BhD,eAAO,MAAM,iBAAiB,WAAY,cAAc,mCAuBvD,CAAC;AAEF,eAAO,MAAM,4BAA4B,UAAW,MAAM,mCA0BzD,CAAC;AAEF,eAAO,MAAM,gBAAgB,gCAO5B,CAAC"}
|
|
@@ -24,6 +24,8 @@ const LEADER_FRAGMENT = (0, graphql_tag_1.default) `
|
|
|
24
24
|
webhookUrl
|
|
25
25
|
url
|
|
26
26
|
jobTypes
|
|
27
|
+
registrationNeeded
|
|
28
|
+
registrationInstructions
|
|
27
29
|
}
|
|
28
30
|
`;
|
|
29
31
|
const GET_LEADERS_QUERY = (filter) => {
|
|
@@ -67,7 +69,9 @@ const GET_REPUTATION_NETWORK_QUERY = (role) => {
|
|
|
67
69
|
address,
|
|
68
70
|
role,
|
|
69
71
|
url,
|
|
70
|
-
jobTypes
|
|
72
|
+
jobTypes,
|
|
73
|
+
registrationNeeded,
|
|
74
|
+
registrationInstructions
|
|
71
75
|
}
|
|
72
76
|
}
|
|
73
77
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../../src/graphql/queries/transaction.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAc9D,eAAO,MAAM,sBAAsB,WAAY,mBAAmB,
|
|
1
|
+
{"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../../src/graphql/queries/transaction.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAc9D,eAAO,MAAM,sBAAsB,WAAY,mBAAmB,mCAqDjE,CAAC;AAEF,eAAO,MAAM,qBAAqB,gCAOjC,CAAC"}
|
|
@@ -29,7 +29,9 @@ const GET_TRANSACTIONS_QUERY = (filter) => {
|
|
|
29
29
|
`;
|
|
30
30
|
const WHERE_CLAUSE = `
|
|
31
31
|
where: {
|
|
32
|
-
${fromAddress === toAddress
|
|
32
|
+
${fromAddress === toAddress
|
|
33
|
+
? `or: [ ${addressCondition} ],`
|
|
34
|
+
: addressCondition}
|
|
33
35
|
${startDate ? `timestamp_gte: $startDate,` : ''}
|
|
34
36
|
${endDate ? `timestamp_lte: $endDate,` : ''}
|
|
35
37
|
${startBlock ? `block_gte: $startBlock,` : ''}
|
package/dist/interfaces.d.ts
CHANGED
|
@@ -30,6 +30,8 @@ export interface ILeader {
|
|
|
30
30
|
webhookUrl?: string;
|
|
31
31
|
url?: string;
|
|
32
32
|
jobTypes?: string[];
|
|
33
|
+
registrationNeeded?: boolean;
|
|
34
|
+
registrationInstructions?: string;
|
|
33
35
|
}
|
|
34
36
|
export interface ILeaderSubgraph extends Omit<ILeader, 'jobTypes'> {
|
|
35
37
|
jobTypes?: string;
|
|
@@ -51,6 +53,8 @@ export interface IOperator {
|
|
|
51
53
|
role?: string;
|
|
52
54
|
url?: string;
|
|
53
55
|
jobTypes?: string[];
|
|
56
|
+
registrationNeeded?: boolean;
|
|
57
|
+
registrationInstructions?: string;
|
|
54
58
|
}
|
|
55
59
|
export interface IOperatorSubgraph extends Omit<IOperator, 'jobTypes'> {
|
|
56
60
|
jobTypes?: string;
|
package/dist/interfaces.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"interfaces.d.ts","sourceRoot":"","sources":["../src/interfaces.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACvC,OAAO,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAElD,MAAM,WAAW,WAAW;IAC1B,aAAa,EAAE,MAAM,CAAC;IACtB,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,OAAO;IACtB,aAAa,EAAE,MAAM,CAAC;IACtB,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,OAAO;IACtB,EAAE,EAAE,MAAM,CAAC;IACX,OAAO,EAAE,OAAO,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,YAAY,EAAE,MAAM,CAAC;IACrB,eAAe,EAAE,MAAM,CAAC;IACxB,YAAY,EAAE,MAAM,CAAC;IACrB,oBAAoB,EAAE,MAAM,CAAC;IAC7B,eAAe,EAAE,MAAM,CAAC;IACxB,aAAa,EAAE,MAAM,CAAC;IACtB,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE,MAAM,CAAC;IACf,mBAAmB,EAAE,MAAM,CAAC;IAC5B,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"interfaces.d.ts","sourceRoot":"","sources":["../src/interfaces.ts"],"names":[],"mappings":"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"}
|
package/dist/kvstore.js
CHANGED
|
@@ -245,6 +245,7 @@ class KVStoreClient extends base_1.BaseEthersClient {
|
|
|
245
245
|
}
|
|
246
246
|
}
|
|
247
247
|
}
|
|
248
|
+
exports.KVStoreClient = KVStoreClient;
|
|
248
249
|
__decorate([
|
|
249
250
|
decorators_1.requiresSigner,
|
|
250
251
|
__metadata("design:type", Function),
|
|
@@ -263,7 +264,6 @@ __decorate([
|
|
|
263
264
|
__metadata("design:paramtypes", [String, Object, Object]),
|
|
264
265
|
__metadata("design:returntype", Promise)
|
|
265
266
|
], KVStoreClient.prototype, "setFileUrlAndHash", null);
|
|
266
|
-
exports.KVStoreClient = KVStoreClient;
|
|
267
267
|
/**
|
|
268
268
|
* ## Introduction
|
|
269
269
|
*
|
package/dist/staking.js
CHANGED
|
@@ -493,6 +493,7 @@ class StakingClient extends base_1.BaseEthersClient {
|
|
|
493
493
|
}
|
|
494
494
|
}
|
|
495
495
|
}
|
|
496
|
+
exports.StakingClient = StakingClient;
|
|
496
497
|
__decorate([
|
|
497
498
|
decorators_1.requiresSigner,
|
|
498
499
|
__metadata("design:type", Function),
|
|
@@ -541,4 +542,3 @@ __decorate([
|
|
|
541
542
|
__metadata("design:paramtypes", [String, Object]),
|
|
542
543
|
__metadata("design:returntype", Promise)
|
|
543
544
|
], StakingClient.prototype, "distributeReward", null);
|
|
544
|
-
exports.StakingClient = StakingClient;
|
package/dist/types.js
CHANGED
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@human-protocol/sdk",
|
|
3
3
|
"description": "Human Protocol SDK",
|
|
4
|
-
"version": "3.0.
|
|
4
|
+
"version": "3.0.7",
|
|
5
5
|
"files": [
|
|
6
6
|
"src",
|
|
7
7
|
"dist"
|
|
@@ -45,7 +45,7 @@
|
|
|
45
45
|
"graphql-request": "^6.1.0",
|
|
46
46
|
"graphql-tag": "^2.12.6",
|
|
47
47
|
"minio": "7.1.3",
|
|
48
|
-
"openpgp": "^5.11.
|
|
48
|
+
"openpgp": "^5.11.2",
|
|
49
49
|
"secp256k1": "^4.0.3",
|
|
50
50
|
"vitest": "^1.6.0"
|
|
51
51
|
},
|
package/src/constants.ts
CHANGED
|
@@ -63,7 +63,7 @@ export const NETWORKS: {
|
|
|
63
63
|
subgraphUrl:
|
|
64
64
|
'https://api.studio.thegraph.com/query/74256/ethereum/version/latest',
|
|
65
65
|
subgraphUrlApiKey:
|
|
66
|
-
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
66
|
+
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/QmaTcYR8NCzZuxwY7tBkMJAo1Q64BMqNNSzqjxd7FH9s2p',
|
|
67
67
|
oldSubgraphUrl: '',
|
|
68
68
|
oldFactoryAddress: '',
|
|
69
69
|
},
|
|
@@ -109,7 +109,7 @@ export const NETWORKS: {
|
|
|
109
109
|
subgraphUrl:
|
|
110
110
|
'https://api.studio.thegraph.com/query/74256/sepolia/version/latest',
|
|
111
111
|
subgraphUrlApiKey:
|
|
112
|
-
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
112
|
+
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/QmadNQBBzcfJHTmzLezZGbwvLux7HmnmfByBHubS2cmLUr',
|
|
113
113
|
oldSubgraphUrl: '',
|
|
114
114
|
oldFactoryAddress: '',
|
|
115
115
|
},
|
|
@@ -125,7 +125,7 @@ export const NETWORKS: {
|
|
|
125
125
|
subgraphUrl:
|
|
126
126
|
'https://api.studio.thegraph.com/query/74256/bsc/version/latest',
|
|
127
127
|
subgraphUrlApiKey:
|
|
128
|
-
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
128
|
+
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/QmXZ4QJMi8kyfXDEJwtdizyKf5JdJui89iYCLCE79N8Xf5',
|
|
129
129
|
oldSubgraphUrl: 'https://api.thegraph.com/subgraphs/name/humanprotocol/bsc',
|
|
130
130
|
oldFactoryAddress: '0xc88bC422cAAb2ac8812de03176402dbcA09533f4',
|
|
131
131
|
},
|
|
@@ -141,7 +141,7 @@ export const NETWORKS: {
|
|
|
141
141
|
subgraphUrl:
|
|
142
142
|
'https://api.studio.thegraph.com/query/74256/bsc-testnet/version/latest',
|
|
143
143
|
subgraphUrlApiKey:
|
|
144
|
-
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
144
|
+
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/Qmdq449rn4WKDf7NLvRZgt7CedZRrvpDzPqcvSmhvuu16D',
|
|
145
145
|
oldSubgraphUrl:
|
|
146
146
|
'https://api.thegraph.com/subgraphs/name/humanprotocol/bsctest',
|
|
147
147
|
oldFactoryAddress: '0xaae6a2646c1f88763e62e0cd08ad050ea66ac46f',
|
|
@@ -158,7 +158,7 @@ export const NETWORKS: {
|
|
|
158
158
|
subgraphUrl:
|
|
159
159
|
'https://api.studio.thegraph.com/query/74256/polygon/version/latest',
|
|
160
160
|
subgraphUrlApiKey:
|
|
161
|
-
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
161
|
+
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/QmNdsofT4Cj2KRwr8vgyKgCWpZNmrMN41zUdygRz7eSGC9',
|
|
162
162
|
oldSubgraphUrl:
|
|
163
163
|
'https://api.thegraph.com/subgraphs/name/humanprotocol/polygon',
|
|
164
164
|
oldFactoryAddress: '0x45eBc3eAE6DA485097054ae10BA1A0f8e8c7f794',
|
|
@@ -191,7 +191,7 @@ export const NETWORKS: {
|
|
|
191
191
|
subgraphUrl:
|
|
192
192
|
'https://api.studio.thegraph.com/query/74256/amoy/version/latest',
|
|
193
193
|
subgraphUrlApiKey:
|
|
194
|
-
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
194
|
+
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/Qmbwio5UnvDn5GQRJ5kLJfK27fqHK9nkEh4YXXYKWCc9rH',
|
|
195
195
|
oldSubgraphUrl: '',
|
|
196
196
|
oldFactoryAddress: '',
|
|
197
197
|
},
|
|
@@ -207,7 +207,7 @@ export const NETWORKS: {
|
|
|
207
207
|
subgraphUrl:
|
|
208
208
|
'https://api.studio.thegraph.com/query/74256/moonbeam/version/latest',
|
|
209
209
|
subgraphUrlApiKey:
|
|
210
|
-
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
210
|
+
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/QmYe9hsFYuVgQsH719AsqRNqgVM8YBYfCuhBNYjXtBqQru',
|
|
211
211
|
oldSubgraphUrl:
|
|
212
212
|
'https://api.thegraph.com/subgraphs/name/humanprotocol/moonbeam',
|
|
213
213
|
oldFactoryAddress: '0x98108c28B7767a52BE38B4860832dd4e11A7ecad',
|
|
@@ -224,7 +224,7 @@ export const NETWORKS: {
|
|
|
224
224
|
subgraphUrl:
|
|
225
225
|
'https://api.studio.thegraph.com/query/74256/moonbase-alpha/version/latest',
|
|
226
226
|
subgraphUrlApiKey:
|
|
227
|
-
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
227
|
+
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/QmeC4JrotcrXWJtJU519RX3KkxE5879wveRJJ58EheH3j1',
|
|
228
228
|
oldSubgraphUrl: '',
|
|
229
229
|
oldFactoryAddress: '',
|
|
230
230
|
},
|
|
@@ -240,7 +240,7 @@ export const NETWORKS: {
|
|
|
240
240
|
subgraphUrl:
|
|
241
241
|
'https://api.studio.thegraph.com/query/74256/fuji/version/latest',
|
|
242
242
|
subgraphUrlApiKey:
|
|
243
|
-
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
243
|
+
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/QmcFhecY6w3AhKGSg8XeidXwwuXCV9DAQ5SYGE1sTzydgR',
|
|
244
244
|
oldSubgraphUrl:
|
|
245
245
|
'https://api.thegraph.com/subgraphs/name/humanprotocol/fuji',
|
|
246
246
|
oldFactoryAddress: '0xfb4469201951C3B9a7F1996c477cb7BDBEcE0A88',
|
|
@@ -257,7 +257,7 @@ export const NETWORKS: {
|
|
|
257
257
|
subgraphUrl:
|
|
258
258
|
'https://api.studio.thegraph.com/query/74256/avalanche/version/latest',
|
|
259
259
|
subgraphUrlApiKey:
|
|
260
|
-
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
260
|
+
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/QmYR8NUuAQVoGmGSwKanUJLjX9iZxrEyGH39HjUuXLmsum',
|
|
261
261
|
oldSubgraphUrl:
|
|
262
262
|
'https://api.thegraph.com/subgraphs/name/humanprotocol/avalanche',
|
|
263
263
|
oldFactoryAddress: '0x9767a578ba7a5FA1563c8229943cB01cd8446BB4',
|
|
@@ -274,7 +274,7 @@ export const NETWORKS: {
|
|
|
274
274
|
subgraphUrl:
|
|
275
275
|
'https://api.studio.thegraph.com/query/74256/celo-alfajores/version/latest',
|
|
276
276
|
subgraphUrlApiKey:
|
|
277
|
-
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
277
|
+
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/Qmb2WKCFFhT7REAjTuMd9pZvGw7rRpzeZSPJ3KRztD2pMM',
|
|
278
278
|
oldSubgraphUrl: '',
|
|
279
279
|
oldFactoryAddress: '',
|
|
280
280
|
},
|
|
@@ -290,7 +290,7 @@ export const NETWORKS: {
|
|
|
290
290
|
subgraphUrl:
|
|
291
291
|
'https://api.studio.thegraph.com/query/74256/celo/version/latest',
|
|
292
292
|
subgraphUrlApiKey:
|
|
293
|
-
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
293
|
+
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/Qmeeb5zshw1z9Q38NNPun2Pd7P951Mkzz5ywK171tauNRY',
|
|
294
294
|
oldSubgraphUrl: '',
|
|
295
295
|
oldFactoryAddress: '',
|
|
296
296
|
},
|
|
@@ -306,7 +306,7 @@ export const NETWORKS: {
|
|
|
306
306
|
subgraphUrl:
|
|
307
307
|
'https://api.studio.thegraph.com/query/74256/xlayer/version/latest',
|
|
308
308
|
subgraphUrlApiKey:
|
|
309
|
-
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
309
|
+
'https://gateway-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/QmWTggMrB5sRSs2fePuqQG9WbLMk8HtnfLH3VbRhmVdF8s',
|
|
310
310
|
oldSubgraphUrl: '',
|
|
311
311
|
oldFactoryAddress: '',
|
|
312
312
|
},
|
|
@@ -322,7 +322,7 @@ export const NETWORKS: {
|
|
|
322
322
|
subgraphUrl:
|
|
323
323
|
'https://api.studio.thegraph.com/query/74256/xlayer-testnet/version/latest',
|
|
324
324
|
subgraphUrlApiKey:
|
|
325
|
-
'https://gateway-testnet-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/
|
|
325
|
+
'https://gateway-testnet-arbitrum.network.thegraph.com/api/[SUBGRAPH_API_KEY]/deployments/id/QmQrTmq89ZCdVABsFpLHtQUWuyyVzbcARoan9eztHd21oP',
|
|
326
326
|
oldSubgraphUrl: '',
|
|
327
327
|
oldFactoryAddress: '',
|
|
328
328
|
},
|
|
@@ -350,6 +350,7 @@ export const KVStoreKeys = {
|
|
|
350
350
|
url: 'url',
|
|
351
351
|
jobTypes: 'job_types',
|
|
352
352
|
registrationNeeded: 'registration_needed',
|
|
353
|
+
registrationInstructions: 'registration_instructions',
|
|
353
354
|
};
|
|
354
355
|
|
|
355
356
|
export const Role = {
|
package/src/encryption.ts
CHANGED
|
@@ -1,6 +1,16 @@
|
|
|
1
1
|
import * as openpgp from 'openpgp';
|
|
2
2
|
import { IKeyPair } from './interfaces';
|
|
3
3
|
|
|
4
|
+
type MessageDataType = string | Uint8Array;
|
|
5
|
+
|
|
6
|
+
function makeMessageDataBinary(message: MessageDataType): Uint8Array {
|
|
7
|
+
if (typeof message === 'string') {
|
|
8
|
+
return Buffer.from(message);
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
return message;
|
|
12
|
+
}
|
|
13
|
+
|
|
4
14
|
/**
|
|
5
15
|
* ## Introduction
|
|
6
16
|
*
|
|
@@ -126,20 +136,21 @@ export class Encryption {
|
|
|
126
136
|
* ```
|
|
127
137
|
*/
|
|
128
138
|
public async signAndEncrypt(
|
|
129
|
-
message:
|
|
139
|
+
message: MessageDataType,
|
|
130
140
|
publicKeys: string[]
|
|
131
141
|
): Promise<string> {
|
|
132
|
-
const plaintext = message;
|
|
133
|
-
|
|
134
142
|
const pgpPublicKeys = await Promise.all(
|
|
135
143
|
publicKeys.map((armoredKey) => openpgp.readKey({ armoredKey }))
|
|
136
144
|
);
|
|
137
145
|
|
|
138
|
-
const pgpMessage = await openpgp.createMessage({
|
|
146
|
+
const pgpMessage = await openpgp.createMessage({
|
|
147
|
+
binary: makeMessageDataBinary(message),
|
|
148
|
+
});
|
|
139
149
|
const encrypted = await openpgp.encrypt({
|
|
140
150
|
message: pgpMessage,
|
|
141
151
|
encryptionKeys: pgpPublicKeys,
|
|
142
152
|
signingKeys: this.privateKey,
|
|
153
|
+
format: 'armored',
|
|
143
154
|
});
|
|
144
155
|
|
|
145
156
|
return encrypted as string;
|
|
@@ -176,23 +187,43 @@ export class Encryption {
|
|
|
176
187
|
* const resultMessage = await encription.decrypt('message');
|
|
177
188
|
* ```
|
|
178
189
|
*/
|
|
179
|
-
public async decrypt(
|
|
180
|
-
|
|
190
|
+
public async decrypt(
|
|
191
|
+
message: string,
|
|
192
|
+
publicKey?: string
|
|
193
|
+
): Promise<Uint8Array> {
|
|
194
|
+
const pgpMessage = await openpgp.readMessage({
|
|
195
|
+
armoredMessage: message,
|
|
196
|
+
});
|
|
181
197
|
|
|
182
198
|
const decryptionOptions: openpgp.DecryptOptions = {
|
|
183
199
|
message: pgpMessage,
|
|
184
200
|
decryptionKeys: this.privateKey,
|
|
185
|
-
|
|
201
|
+
format: 'binary',
|
|
186
202
|
};
|
|
187
203
|
|
|
188
|
-
|
|
204
|
+
const shouldVerifySignature = !!publicKey;
|
|
205
|
+
if (shouldVerifySignature) {
|
|
189
206
|
const pgpPublicKey = await openpgp.readKey({ armoredKey: publicKey });
|
|
190
207
|
decryptionOptions.verificationKeys = pgpPublicKey;
|
|
191
208
|
}
|
|
192
209
|
|
|
193
|
-
const { data: decrypted } =
|
|
210
|
+
const { data: decrypted, signatures } =
|
|
211
|
+
await openpgp.decrypt(decryptionOptions);
|
|
212
|
+
|
|
213
|
+
/**
|
|
214
|
+
* There is an option to automatically verify signatures - `expectSigned`,
|
|
215
|
+
* but atm it has a bug - https://github.com/openpgpjs/openpgpjs/issues/1803,
|
|
216
|
+
* so we have to verify it manually till it's fixed.
|
|
217
|
+
*/
|
|
218
|
+
try {
|
|
219
|
+
if (shouldVerifySignature) {
|
|
220
|
+
await signatures[0].verified;
|
|
221
|
+
}
|
|
222
|
+
} catch {
|
|
223
|
+
throw new Error('Signature could not be verified');
|
|
224
|
+
}
|
|
194
225
|
|
|
195
|
-
return decrypted as
|
|
226
|
+
return decrypted as Uint8Array;
|
|
196
227
|
}
|
|
197
228
|
|
|
198
229
|
/**
|
|
@@ -419,19 +450,20 @@ export class EncryptionUtils {
|
|
|
419
450
|
* ```
|
|
420
451
|
*/
|
|
421
452
|
public static async encrypt(
|
|
422
|
-
message:
|
|
453
|
+
message: MessageDataType,
|
|
423
454
|
publicKeys: string[]
|
|
424
455
|
): Promise<string> {
|
|
425
|
-
const plaintext = message;
|
|
426
|
-
|
|
427
456
|
const pgpPublicKeys = await Promise.all(
|
|
428
457
|
publicKeys.map((armoredKey) => openpgp.readKey({ armoredKey }))
|
|
429
458
|
);
|
|
430
459
|
|
|
431
|
-
const pgpMessage = await openpgp.createMessage({
|
|
460
|
+
const pgpMessage = await openpgp.createMessage({
|
|
461
|
+
binary: makeMessageDataBinary(message),
|
|
462
|
+
});
|
|
432
463
|
const encrypted = await openpgp.encrypt({
|
|
433
464
|
message: pgpMessage,
|
|
434
465
|
encryptionKeys: pgpPublicKeys,
|
|
466
|
+
format: 'armored',
|
|
435
467
|
});
|
|
436
468
|
|
|
437
469
|
return encrypted as string;
|
|
@@ -20,6 +20,8 @@ const LEADER_FRAGMENT = gql`
|
|
|
20
20
|
webhookUrl
|
|
21
21
|
url
|
|
22
22
|
jobTypes
|
|
23
|
+
registrationNeeded
|
|
24
|
+
registrationInstructions
|
|
23
25
|
}
|
|
24
26
|
`;
|
|
25
27
|
|
|
@@ -67,7 +69,9 @@ export const GET_REPUTATION_NETWORK_QUERY = (role?: string) => {
|
|
|
67
69
|
address,
|
|
68
70
|
role,
|
|
69
71
|
url,
|
|
70
|
-
jobTypes
|
|
72
|
+
jobTypes,
|
|
73
|
+
registrationNeeded,
|
|
74
|
+
registrationInstructions
|
|
71
75
|
}
|
|
72
76
|
}
|
|
73
77
|
}
|
|
@@ -30,7 +30,11 @@ export const GET_TRANSACTIONS_QUERY = (filter: ITransactionsFilter) => {
|
|
|
30
30
|
|
|
31
31
|
const WHERE_CLAUSE = `
|
|
32
32
|
where: {
|
|
33
|
-
${
|
|
33
|
+
${
|
|
34
|
+
fromAddress === toAddress
|
|
35
|
+
? `or: [ ${addressCondition} ],`
|
|
36
|
+
: addressCondition
|
|
37
|
+
}
|
|
34
38
|
${startDate ? `timestamp_gte: $startDate,` : ''}
|
|
35
39
|
${endDate ? `timestamp_lte: $endDate,` : ''}
|
|
36
40
|
${startBlock ? `block_gte: $startBlock,` : ''}
|
package/src/interfaces.ts
CHANGED
|
@@ -33,6 +33,8 @@ export interface ILeader {
|
|
|
33
33
|
webhookUrl?: string;
|
|
34
34
|
url?: string;
|
|
35
35
|
jobTypes?: string[];
|
|
36
|
+
registrationNeeded?: boolean;
|
|
37
|
+
registrationInstructions?: string;
|
|
36
38
|
}
|
|
37
39
|
|
|
38
40
|
export interface ILeaderSubgraph extends Omit<ILeader, 'jobTypes'> {
|
|
@@ -60,6 +62,8 @@ export interface IOperator {
|
|
|
60
62
|
role?: string;
|
|
61
63
|
url?: string;
|
|
62
64
|
jobTypes?: string[];
|
|
65
|
+
registrationNeeded?: boolean;
|
|
66
|
+
registrationInstructions?: string;
|
|
63
67
|
}
|
|
64
68
|
|
|
65
69
|
export interface IOperatorSubgraph extends Omit<IOperator, 'jobTypes'> {
|