@getpara/server-sdk 1.2.0 → 1.3.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/dist/cjs/index.js +1 -21
- package/dist/cjs/index.js.br +0 -0
- package/dist/cjs/index.js.gz +0 -0
- package/dist/cjs/workers/worker.js +2 -154
- package/dist/cjs/workers/worker.js.br +0 -0
- package/dist/cjs/workers/worker.js.gz +0 -0
- package/dist/esm/index.js +1 -4
- package/dist/esm/index.js.br +0 -0
- package/dist/esm/index.js.gz +0 -0
- package/dist/esm/workers/chunk-NEJSZOZX.js +1 -0
- package/dist/esm/workers/chunk-NEJSZOZX.js.br +0 -0
- package/dist/esm/workers/chunk-NEJSZOZX.js.gz +0 -0
- package/dist/esm/workers/wasm_exec-TBSO5IWG.js +2 -0
- package/dist/esm/workers/wasm_exec-TBSO5IWG.js.br +0 -0
- package/dist/esm/workers/wasm_exec-TBSO5IWG.js.gz +0 -0
- package/dist/esm/workers/worker.js +1 -124
- package/dist/esm/workers/worker.js.br +0 -0
- package/dist/esm/workers/worker.js.gz +0 -0
- package/package.json +6 -5
- package/dist/cjs/ParaServer.d.ts +0 -4
- package/dist/cjs/ParaServer.js +0 -14
- package/dist/cjs/ServerLocalStorage.d.ts +0 -12
- package/dist/cjs/ServerLocalStorage.js +0 -30
- package/dist/cjs/ServerSessionStorage.d.ts +0 -12
- package/dist/cjs/ServerSessionStorage.js +0 -30
- package/dist/cjs/ServerUtils.d.ts +0 -43
- package/dist/cjs/ServerUtils.js +0 -55
- package/dist/cjs/index.d.ts +0 -5
- package/dist/cjs/package.json +0 -1
- package/dist/cjs/wallet/keygen.d.ts +0 -22
- package/dist/cjs/wallet/keygen.js +0 -172
- package/dist/cjs/wallet/privateKey.d.ts +0 -2
- package/dist/cjs/wallet/privateKey.js +0 -62
- package/dist/cjs/wallet/signing.d.ts +0 -5
- package/dist/cjs/wallet/signing.js +0 -133
- package/dist/cjs/wasm/wasm_exec.d.ts +0 -1
- package/dist/cjs/wasm/wasm_exec.js +0 -521
- package/dist/cjs/workers/walletUtils.d.ts +0 -25
- package/dist/cjs/workers/walletUtils.js +0 -247
- package/dist/cjs/workers/worker.d.ts +0 -18
- package/dist/cjs/workers/workerWrapper.d.ts +0 -4
- package/dist/cjs/workers/workerWrapper.js +0 -55
- package/dist/esm/ParaServer.d.ts +0 -4
- package/dist/esm/ParaServer.js +0 -7
- package/dist/esm/ServerLocalStorage.d.ts +0 -12
- package/dist/esm/ServerLocalStorage.js +0 -26
- package/dist/esm/ServerSessionStorage.d.ts +0 -12
- package/dist/esm/ServerSessionStorage.js +0 -26
- package/dist/esm/ServerUtils.d.ts +0 -43
- package/dist/esm/ServerUtils.js +0 -51
- package/dist/esm/index.d.ts +0 -5
- package/dist/esm/package.json +0 -1
- package/dist/esm/wallet/keygen.d.ts +0 -22
- package/dist/esm/wallet/keygen.js +0 -142
- package/dist/esm/wallet/privateKey.d.ts +0 -2
- package/dist/esm/wallet/privateKey.js +0 -35
- package/dist/esm/wallet/signing.d.ts +0 -5
- package/dist/esm/wallet/signing.js +0 -103
- package/dist/esm/wasm/wasm_exec.d.ts +0 -1
- package/dist/esm/wasm/wasm_exec.js +0 -521
- package/dist/esm/workers/walletUtils.d.ts +0 -25
- package/dist/esm/workers/walletUtils.js +0 -234
- package/dist/esm/workers/worker.d.ts +0 -18
- package/dist/esm/workers/workerWrapper.d.ts +0 -4
- package/dist/esm/workers/workerWrapper.js +0 -51
|
@@ -1,234 +0,0 @@
|
|
|
1
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
-
});
|
|
9
|
-
};
|
|
10
|
-
import { getBaseMPCNetworkUrl, WalletScheme, WalletType } from '@getpara/core-sdk';
|
|
11
|
-
const configCGGMPBase = (serverUrl, walletId, id) => `{"ServerUrl":"${serverUrl}", "WalletId": "${walletId}", "Id":"${id}", "Ids":["USER","CAPSULE"], "Threshold":1}`;
|
|
12
|
-
const configDKLSBase = (walletId, id, disableWebSockets) => `{"walletId": "${walletId}", "id":"${id}", "otherId":"CAPSULE", "isReceiver": false, "disableWebSockets": ${disableWebSockets}}`;
|
|
13
|
-
function keygenRequest(ctx, userId, walletId, protocolId) {
|
|
14
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
15
|
-
const { data } = yield ctx.mpcComputationClient.post('/wallets', {
|
|
16
|
-
userId,
|
|
17
|
-
walletId,
|
|
18
|
-
protocolId,
|
|
19
|
-
});
|
|
20
|
-
return data;
|
|
21
|
-
});
|
|
22
|
-
}
|
|
23
|
-
function signMessageRequest(ctx, userId, walletId, protocolId, message, signer) {
|
|
24
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
25
|
-
const { data } = yield ctx.mpcComputationClient.post(`/wallets/${walletId}/messages/sign`, {
|
|
26
|
-
userId,
|
|
27
|
-
protocolId,
|
|
28
|
-
message,
|
|
29
|
-
signer,
|
|
30
|
-
});
|
|
31
|
-
return data;
|
|
32
|
-
});
|
|
33
|
-
}
|
|
34
|
-
function sendTransactionRequest(ctx, userId, walletId, protocolId, transaction, signer, chainId) {
|
|
35
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
36
|
-
const { data } = yield ctx.mpcComputationClient.post(`/wallets/${walletId}/transactions/send`, {
|
|
37
|
-
userId,
|
|
38
|
-
protocolId,
|
|
39
|
-
transaction,
|
|
40
|
-
signer,
|
|
41
|
-
chainId,
|
|
42
|
-
});
|
|
43
|
-
return data;
|
|
44
|
-
});
|
|
45
|
-
}
|
|
46
|
-
export function ed25519Keygen(ctx, userId) {
|
|
47
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
48
|
-
const { walletId, protocolId } = yield ctx.client.createWallet(userId, {
|
|
49
|
-
scheme: WalletScheme.ED25519,
|
|
50
|
-
type: WalletType.SOLANA,
|
|
51
|
-
});
|
|
52
|
-
const serverUrl = getBaseMPCNetworkUrl(ctx.env, !ctx.disableWebSockets);
|
|
53
|
-
const newSigner = (yield new Promise((resolve, reject) => global.ed25519CreateAccount(serverUrl, walletId, protocolId, (err, result) => {
|
|
54
|
-
if (err) {
|
|
55
|
-
reject(err);
|
|
56
|
-
}
|
|
57
|
-
resolve(result);
|
|
58
|
-
})));
|
|
59
|
-
return { signer: newSigner, walletId };
|
|
60
|
-
});
|
|
61
|
-
}
|
|
62
|
-
export function ed25519PreKeygen(ctx, pregenIdentifier, pregenIdentifierType) {
|
|
63
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
64
|
-
const { walletId, protocolId } = yield ctx.client.createPregenWallet({
|
|
65
|
-
pregenIdentifier,
|
|
66
|
-
pregenIdentifierType,
|
|
67
|
-
scheme: WalletScheme.ED25519,
|
|
68
|
-
type: WalletType.SOLANA,
|
|
69
|
-
});
|
|
70
|
-
const serverUrl = getBaseMPCNetworkUrl(ctx.env, !ctx.disableWebSockets);
|
|
71
|
-
const newSigner = (yield new Promise((resolve, reject) => global.ed25519CreateAccount(serverUrl, walletId, protocolId, (err, result) => {
|
|
72
|
-
if (err) {
|
|
73
|
-
reject(err);
|
|
74
|
-
}
|
|
75
|
-
resolve(result);
|
|
76
|
-
})));
|
|
77
|
-
return { signer: newSigner, walletId };
|
|
78
|
-
});
|
|
79
|
-
}
|
|
80
|
-
export function ed25519Sign(ctx, share, userId, walletId, base64Bytes) {
|
|
81
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
82
|
-
const { protocolId } = yield ctx.client.preSignMessage(userId, walletId, base64Bytes, WalletScheme.ED25519);
|
|
83
|
-
const base64Sig = (yield new Promise((resolve, reject) => global.ed25519Sign(share, protocolId, base64Bytes, (err, result) => {
|
|
84
|
-
if (err) {
|
|
85
|
-
reject(err);
|
|
86
|
-
}
|
|
87
|
-
resolve(result);
|
|
88
|
-
})));
|
|
89
|
-
return { signature: base64Sig };
|
|
90
|
-
});
|
|
91
|
-
}
|
|
92
|
-
export function keygen(ctx, userId, type, secretKey) {
|
|
93
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
94
|
-
const { walletId, protocolId } = yield ctx.client.createWallet(userId, {
|
|
95
|
-
useTwoSigners: true,
|
|
96
|
-
scheme: ctx.useDKLS ? WalletScheme.DKLS : WalletScheme.CGGMP,
|
|
97
|
-
type,
|
|
98
|
-
cosmosPrefix: type === WalletType.COSMOS ? ctx.cosmosPrefix : undefined,
|
|
99
|
-
});
|
|
100
|
-
if (ctx.offloadMPCComputationURL && !ctx.useDKLS) {
|
|
101
|
-
return {
|
|
102
|
-
signer: (yield keygenRequest(ctx, userId, walletId, protocolId)).signer,
|
|
103
|
-
walletId,
|
|
104
|
-
};
|
|
105
|
-
}
|
|
106
|
-
const serverUrl = getBaseMPCNetworkUrl(ctx.env, !ctx.disableWebSockets);
|
|
107
|
-
const signerConfigUser = ctx.useDKLS
|
|
108
|
-
? configDKLSBase(walletId, 'USER', ctx.disableWebSockets)
|
|
109
|
-
: configCGGMPBase(serverUrl, walletId, 'USER');
|
|
110
|
-
const createAccountFn = ctx.useDKLS ? global.dklsCreateAccount : global.createAccountV2;
|
|
111
|
-
const newSigner = (yield new Promise((resolve, reject) => createAccountFn(signerConfigUser, serverUrl, protocolId, secretKey, () => { }, // no-op for deprecated callback to update progress percentage
|
|
112
|
-
(err, result) => {
|
|
113
|
-
if (err) {
|
|
114
|
-
reject(err);
|
|
115
|
-
}
|
|
116
|
-
resolve(result);
|
|
117
|
-
})));
|
|
118
|
-
return { signer: newSigner, walletId };
|
|
119
|
-
});
|
|
120
|
-
}
|
|
121
|
-
export function preKeygen(ctx, partnerId, pregenIdentifier, pregenIdentifierType, type, secretKey) {
|
|
122
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
123
|
-
const { walletId, protocolId } = yield ctx.client.createPregenWallet({
|
|
124
|
-
pregenIdentifier,
|
|
125
|
-
pregenIdentifierType,
|
|
126
|
-
type,
|
|
127
|
-
cosmosPrefix: type === WalletType.COSMOS ? ctx.cosmosPrefix : undefined,
|
|
128
|
-
});
|
|
129
|
-
if (ctx.offloadMPCComputationURL && !ctx.useDKLS) {
|
|
130
|
-
return {
|
|
131
|
-
signer: (yield keygenRequest(ctx, partnerId, walletId, protocolId)).signer,
|
|
132
|
-
walletId,
|
|
133
|
-
};
|
|
134
|
-
}
|
|
135
|
-
const serverUrl = getBaseMPCNetworkUrl(ctx.env, !ctx.disableWebSockets);
|
|
136
|
-
const signerConfigUser = ctx.useDKLS
|
|
137
|
-
? configDKLSBase(walletId, 'USER', ctx.disableWebSockets)
|
|
138
|
-
: configCGGMPBase(serverUrl, walletId, 'USER');
|
|
139
|
-
const createAccountFn = ctx.useDKLS ? global.dklsCreateAccount : global.createAccountV2;
|
|
140
|
-
const newSigner = (yield new Promise((resolve, reject) => createAccountFn(signerConfigUser, serverUrl, protocolId, secretKey, () => { }, // no-op for deprecated callback to update progress percentage
|
|
141
|
-
(err, result) => {
|
|
142
|
-
if (err) {
|
|
143
|
-
reject(err);
|
|
144
|
-
}
|
|
145
|
-
resolve(result);
|
|
146
|
-
})));
|
|
147
|
-
return { signer: newSigner, walletId };
|
|
148
|
-
});
|
|
149
|
-
}
|
|
150
|
-
export function signMessage(ctx, share, walletId, userId, message) {
|
|
151
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
152
|
-
const { protocolId, pendingTransactionId } = yield ctx.client.preSignMessage(userId, walletId, message);
|
|
153
|
-
if (pendingTransactionId) {
|
|
154
|
-
return { pendingTransactionId };
|
|
155
|
-
}
|
|
156
|
-
if (ctx.offloadMPCComputationURL && !ctx.useDKLS) {
|
|
157
|
-
return signMessageRequest(ctx, userId, walletId, protocolId, message, share);
|
|
158
|
-
}
|
|
159
|
-
const serverUrl = getBaseMPCNetworkUrl(ctx.env, !ctx.disableWebSockets);
|
|
160
|
-
const signMessageFn = ctx.useDKLS ? global.dklsSignMessage : global.signMessage;
|
|
161
|
-
return new Promise((resolve, reject) => signMessageFn(share, serverUrl, message, protocolId, (err, result) => {
|
|
162
|
-
if (err) {
|
|
163
|
-
reject(err);
|
|
164
|
-
}
|
|
165
|
-
resolve({ signature: result });
|
|
166
|
-
}));
|
|
167
|
-
});
|
|
168
|
-
}
|
|
169
|
-
export function signTransaction(ctx, share, walletId, userId, tx, chainId) {
|
|
170
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
171
|
-
const { data: { protocolId, pendingTransactionId }, } = yield ctx.client.signTransaction(userId, walletId, { transaction: tx, chainId });
|
|
172
|
-
if (pendingTransactionId) {
|
|
173
|
-
return { pendingTransactionId };
|
|
174
|
-
}
|
|
175
|
-
if (ctx.offloadMPCComputationURL && !ctx.useDKLS) {
|
|
176
|
-
return sendTransactionRequest(ctx, userId, walletId, protocolId, tx, share, chainId);
|
|
177
|
-
}
|
|
178
|
-
const serverUrl = getBaseMPCNetworkUrl(ctx.env, !ctx.disableWebSockets);
|
|
179
|
-
const signTransactionFn = ctx.useDKLS ? global.dklsSendTransaction : global.sendTransaction;
|
|
180
|
-
return new Promise((resolve, reject) => signTransactionFn(share, serverUrl, tx, chainId, protocolId, (err, result) => {
|
|
181
|
-
if (err) {
|
|
182
|
-
reject(err);
|
|
183
|
-
}
|
|
184
|
-
resolve({ signature: result });
|
|
185
|
-
}));
|
|
186
|
-
});
|
|
187
|
-
}
|
|
188
|
-
export function sendTransaction(ctx, share, walletId, userId, tx, chainId) {
|
|
189
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
190
|
-
const { data: { protocolId, pendingTransactionId }, } = yield ctx.client.sendTransaction(userId, walletId, { transaction: tx, chainId });
|
|
191
|
-
if (pendingTransactionId) {
|
|
192
|
-
return { pendingTransactionId };
|
|
193
|
-
}
|
|
194
|
-
if (ctx.offloadMPCComputationURL && !ctx.useDKLS) {
|
|
195
|
-
return sendTransactionRequest(ctx, userId, walletId, protocolId, tx, share, chainId);
|
|
196
|
-
}
|
|
197
|
-
const serverUrl = getBaseMPCNetworkUrl(ctx.env, !ctx.disableWebSockets);
|
|
198
|
-
const sendTransactionFn = ctx.useDKLS ? global.dklsSendTransaction : global.sendTransaction;
|
|
199
|
-
return new Promise((resolve, reject) => sendTransactionFn(share, serverUrl, tx, chainId, protocolId, (err, result) => {
|
|
200
|
-
if (err) {
|
|
201
|
-
reject(err);
|
|
202
|
-
}
|
|
203
|
-
resolve({ signature: result });
|
|
204
|
-
}));
|
|
205
|
-
});
|
|
206
|
-
}
|
|
207
|
-
export function refresh(ctx, share, walletId, userId) {
|
|
208
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
209
|
-
const { data: { protocolId }, } = yield ctx.client.refreshKeys(userId, walletId);
|
|
210
|
-
const serverUrl = getBaseMPCNetworkUrl(ctx.env, !ctx.disableWebSockets);
|
|
211
|
-
const refreshFn = ctx.useDKLS ? global.dklsRefresh : global.refresh;
|
|
212
|
-
return new Promise((resolve, reject) => refreshFn(share, serverUrl, protocolId, (err, result) => {
|
|
213
|
-
if (err) {
|
|
214
|
-
reject(err);
|
|
215
|
-
}
|
|
216
|
-
resolve(result);
|
|
217
|
-
}));
|
|
218
|
-
});
|
|
219
|
-
}
|
|
220
|
-
export function getPrivateKey(ctx, share, walletId, userId) {
|
|
221
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
222
|
-
const paraShare = yield ctx.client.getParaShare(userId, walletId);
|
|
223
|
-
if (!paraShare) {
|
|
224
|
-
console.error('unable to retrieve Para share');
|
|
225
|
-
return '';
|
|
226
|
-
}
|
|
227
|
-
return new Promise((resolve, reject) => global.getPrivateKey(share, paraShare, (err, result) => {
|
|
228
|
-
if (err) {
|
|
229
|
-
reject(err);
|
|
230
|
-
}
|
|
231
|
-
resolve(result);
|
|
232
|
-
}));
|
|
233
|
-
});
|
|
234
|
-
}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { Environment } from '@getpara/core-sdk';
|
|
2
|
-
interface Message {
|
|
3
|
-
env: Environment;
|
|
4
|
-
apiKey?: string;
|
|
5
|
-
cosmosPrefix?: string;
|
|
6
|
-
offloadMPCComputationURL?: string;
|
|
7
|
-
disableWorkers?: boolean;
|
|
8
|
-
functionType: string;
|
|
9
|
-
params: Record<string, any>;
|
|
10
|
-
sessionCookie?: string;
|
|
11
|
-
useDKLS?: boolean;
|
|
12
|
-
disableWebSockets?: boolean;
|
|
13
|
-
workId: string;
|
|
14
|
-
}
|
|
15
|
-
export declare function handleMessage(e: {
|
|
16
|
-
data: Message;
|
|
17
|
-
}): Promise<any>;
|
|
18
|
-
export {};
|
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
-
});
|
|
9
|
-
};
|
|
10
|
-
import { Worker } from 'worker_threads';
|
|
11
|
-
import { getPortalBaseURL } from '@getpara/core-sdk';
|
|
12
|
-
const CLEAR_WORKER_TIMEOUT_MS = 1000 * 90;
|
|
13
|
-
let worker;
|
|
14
|
-
const resFunctionMap = {};
|
|
15
|
-
function removeWorkId(workId, skipClearTimeout) {
|
|
16
|
-
const { timeoutId } = resFunctionMap[workId];
|
|
17
|
-
delete resFunctionMap[workId];
|
|
18
|
-
if (skipClearTimeout) {
|
|
19
|
-
return;
|
|
20
|
-
}
|
|
21
|
-
clearTimeout(timeoutId);
|
|
22
|
-
}
|
|
23
|
-
export function setupWorker(ctx, resFunction, workId) {
|
|
24
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
25
|
-
const timeoutId = setTimeout(() => {
|
|
26
|
-
removeWorkId(workId, true);
|
|
27
|
-
}, CLEAR_WORKER_TIMEOUT_MS);
|
|
28
|
-
resFunctionMap[workId] = {
|
|
29
|
-
fn: resFunction,
|
|
30
|
-
timeoutId,
|
|
31
|
-
};
|
|
32
|
-
if (!worker || !worker.threadId) {
|
|
33
|
-
const workerRes = yield fetch(`${getPortalBaseURL(ctx)}/static/js/mpcWorkerServer-bundle.js`);
|
|
34
|
-
worker = new Worker(yield workerRes.text(), { eval: true });
|
|
35
|
-
const onmessage = (message) => __awaiter(this, void 0, void 0, function* () {
|
|
36
|
-
const { workId: messageWorkId } = message;
|
|
37
|
-
delete message.workId;
|
|
38
|
-
yield resFunctionMap[messageWorkId].fn(message);
|
|
39
|
-
removeWorkId(messageWorkId);
|
|
40
|
-
});
|
|
41
|
-
worker.on('message', onmessage);
|
|
42
|
-
worker.on('error', err => {
|
|
43
|
-
throw err;
|
|
44
|
-
});
|
|
45
|
-
worker.on('exit', code => {
|
|
46
|
-
console.error(`worker stopped with exit code ${code}`);
|
|
47
|
-
});
|
|
48
|
-
}
|
|
49
|
-
return worker;
|
|
50
|
-
});
|
|
51
|
-
}
|