zkcloudworker 0.1.19 → 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.
Files changed (80) hide show
  1. package/{dist/lib/web → lib/ts}/src/api/api.d.ts +34 -6
  2. package/{dist/lib → lib}/ts/src/api/api.js +35 -6
  3. package/lib/ts/src/cloud/cloud.d.ts +38 -0
  4. package/lib/ts/src/cloud/cloud.js +24 -0
  5. package/{dist/lib → lib}/ts/src/cloud/local.d.ts +13 -3
  6. package/{dist/lib → lib}/ts/src/cloud/local.js +16 -3
  7. package/{dist/lib → lib}/ts/src/index.d.ts +3 -3
  8. package/{dist/lib → lib}/ts/src/index.js +5 -4
  9. package/lib/ts/tsconfig.tsbuildinfo +1 -0
  10. package/{dist/lib/ts → lib/web}/src/api/api.d.ts +34 -6
  11. package/{dist/lib → lib}/web/src/api/api.js +35 -4
  12. package/lib/web/src/api/api.js.map +1 -0
  13. package/lib/web/src/cloud/cloud.d.ts +38 -0
  14. package/lib/web/src/cloud/cloud.js +20 -0
  15. package/lib/web/src/cloud/cloud.js.map +1 -0
  16. package/{dist/lib → lib}/web/src/cloud/local.d.ts +13 -3
  17. package/{dist/lib → lib}/web/src/cloud/local.js +16 -3
  18. package/lib/web/src/cloud/local.js.map +1 -0
  19. package/{dist/lib → lib}/web/src/index.d.ts +3 -3
  20. package/{dist/lib → lib}/web/src/index.js +3 -3
  21. package/lib/web/src/index.js.map +1 -0
  22. package/lib/web/tsconfig.web.tsbuildinfo +1 -0
  23. package/package.json +40 -50
  24. package/LICENSE +0 -201
  25. package/dist/README.md +0 -79
  26. package/dist/lib/ts/src/cloud/cloud.d.ts +0 -12
  27. package/dist/lib/ts/src/cloud/cloud.js +0 -9
  28. package/dist/lib/ts/src/custom/backend.d.ts +0 -20
  29. package/dist/lib/ts/src/custom/backend.js +0 -13
  30. package/dist/lib/ts/tsconfig.tsbuildinfo +0 -1
  31. package/dist/lib/web/src/api/api.js.map +0 -1
  32. package/dist/lib/web/src/cloud/cloud.d.ts +0 -12
  33. package/dist/lib/web/src/cloud/cloud.js +0 -6
  34. package/dist/lib/web/src/cloud/cloud.js.map +0 -1
  35. package/dist/lib/web/src/cloud/local.js.map +0 -1
  36. package/dist/lib/web/src/custom/backend.d.ts +0 -20
  37. package/dist/lib/web/src/custom/backend.js +0 -11
  38. package/dist/lib/web/src/custom/backend.js.map +0 -1
  39. package/dist/lib/web/src/index.js.map +0 -1
  40. package/dist/lib/web/tsconfig.web.tsbuildinfo +0 -1
  41. package/dist/package.json +0 -49
  42. package/dist/yarn.lock +0 -94
  43. package/jest-config.ts +0 -32
  44. package/src/api/api.ts +0 -250
  45. package/src/api/client-api.ts +0 -186
  46. package/src/cloud/cloud.ts +0 -22
  47. package/src/cloud/local.ts +0 -34
  48. package/src/config.ts +0 -9
  49. package/src/custom/backend.ts +0 -30
  50. package/src/fee.ts +0 -7
  51. package/src/index.ts +0 -38
  52. package/src/mina.ts +0 -230
  53. package/src/networks.ts +0 -88
  54. package/tsconfig.json +0 -41
  55. package/tsconfig.web.json +0 -29
  56. /package/{dist/lib → lib}/ts/src/api/client-api.d.ts +0 -0
  57. /package/{dist/lib → lib}/ts/src/api/client-api.js +0 -0
  58. /package/{dist/lib → lib}/ts/src/config.d.ts +0 -0
  59. /package/{dist/lib → lib}/ts/src/config.js +0 -0
  60. /package/{dist/lib → lib}/ts/src/fee.d.ts +0 -0
  61. /package/{dist/lib → lib}/ts/src/fee.js +0 -0
  62. /package/{dist/lib → lib}/ts/src/mina.d.ts +0 -0
  63. /package/{dist/lib → lib}/ts/src/mina.js +0 -0
  64. /package/{dist/lib → lib}/ts/src/networks.d.ts +0 -0
  65. /package/{dist/lib → lib}/ts/src/networks.js +0 -0
  66. /package/{dist/lib → lib}/web/src/api/client-api.d.ts +0 -0
  67. /package/{dist/lib → lib}/web/src/api/client-api.js +0 -0
  68. /package/{dist/lib → lib}/web/src/api/client-api.js.map +0 -0
  69. /package/{dist/lib → lib}/web/src/config.d.ts +0 -0
  70. /package/{dist/lib → lib}/web/src/config.js +0 -0
  71. /package/{dist/lib → lib}/web/src/config.js.map +0 -0
  72. /package/{dist/lib → lib}/web/src/fee.d.ts +0 -0
  73. /package/{dist/lib → lib}/web/src/fee.js +0 -0
  74. /package/{dist/lib → lib}/web/src/fee.js.map +0 -0
  75. /package/{dist/lib → lib}/web/src/mina.d.ts +0 -0
  76. /package/{dist/lib → lib}/web/src/mina.js +0 -0
  77. /package/{dist/lib → lib}/web/src/mina.js.map +0 -0
  78. /package/{dist/lib → lib}/web/src/networks.d.ts +0 -0
  79. /package/{dist/lib → lib}/web/src/networks.js +0 -0
  80. /package/{dist/lib → lib}/web/src/networks.js.map +0 -0
package/src/api/api.ts DELETED
@@ -1,250 +0,0 @@
1
- import axios from "axios";
2
- import { sleep } from "../mina";
3
- import config from "../config";
4
- const { ZKCLOUDWORKER_AUTH, ZKCLOUDWORKER_API } = config;
5
-
6
- /**
7
- * API class for interacting with the zkCloudWorker
8
- * @property jwt The jwt token for authentication, get it at https://t.me/minanft_bot?start=auth
9
- * @property endpoint The endpoint of the serverless api
10
- */
11
- export class zkCloudWorker {
12
- jwt: string;
13
- endpoint: string;
14
-
15
- /**
16
- * Constructor for the API class
17
- * @param jwt The jwt token for authentication, get it at https://t.me/minanft_bot?start=auth
18
- */
19
- constructor(jwt: string) {
20
- this.jwt = jwt;
21
- this.endpoint = ZKCLOUDWORKER_API;
22
- }
23
-
24
- /**
25
- * Starts a new job for the proof calculation using serverless api call
26
- * The developer and name should correspond to the BackupPlugin of the API
27
- * All other parameters should correspond to the parameters of the BackupPlugin
28
- * @param data the data for the proof call
29
- * @param data.transactions the transactions
30
- * @param data.developer the developer
31
- * @param data.name the name of the job
32
- * @param data.task the task of the job
33
- * @param data.args the arguments of the job
34
- * @returns { success: boolean, error?: string, jobId?: string }
35
- * where jonId is the jobId of the job
36
- */
37
- public async createJob(data: {
38
- transactions: string[];
39
- developer: string;
40
- name: string;
41
- task: string;
42
- args: string[];
43
- metadata?: string;
44
- }): Promise<{
45
- success: boolean;
46
- error?: string;
47
- jobId?: string;
48
- }> {
49
- const result = await this.apiHub("createJob", data);
50
- if (result.data === "error")
51
- return {
52
- success: false,
53
- error: result.error,
54
- };
55
- else
56
- return {
57
- success: result.success,
58
- jobId: result.data,
59
- error: result.error,
60
- };
61
- }
62
-
63
- /**
64
- * Gets the result of the job using serverless api call
65
- * @param data the data for the jobResult call
66
- * @param data.jobId the jobId of the job
67
- * @returns { success: boolean, error?: string, result?: any }
68
- * where result is the result of the job
69
- * if the job is not finished yet, the result will be undefined
70
- * if the job failed, the result will be undefined and error will be set
71
- * if the job is finished, the result will be set and error will be undefined
72
- * if the job is not found, the result will be undefined and error will be set
73
- */
74
- public async jobResult(data: { jobId: string }): Promise<{
75
- success: boolean;
76
- error?: string;
77
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
78
- result?: any;
79
- }> {
80
- const result = await this.apiHub("jobResult", data);
81
- if (this.isError(result.data))
82
- return {
83
- success: false,
84
- error: result.error,
85
- result: result.data,
86
- };
87
- else
88
- return {
89
- success: result.success,
90
- error: result.error,
91
- result: result.data,
92
- };
93
- }
94
-
95
- /**
96
- * Gets the result of the job using serverless api call
97
- * @param data the data for the deploy call
98
- * @param data.packageName the name of the zip file with the code to be deployed
99
- * @returns { success: boolean, error?: string, result?: any }
100
- * where result is the result of the job
101
- * if the job is not finished yet, the result will be undefined
102
- * if the job failed, the result will be undefined and error will be set
103
- * if the job is finished, the result will be set and error will be undefined
104
- * if the job is not found, the result will be undefined and error will be set
105
- */
106
- public async deploy(data: { packageName: string }): Promise<{
107
- success: boolean;
108
- error?: string;
109
- jobId?: string;
110
- }> {
111
- const result = await this.apiHub("deploy", data);
112
- if (result.data === "error")
113
- return {
114
- success: false,
115
- error: result.error,
116
- };
117
- else
118
- return {
119
- success: result.success,
120
- jobId: result.data,
121
- error: result.error,
122
- };
123
- }
124
-
125
- /**
126
- * Gets the billing report for the jobs sent using JWT
127
- * @returns { success: boolean, error?: string, result?: any }
128
- * where result is the billing report
129
- */
130
- public async queryBilling(): Promise<{
131
- success: boolean;
132
- error?: string;
133
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
134
- result?: any;
135
- }> {
136
- const result = await this.apiHub("queryBilling", {});
137
- if (this.isError(result.data))
138
- return {
139
- success: false,
140
- error: result.error,
141
- result: result.data,
142
- };
143
- else
144
- return {
145
- success: result.success,
146
- error: result.error,
147
- result: result.data,
148
- };
149
- }
150
-
151
- /**
152
- * Waits for the job to finish
153
- * @param data the data for the waitForJobResult call
154
- * @param data.jobId the jobId of the job
155
- * @param data.maxAttempts the maximum number of attempts, default is 360 (2 hours)
156
- * @param data.interval the interval between attempts, default is 20000 (20 seconds)
157
- * @param data.maxErrors the maximum number of network errors, default is 10
158
- * @returns { success: boolean, error?: string, result?: any }
159
- * where result is the result of the job
160
- */
161
- public async waitForJobResult(data: {
162
- jobId: string;
163
- maxAttempts?: number;
164
- interval?: number;
165
- maxErrors?: number;
166
- }): Promise<{
167
- success: boolean;
168
- error?: string;
169
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
170
- result?: any;
171
- }> {
172
- const maxAttempts = data?.maxAttempts ?? 360; // 2 hours
173
- const interval = data?.interval ?? 20000;
174
- const maxErrors = data?.maxErrors ?? 10;
175
- const errorDelay = 30000; // 30 seconds
176
- let attempts = 0;
177
- let errors = 0;
178
- while (attempts < maxAttempts) {
179
- const result = await this.apiHub("jobResult", data);
180
- if (result.success === false) {
181
- errors++;
182
- if (errors > maxErrors) {
183
- return {
184
- success: false,
185
- error: "Too many network errors",
186
- result: undefined,
187
- };
188
- }
189
- await sleep(errorDelay * errors);
190
- } else {
191
- if (this.isError(result.data))
192
- return {
193
- success: false,
194
- error: result.error,
195
- result: result.data,
196
- };
197
- else if (result.data?.result !== undefined) {
198
- return {
199
- success: result.success,
200
- error: result.error,
201
- result: result.data,
202
- };
203
- }
204
- await sleep(interval);
205
- }
206
- attempts++;
207
- }
208
- return {
209
- success: false,
210
- error: "Timeout",
211
- result: undefined,
212
- };
213
- }
214
-
215
- /**
216
- * Calls the serverless API
217
- * @param command the command of the API
218
- * @param data the data of the API
219
- * */
220
- private async apiHub(
221
- command: string,
222
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
223
- data: any
224
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
225
- ): Promise<{ success: boolean; data?: any; error?: any }> {
226
- const apiData = {
227
- auth: ZKCLOUDWORKER_AUTH,
228
- command: command,
229
- jwtToken: this.jwt,
230
- data: data,
231
- };
232
-
233
- try {
234
- const response = await axios.post(this.endpoint, apiData);
235
- return { success: true, data: response.data };
236
- } catch (error: any) {
237
- console.error("apiHub error:", error.message ?? error);
238
- return { success: false, error: error };
239
- }
240
- }
241
-
242
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
243
- private isError(data: any): boolean {
244
- if (data === "error") return true;
245
- if (data?.jobStatus === "failed") return true;
246
- if (typeof data === "string" && data.toLowerCase().startsWith("error"))
247
- return true;
248
- return false;
249
- }
250
- }
@@ -1,186 +0,0 @@
1
- /**
2
- * Client API for calling the zkCloudWorker
3
- */
4
- export {
5
- TxnPayload,
6
- IsError,
7
- SerializedTxn,
8
- SignedSerializedTxn,
9
- TxnResult,
10
- JobPayload,
11
- JobResult,
12
- zkCloudWorkerAPI,
13
- };
14
-
15
- interface TxnPayload {
16
- data: object;
17
- options?: object;
18
- }
19
-
20
- interface IsError {
21
- code: number;
22
- message: string;
23
- exception: any;
24
- }
25
-
26
- interface SerializedTxn {
27
- hash: string | null;
28
- transaction: any | null;
29
- error: IsError | null;
30
- }
31
-
32
- interface SignedSerializedTxn {
33
- hash: string | null;
34
- transaction: any | null;
35
- error: IsError | null;
36
- }
37
-
38
- interface TxnResult {
39
- hash: string | null;
40
- data: any | null;
41
- error: IsError | null;
42
- }
43
-
44
- interface JobPayload {
45
- data: object;
46
- options?: object;
47
- }
48
-
49
- interface JobResult {
50
- data: any | null;
51
- error: IsError | null;
52
- }
53
-
54
- class zkCloudWorkerAPI {
55
- private API_KEY: string = "";
56
-
57
- constructor(apiKey: string) {
58
- this.API_KEY = apiKey;
59
- }
60
-
61
- /**
62
- * prove() sign() and send()
63
- *
64
- * The called cloud worker is expected to compile the needed Contract,
65
- * create the transaction, prove it and send it back serialized.
66
- *
67
- * Then the serialized transaction can be signed locally using AuroWallet
68
- * and finally send it to MINA using the cloud worker.
69
- *
70
- * IMPORTANT: the transaction fee will be paid by the local sender, using
71
- * the Auro Wallet at the moment of signing the serialized transaction.
72
- *
73
- * We only need the sender public key to create and prove the transaction.
74
- * The sender private key NEVER leaves the local wallet.
75
- *
76
- * Example:
77
- * ~~~
78
- * let zkWorker = new ZKRunner(API_KEY);
79
- *
80
- * let serializedTxn = await zkWorker.prove('batch-voting-...', {
81
- * data: {
82
- * claimUid: '012345...789',
83
- * // ...
84
- * },
85
- * options: {
86
- * senderAddress: 'B62...',
87
- * fee: MIN_FEE // MAX_FEE | AUTO_FEE | number
88
- * }
89
- * });
90
- * if (serializedTxn.error)
91
- * // treat error here
92
- *
93
- * let signedTxn = await zkWorker.sign(signerAddress, serializedTxn);
94
- * if (signedTxn.error)
95
- * // treat error here
96
- *
97
- * let txnResult = await zkWorker.send(signedTxn) ;
98
- * if (txnResult.error)
99
- * // treat error here
100
- * ~~~
101
- */
102
- async prove(
103
- jobName: string,
104
- payload: TxnPayload //: Promise < SerializedTxn > {
105
- ) {}
106
-
107
- async sign(
108
- signerAddress: string,
109
- serializedTxn: SerializedTxn //: Promise<SignedSerializedTxn> {
110
- ) {}
111
-
112
- async send(
113
- txn: SignedSerializedTxn //: Promise<TxnResult> {
114
- ) {}
115
-
116
- /**
117
- * proveAndSend()
118
- *
119
- * The called cloud worker is expected to do all: compile the needed Contract,
120
- * create the transaction, prove it, sign it using one of the available
121
- * fee payers, and finally send it to MINA.
122
- *
123
- * IMPORTANT: the transaction fee will be paid by the first fee payer
124
- * available from the list of fee payers provided by the ZKRunner service.
125
- * Also the fee will be set by the cloud worker using some optimal algorithm
126
- * that minimizes fees.
127
- *
128
- * In this case the sender public key to create and prove the transaction
129
- * will be the selected ZKRunner fee payer previously mentioned.
130
- *
131
- * Example:
132
- * ~~~
133
- * let zkWorker = new ZKRunner(API_KEY);
134
- *
135
- * let txnResult = await zkWorker.proveAndSend('batch-voting-...', {
136
- * data: {
137
- * claimUid: '012345...789',
138
- * // ...
139
- * }
140
- * });
141
- *
142
- * if (txnResult.error)
143
- * // treat error here
144
- * ~~~
145
- */
146
- async proveAndSend(
147
- jobName: string,
148
- payload: TxnPayload //: Promise<TxnResult> {
149
- ) {}
150
-
151
- /**
152
- * runJob()
153
- *
154
- * The called cloud worker can also be used to easily run jobs not related to
155
- * a MINA transaction, and will act just like any serverless function.
156
- *
157
- * This "generic" job can benefit from the easy to use deploy and call service
158
- * already implemented for cloud proving without no extra costs.
159
- *
160
- * IMPORTANT: there will be a small fee that needs to be paid for service usage,
161
- * but no MINA fees need to be paid.
162
- *
163
- * Example:
164
- * ~~~
165
- * let zkWorker = new ZKRunner(API_KEY);
166
- *
167
- * let jobResult = await zkWorker.runJob('send-email-to-judges', {
168
- * data: {
169
- * judges: [
170
- * // ...
171
- * ],
172
- * },
173
- * options: {
174
- * // ...
175
- * }
176
- * });
177
- *
178
- * if (txnResult.error)
179
- * // treat error here
180
- * ~~~
181
- */
182
- async runJob(
183
- jobName: string,
184
- payload: JobPayload //: Promise<JobResult> {
185
- ) {}
186
- }
@@ -1,22 +0,0 @@
1
- import { Cache, PrivateKey } from "o1js";
2
-
3
- export abstract class Cloud {
4
- cache: Cache;
5
- constructor(cache: Cache) {
6
- this.cache = cache;
7
- }
8
- // TODO: change it to the sign method to protect the private key
9
- abstract getDeployer(): Promise<PrivateKey>;
10
- abstract log(msg: string): void;
11
-
12
- /* TODO: add more methods
13
- -getDataByKey
14
- -saveDataByKey
15
- -saveFile
16
- -loadFile
17
- */
18
- abstract getDataByKey(key: string): Promise<string | undefined>;
19
- abstract saveDataByKey(key: string, value: string): Promise<void>;
20
- abstract saveFile(filename: string, value: Buffer): Promise<void>;
21
- abstract loadFile(filename: string): Promise<Buffer | undefined>;
22
- }
@@ -1,34 +0,0 @@
1
- import { Cache, PrivateKey } from "o1js";
2
- import { Cloud } from "./cloud";
3
-
4
- export class LocalCloud extends Cloud {
5
- cache: Cache;
6
- data: Map<string, string> = new Map<string, string>();
7
-
8
- constructor() {
9
- const cache = Cache.FileSystem("./cache");
10
- super(cache);
11
- }
12
- public async getDeployer(): Promise<PrivateKey> {
13
- throw new Error("Method not implemented.");
14
- }
15
- public async log(msg: string): Promise<void> {
16
- console.log("LocalCloud:", msg);
17
- }
18
-
19
- public async getDataByKey(key: string): Promise<string | undefined> {
20
- const value = this.data.get(key);
21
- return value;
22
- }
23
-
24
- public async saveDataByKey(key: string, value: string): Promise<void> {
25
- this.data.set(key, value);
26
- }
27
-
28
- public async saveFile(filename: string, value: Buffer): Promise<void> {
29
- throw new Error("Method not implemented.");
30
- }
31
- public async loadFile(filename: string): Promise<Buffer | undefined> {
32
- throw new Error("Method not implemented.");
33
- }
34
- }
package/src/config.ts DELETED
@@ -1,9 +0,0 @@
1
- const config = {
2
- MINAFEE: "200000000",
3
- ZKCLOUDWORKER_AUTH:
4
- "M6t4jtbBAFFXhLERHQWyEB9JA9xi4cWqmYduaCXtbrFjb7yaY7TyaXDunKDJNiUTBEcyUomNXJgC",
5
- ZKCLOUDWORKER_API:
6
- "https://cuq99yahhi.execute-api.eu-west-1.amazonaws.com/dev/zkcloudworker",
7
- };
8
-
9
- export default config;
@@ -1,30 +0,0 @@
1
- export { BackendPlugin };
2
- import type { Cache } from "o1js";
3
-
4
- abstract class BackendPlugin {
5
- name: string;
6
- task: string;
7
- args: string[];
8
- jobId?: string;
9
-
10
- constructor(params: {
11
- name: string;
12
- task: string;
13
- args: string[];
14
- jobId?: string;
15
- }) {
16
- const { name, task, args, jobId } = params;
17
- this.name = name;
18
- this.task = task;
19
- this.args = args;
20
- this.jobId = jobId;
21
- }
22
-
23
- abstract compile(cache: Cache): Promise<void>;
24
- abstract create(transaction: string): Promise<string | undefined>;
25
- abstract merge(proof1: string, proof2: string): Promise<string | undefined>;
26
-
27
- abstract send(transaction: string): Promise<string | undefined>;
28
- abstract mint(transaction: string): Promise<string | undefined>;
29
- abstract verify(proof: string): Promise<string | undefined>;
30
- }
package/src/fee.ts DELETED
@@ -1,7 +0,0 @@
1
- import { UInt64 } from "o1js";
2
- import config from "./config";
3
-
4
- export async function fee(): Promise<UInt64> {
5
- //TODO: update after mainnet launch
6
- return UInt64.fromJSON(config.MINAFEE);
7
- }
package/src/index.ts DELETED
@@ -1,38 +0,0 @@
1
- export { zkCloudWorker } from "./api/api";
2
- export { Cloud } from "./cloud/cloud";
3
- export { LocalCloud } from "./cloud/local";
4
- export {
5
- initBlockchain,
6
- Memory,
7
- makeString,
8
- sleep,
9
- accountBalance,
10
- accountBalanceMina,
11
- formatTime,
12
- MinaNetworkInstance,
13
- currentNetwork,
14
- getNetworkIdHash,
15
- } from "./mina";
16
- export { fee } from "./fee";
17
- export {
18
- blockchain,
19
- MinaNetwork,
20
- networks,
21
- Mainnet,
22
- Berkeley,
23
- Zeko,
24
- TestWorld2,
25
- Lightnet,
26
- Local,
27
- } from "./networks";
28
- export {
29
- TxnPayload,
30
- IsError,
31
- SerializedTxn,
32
- SignedSerializedTxn,
33
- TxnResult,
34
- JobPayload,
35
- JobResult,
36
- zkCloudWorkerAPI,
37
- } from "./api/client-api";
38
- export { BackendPlugin } from "./custom/backend";