@devtion/backend 0.0.0-4088679 → 0.0.0-477457c

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 (50) hide show
  1. package/README.md +7 -7
  2. package/dist/src/functions/index.js +669 -354
  3. package/dist/src/functions/index.mjs +672 -359
  4. package/dist/src/functions/types/functions/bandada.d.ts +4 -0
  5. package/dist/src/functions/types/functions/bandada.d.ts.map +1 -0
  6. package/dist/{types → src/functions/types}/functions/ceremony.d.ts.map +1 -1
  7. package/dist/{types → src/functions/types}/functions/circuit.d.ts.map +1 -1
  8. package/dist/{types → src/functions/types}/functions/index.d.ts +2 -0
  9. package/dist/{types → src/functions/types}/functions/index.d.ts.map +1 -1
  10. package/dist/src/functions/types/functions/siwe.d.ts +4 -0
  11. package/dist/src/functions/types/functions/siwe.d.ts.map +1 -0
  12. package/dist/{types → src/functions/types}/functions/storage.d.ts.map +1 -1
  13. package/dist/{types → src/functions/types}/functions/timeout.d.ts.map +1 -1
  14. package/dist/{types → src/functions/types}/functions/user.d.ts.map +1 -1
  15. package/dist/{types → src/functions/types}/lib/errors.d.ts +3 -1
  16. package/dist/src/functions/types/lib/errors.d.ts.map +1 -0
  17. package/dist/{types → src/functions/types}/lib/services.d.ts +7 -0
  18. package/dist/src/functions/types/lib/services.d.ts.map +1 -0
  19. package/dist/src/functions/types/lib/utils.d.ts.map +1 -0
  20. package/dist/{types → src/functions/types}/types/index.d.ts +56 -0
  21. package/dist/src/functions/types/types/index.d.ts.map +1 -0
  22. package/package.json +8 -7
  23. package/src/functions/bandada.ts +154 -0
  24. package/src/functions/ceremony.ts +16 -8
  25. package/src/functions/circuit.ts +443 -391
  26. package/src/functions/index.ts +2 -0
  27. package/src/functions/participant.ts +15 -15
  28. package/src/functions/siwe.ts +77 -0
  29. package/src/functions/storage.ts +12 -8
  30. package/src/functions/timeout.ts +14 -13
  31. package/src/functions/user.ts +22 -11
  32. package/src/lib/errors.ts +11 -1
  33. package/src/lib/services.ts +36 -0
  34. package/src/lib/utils.ts +10 -8
  35. package/src/types/declarations.d.ts +1 -0
  36. package/src/types/index.ts +60 -0
  37. package/dist/types/lib/errors.d.ts.map +0 -1
  38. package/dist/types/lib/services.d.ts.map +0 -1
  39. package/dist/types/lib/utils.d.ts.map +0 -1
  40. package/dist/types/types/index.d.ts.map +0 -1
  41. /package/dist/{types → src/functions/types}/functions/ceremony.d.ts +0 -0
  42. /package/dist/{types → src/functions/types}/functions/circuit.d.ts +0 -0
  43. /package/dist/{types → src/functions/types}/functions/participant.d.ts +0 -0
  44. /package/dist/{types → src/functions/types}/functions/participant.d.ts.map +0 -0
  45. /package/dist/{types → src/functions/types}/functions/storage.d.ts +0 -0
  46. /package/dist/{types → src/functions/types}/functions/timeout.d.ts +0 -0
  47. /package/dist/{types → src/functions/types}/functions/user.d.ts +0 -0
  48. /package/dist/{types → src/functions/types}/lib/utils.d.ts +0 -0
  49. /package/dist/{types → src/functions/types}/types/enums.d.ts +0 -0
  50. /package/dist/{types → src/functions/types}/types/enums.d.ts.map +0 -0
@@ -0,0 +1,4 @@
1
+ import * as functions from "firebase-functions";
2
+ export declare const bandadaValidateProof: functions.HttpsFunction & functions.Runnable<any>;
3
+ export default bandadaValidateProof;
4
+ //# sourceMappingURL=bandada.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bandada.d.ts","sourceRoot":"","sources":["../../../src/functions/bandada.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,SAAS,MAAM,oBAAoB,CAAA;AAa/C,eAAO,MAAM,oBAAoB,mDAyI3B,CAAA;AAEN,eAAe,oBAAoB,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"ceremony.d.ts","sourceRoot":"","sources":["../../../src/functions/ceremony.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,oBAAoB,CAAA;AAuC/C;;;;;GAKG;AACH,eAAO,MAAM,aAAa,kCAiBpB,CAAA;AAEN;;;;;GAKG;AACH,eAAO,MAAM,YAAY,kCAkBnB,CAAA;AAEN;;;;GAIG;AACH,eAAO,MAAM,aAAa,mDA0HpB,CAAA;AAEN;;;GAGG;AACH,eAAO,MAAM,+BAA+B,oEAsCtC,CAAA;AAEN;;;;GAIG;AACH,eAAO,MAAM,gBAAgB,mDAiEvB,CAAA"}
1
+ {"version":3,"file":"ceremony.d.ts","sourceRoot":"","sources":["../../../src/functions/ceremony.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,oBAAoB,CAAA;AAuC/C;;;;;GAKG;AACH,eAAO,MAAM,aAAa,kCAiBpB,CAAA;AAEN;;;;;GAKG;AACH,eAAO,MAAM,YAAY,kCAkBnB,CAAA;AAEN;;;;GAIG;AACH,eAAO,MAAM,aAAa,mDAkIpB,CAAA;AAEN;;;GAGG;AACH,eAAO,MAAM,+BAA+B,oEAsCtC,CAAA;AAEN;;;;GAIG;AACH,eAAO,MAAM,gBAAgB,mDAiEvB,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"circuit.d.ts","sourceRoot":"","sources":["../../../src/functions/circuit.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,WAAW,MAAM,uBAAuB,CAAA;AACpD,OAAO,KAAK,WAAW,MAAM,uBAAuB,CAAA;AAyCpD,OAAO,EAAuB,sBAAsB,EAAE,MAAM,gBAAgB,CAAA;AAkO5E;;;;;;;;;;;;;;;;;;GAkBG;AACH,eAAO,MAAM,6BAA6B,4FAoGpC,CAAA;AA8BN;;;;;;;;;;;;;;;;;;;;;;;;;GAyBG;AACH,eAAO,MAAM,kBAAkB,0EA2Z9B,CAAA;AAED;;;;GAIG;AACH,eAAO,MAAM,+CAA+C,wEA4EtD,CAAA;AAEN;;;;GAIG;AACH,eAAO,MAAM,eAAe,uDA8EtB,CAAA"}
1
+ {"version":3,"file":"circuit.d.ts","sourceRoot":"","sources":["../../../src/functions/circuit.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,WAAW,MAAM,uBAAuB,CAAA;AACpD,OAAO,KAAK,WAAW,MAAM,uBAAuB,CAAA;AA2CpD,OAAO,EAAuB,sBAAsB,EAAE,MAAM,gBAAgB,CAAA;AAwP5E;;;;;;;;;;;;;;;;;;GAkBG;AACH,eAAO,MAAM,6BAA6B,4FAoGpC,CAAA;AAwBN;;;;;;;;;;;;;;;;;;;;;;;;;GAyBG;AACH,eAAO,MAAM,kBAAkB,0EA6b9B,CAAA;AAED;;;;GAIG;AACH,eAAO,MAAM,+CAA+C,wEA4EtD,CAAA;AAEN;;;;GAIG;AACH,eAAO,MAAM,eAAe,uDA8EtB,CAAA"}
@@ -3,5 +3,7 @@ export { startCeremony, stopCeremony, setupCeremony, initEmptyWaitingQueueForCir
3
3
  export { checkParticipantForCeremony, progressToNextContributionStep, permanentlyStoreCurrentContributionTimeAndHash, temporaryStoreCurrentContributionMultiPartUploadId, temporaryStoreCurrentContributionUploadedChunkData, progressToNextCircuitForContribution, checkAndPrepareCoordinatorForFinalization } from "./participant";
4
4
  export { coordinateCeremonyParticipant, verifycontribution, refreshParticipantAfterContributionVerification, finalizeCircuit } from "./circuit";
5
5
  export { createBucket, checkIfObjectExist, generateGetObjectPreSignedUrl, startMultiPartUpload, generatePreSignedUrlsParts, completeMultiPartUpload } from "./storage";
6
+ export { bandadaValidateProof } from "./bandada";
7
+ export { checkNonceOfSIWEAddress } from "./siwe";
6
8
  export { checkAndRemoveBlockingContributor, resumeContributionAfterTimeoutExpiration } from "./timeout";
7
9
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/functions/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,6BAA6B,EAAE,MAAM,QAAQ,CAAA;AACxE,OAAO,EACH,aAAa,EACb,YAAY,EACZ,aAAa,EACb,+BAA+B,EAC/B,gBAAgB,EACnB,MAAM,YAAY,CAAA;AACnB,OAAO,EACH,2BAA2B,EAC3B,8BAA8B,EAC9B,8CAA8C,EAC9C,kDAAkD,EAClD,kDAAkD,EAClD,oCAAoC,EACpC,yCAAyC,EAC5C,MAAM,eAAe,CAAA;AACtB,OAAO,EACH,6BAA6B,EAC7B,kBAAkB,EAClB,+CAA+C,EAC/C,eAAe,EAClB,MAAM,WAAW,CAAA;AAClB,OAAO,EACH,YAAY,EACZ,kBAAkB,EAClB,6BAA6B,EAC7B,oBAAoB,EACpB,0BAA0B,EAC1B,uBAAuB,EAC1B,MAAM,WAAW,CAAA;AAClB,OAAO,EAAE,iCAAiC,EAAE,wCAAwC,EAAE,MAAM,WAAW,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/functions/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,6BAA6B,EAAE,MAAM,QAAQ,CAAA;AACxE,OAAO,EACH,aAAa,EACb,YAAY,EACZ,aAAa,EACb,+BAA+B,EAC/B,gBAAgB,EACnB,MAAM,YAAY,CAAA;AACnB,OAAO,EACH,2BAA2B,EAC3B,8BAA8B,EAC9B,8CAA8C,EAC9C,kDAAkD,EAClD,kDAAkD,EAClD,oCAAoC,EACpC,yCAAyC,EAC5C,MAAM,eAAe,CAAA;AACtB,OAAO,EACH,6BAA6B,EAC7B,kBAAkB,EAClB,+CAA+C,EAC/C,eAAe,EAClB,MAAM,WAAW,CAAA;AAClB,OAAO,EACH,YAAY,EACZ,kBAAkB,EAClB,6BAA6B,EAC7B,oBAAoB,EACpB,0BAA0B,EAC1B,uBAAuB,EAC1B,MAAM,WAAW,CAAA;AAClB,OAAO,EAAE,oBAAoB,EAAE,MAAM,WAAW,CAAA;AAChD,OAAO,EAAE,uBAAuB,EAAE,MAAM,QAAQ,CAAA;AAChD,OAAO,EAAE,iCAAiC,EAAE,wCAAwC,EAAE,MAAM,WAAW,CAAA"}
@@ -0,0 +1,4 @@
1
+ import * as functions from "firebase-functions";
2
+ export declare const checkNonceOfSIWEAddress: functions.HttpsFunction & functions.Runnable<any>;
3
+ export default checkNonceOfSIWEAddress;
4
+ //# sourceMappingURL=siwe.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"siwe.d.ts","sourceRoot":"","sources":["../../../src/functions/siwe.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,SAAS,MAAM,oBAAoB,CAAA;AAQ/C,eAAO,MAAM,uBAAuB,mDAgE9B,CAAA;AAEN,eAAe,uBAAuB,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"storage.d.ts","sourceRoot":"","sources":["../../../src/functions/storage.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,oBAAoB,CAAA;AAiI/C;;;GAGG;AACH,eAAO,MAAM,YAAY,mDAgGnB,CAAA;AAEN;;;GAGG;AACH,eAAO,MAAM,kBAAkB,mDAgDzB,CAAA;AAEN;;;;;GAKG;AACH,eAAO,MAAM,6BAA6B,mDAyCpC,CAAA;AAEN;;;GAGG;AACH,eAAO,MAAM,oBAAoB,mDA2D3B,CAAA;AAEN;;;;;;GAMG;AACH,eAAO,MAAM,0BAA0B,mDAuElC,CAAA;AAEL;;;GAGG;AACH,eAAO,MAAM,uBAAuB,mDAgE9B,CAAA"}
1
+ {"version":3,"file":"storage.d.ts","sourceRoot":"","sources":["../../../src/functions/storage.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,oBAAoB,CAAA;AAiI/C;;;GAGG;AACH,eAAO,MAAM,YAAY,mDAmGnB,CAAA;AAEN;;;GAGG;AACH,eAAO,MAAM,kBAAkB,mDAgDzB,CAAA;AAEN;;;;;GAKG;AACH,eAAO,MAAM,6BAA6B,mDAyCpC,CAAA;AAEN;;;GAGG;AACH,eAAO,MAAM,oBAAoB,mDA2D3B,CAAA;AAEN;;;;;;GAMG;AACH,eAAO,MAAM,0BAA0B,mDAwElC,CAAA;AAEL;;;GAGG;AACH,eAAO,MAAM,uBAAuB,mDAgE9B,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"timeout.d.ts","sourceRoot":"","sources":["../../../src/functions/timeout.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,oBAAoB,CAAA;AAuB/C;;;;;;;;;;;;;;;;;GAiBG;AACH,eAAO,MAAM,iCAAiC,kCA6MxC,CAAA;AAEN;;;GAGG;AACH,eAAO,MAAM,wCAAwC,mDA0C/C,CAAA"}
1
+ {"version":3,"file":"timeout.d.ts","sourceRoot":"","sources":["../../../src/functions/timeout.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,oBAAoB,CAAA;AAuB/C;;;;;;;;;;;;;;;;;GAiBG;AACH,eAAO,MAAM,iCAAiC,kCA8MxC,CAAA;AAEN;;;GAGG;AACH,eAAO,MAAM,wCAAwC,mDA0C/C,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"user.d.ts","sourceRoot":"","sources":["../../../src/functions/user.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,oBAAoB,CAAA;AAW/C;;;;;GAKG;AACH,eAAO,MAAM,gBAAgB,mEAqGvB,CAAA;AACN;;;;GAIG;AACH,eAAO,MAAM,6BAA6B,mEA+BpC,CAAA"}
1
+ {"version":3,"file":"user.d.ts","sourceRoot":"","sources":["../../../src/functions/user.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,oBAAoB,CAAA;AAW/C;;;;;GAKG;AACH,eAAO,MAAM,gBAAgB,mEAgHvB,CAAA;AACN;;;;GAIG;AACH,eAAO,MAAM,6BAA6B,mEA+BpC,CAAA"}
@@ -6,7 +6,7 @@ import { LogLevel } from "../types/enums";
6
6
  * @notice the set of Firebase Functions status codes. The codes are the same at the
7
7
  * ones exposed by {@link https://github.com/grpc/grpc/blob/master/doc/statuscodes.md | gRPC}.
8
8
  * @param errorCode <FunctionsErrorCode> - the set of possible error codes.
9
- * @param message <string> - the error messge.
9
+ * @param message <string> - the error message.
10
10
  * @param [details] <string> - the details of the error (optional).
11
11
  * @returns <HttpsError>
12
12
  */
@@ -55,6 +55,8 @@ export declare const SPECIFIC_ERRORS: {
55
55
  SE_VM_TIMEDOUT_COMMAND_EXECUTION: functions.auth.HttpsError;
56
56
  SE_VM_CANCELLED_COMMAND_EXECUTION: functions.auth.HttpsError;
57
57
  SE_VM_DELAYED_COMMAND_EXECUTION: functions.auth.HttpsError;
58
+ SE_VM_UNKNOWN_COMMAND_STATUS: functions.auth.HttpsError;
59
+ WRONG_BUCKET_NAME: functions.auth.HttpsError;
58
60
  };
59
61
  /**
60
62
  * A set of common errors.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../../src/lib/errors.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,oBAAoB,CAAA;AAC/C,OAAO,EAAE,kBAAkB,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAA;AAC5E,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAA;AAEzC;;;;;;;;GAQG;AACH,eAAO,MAAM,SAAS,GAAI,WAAW,kBAAkB,EAAE,SAAS,MAAM,EAAE,UAAU,MAAM,KAAG,UAC9B,CAAA;AAE/D;;;;GAIG;AACH,eAAO,MAAM,QAAQ,GAAI,SAAS,MAAM,EAAE,UAAU,QAAQ,SAqB3D,CAAA;AAED;;;GAGG;AACH,eAAO,MAAM,gBAAgB,GAAI,OAAO,UAAU,UAGjD,CAAA;AAED;;;GAGG;AACH,eAAO,MAAM,eAAe;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA4I3B,CAAA;AAED;;;GAGG;AACH,eAAO,MAAM,aAAa;;;;;;;;;;;CA2CzB,CAAA"}
@@ -1,3 +1,4 @@
1
+ import ethers from "ethers";
1
2
  import { S3Client } from "@aws-sdk/client-s3";
2
3
  /**
3
4
  * Return a configured and connected instance of the AWS S3 client.
@@ -6,4 +7,10 @@ import { S3Client } from "@aws-sdk/client-s3";
6
7
  * @returns <Promise<S3Client>> - the instance of the connected S3 Client instance.
7
8
  */
8
9
  export declare const getS3Client: () => Promise<S3Client>;
10
+ /**
11
+ * Returns a Prvider, connected via a configured JSON URL or else
12
+ * the ethers.js default provider, using configured API keys.
13
+ * @returns <ethers.providers.Provider> An Eth node provider
14
+ */
15
+ export declare const setEthProvider: () => ethers.providers.Provider;
9
16
  //# sourceMappingURL=services.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"services.d.ts","sourceRoot":"","sources":["../../../src/lib/services.ts"],"names":[],"mappings":"AACA,OAAO,MAAM,MAAM,QAAQ,CAAA;AAC3B,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAA;AAM7C;;;;;GAKG;AACH,eAAO,MAAM,WAAW,QAAa,OAAO,CAAC,QAAQ,CAkBpD,CAAA;AAED;;;;GAIG;AACH,eAAO,MAAM,cAAc,QAAO,MAAM,CAAC,SAAS,CAAC,QAwBlD,CAAA"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,YAAY,EACZ,aAAa,EACb,gBAAgB,EAChB,qBAAqB,EAErB,aAAa,EAChB,MAAM,0BAA0B,CAAA;AACjC,OAAO,KAAK,MAAM,gBAAgB,CAAA;AAWlC,OAAO,EAOH,eAAe,EAClB,MAAM,iBAAiB,CAAA;AAIxB,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAA;AAC/C,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAA;AAM/C;;;;;;;;GAQG;AACH,eAAO,MAAM,eAAe,GACxB,YAAY,MAAM,EAClB,YAAY,MAAM,KACnB,OAAO,CAAC,gBAAgB,CAAC,YAAY,CAAC,CASxC,CAAA;AAED;;;;GAIG;AACH,eAAO,MAAM,iCAAiC,QAAO,MAAoC,CAAA;AAEzF;;;GAGG;AACH,eAAO,MAAM,KAAK,GAAU,IAAI,MAAM,KAAG,OAAO,CAAC,IAAI,CAAmB,CAAA;AAExE;;;;;GAKG;AACH,eAAO,MAAM,mBAAmB,GAAU,YAAY,MAAM,KAAG,OAAO,CAAC,KAAK,CAAC,qBAAqB,CAAC,YAAY,CAAC,CAAC,CAYhH,CAAA;AAED;;;;;GAKG;AACH,eAAO,MAAM,+BAA+B,GACxC,YAAY,MAAM,EAClB,WAAW,MAAM,KAClB,OAAO,CAAC,KAAK,CAAC,qBAAqB,CAAC,YAAY,CAAC,CAAC,CAUpD,CAAA;AAED;;;;;;;GAOG;AACH,eAAO,MAAM,uBAAuB,GAChC,YAAY,MAAM,EAClB,eAAe,MAAM,KACtB,OAAO,CAAC,aAAa,CAAC,YAAY,CAAC,CASrC,CAAA;AAED;;;;GAIG;AACH,eAAO,MAAM,qBAAqB,QAAa,OAAO,CAAC,KAAK,CAAC,qBAAqB,CAAC,YAAY,CAAC,CAAC,CAWhG,CAAA;AAED;;;;;GAKG;AACH,eAAO,MAAM,4BAA4B,GACrC,YAAY,MAAM,EAClB,kBAAkB,MAAM,KACzB,OAAO,CAAC,qBAAqB,CAAC,YAAY,CAAC,CAY7C,CAAA;AAED;;;;;GAKG;AACH,eAAO,MAAM,wBAAwB,GAAI,kBAAkB,MAAM,KAAG,MAAkD,CAAA;AAEtH;;;;;;GAMG;AACH,eAAO,MAAM,4BAA4B,GAAU,YAAY,MAAM,EAAE,WAAW,MAAM,EAAE,eAAe,MAAM,kBA6B9G,CAAA;AAED;;;;;;GAMG;AACH,eAAO,MAAM,kBAAkB,GAC3B,YAAY,MAAM,EAClB,WAAW,MAAM,EACjB,eAAe,MAAM,EACrB,WAAU,OAAe,kBA4B5B,CAAA;AAED,eAAO,MAAM,wBAAwB,GACjC,YAAY,MAAM,EAClB,WAAW,MAAM,EACjB,MAAM,MAAM,EACZ,WAAU,OAAe,kBAyB5B,CAAA;AAED;;;;GAIG;AACH,eAAO,MAAM,YAAY,GAAU,YAAY,MAAM,EAAE,WAAW,MAAM,kBAWvE,CAAA;AAED;;;;;;GAMG;AACH,eAAO,MAAM,6BAA6B,GACtC,OAAO,MAAM,EACb,sBAAsB,OAAO,EAC7B,OAAO,aAAa,KACrB,OAAO,CAAC,KAAK,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,CAAC,SAAS,CAAC,YAAY,CAAC,CAYxD,CAAA;AAEd;;;;;;GAMG;AACH,eAAO,MAAM,oBAAoB,GAC7B,YAAY,MAAM,EAClB,WAAW,MAAM,KAClB,OAAO,CAAC,qBAAqB,CAAC,YAAY,CAAC,CAgB7C,CAAA;AAED;;;;GAIG;AACH,eAAO,MAAM,qBAAqB,GAAI,iBAAiB,eAAe,KAAG,eAKvE,CAAA;AAEF;;;GAGG;AACH,eAAO,MAAM,kBAAkB,QAAO,GAerC,CAAA;AAED;;;GAGG;AACH,eAAO,MAAM,eAAe,QAAO,GAkBlC,CAAA;AAED;;;GAGG;AACH,eAAO,MAAM,eAAe,QAAa,OAAO,CAAC,SAAS,CAYzD,CAAA;AAED;;;GAGG;AACH,eAAO,MAAM,eAAe,QAAa,OAAO,CAAC,SAAS,CAYzD,CAAA;AAED;;;;GAIG;AACH,eAAO,MAAM,gBAAgB,GAAU,WAAW,MAAM,KAAG,OAAO,CAAC,MAAM,CAQxE,CAAA"}
@@ -1,4 +1,5 @@
1
1
  import { CeremonyInputData, CircuitDocument, ETagWithPartNumber } from "@devtion/actions";
2
+ import type { Groth16Proof, PublicSignals } from "snarkjs";
2
3
  /**
3
4
  * Group all the necessary data needed for running the `setupCeremony` cloud function.
4
5
  * @typedef {Object} SetupCeremonyData
@@ -127,4 +128,59 @@ export type FinalizeCircuitData = {
127
128
  bucketName: string;
128
129
  beacon: string;
129
130
  };
131
+ /**
132
+ * Group all the necessary data needed for running the `bandadaValidateProof` cloud function.
133
+ * @typedef {Object} BandadaValidateProof
134
+ * @property {string} merkleTreeRoot - the merkle tree root of the group.
135
+ * @property {string} nullifierHash - the nullifier hash of the member.
136
+ * @property {string} externalNullifier - the external nullifier of the member.
137
+ * @property {PackedProof} proof - the packed proof generated on the client.
138
+ */
139
+ export type BandadaValidateProof = {
140
+ proof: Groth16Proof;
141
+ publicSignals: PublicSignals;
142
+ };
143
+ /**
144
+ * Define the return object of the function that verifies the Bandada membership and proof.
145
+ * @typedef {Object} VerifiedBandadaResponse
146
+ * @property {boolean} valid - true if the proof is valid and the user is a member of the group; otherwise false.
147
+ * @property {string} message - a message describing the result of the verification.
148
+ * @property {string} token - the custom access token.
149
+ */
150
+ export type VerifiedBandadaResponse = {
151
+ valid: boolean;
152
+ message: string;
153
+ token: string;
154
+ };
155
+ /**
156
+ * Define the check nonce object for the cloud function
157
+ * @typedef {Object} CheckNonceOfSIWEAddressRequest
158
+ * @property {string} auth0Token - token from the device flow authentication
159
+ */
160
+ export type CheckNonceOfSIWEAddressRequest = {
161
+ auth0Token: string;
162
+ };
163
+ /**
164
+ * Define the check nonce response object of the cloud function
165
+ * @typedef {Object} CheckNonceOfSIWEAddressResponse
166
+ * @property {boolean} valid - if the checking result was valid or not
167
+ * @property {string} message - informative message
168
+ * @property {string} token - token to sign in
169
+ */
170
+ export type CheckNonceOfSIWEAddressResponse = {
171
+ valid: boolean;
172
+ message?: string;
173
+ token?: string;
174
+ };
175
+ /**
176
+ * Define the response from auth0 /userinfo endpoint
177
+ *
178
+ */
179
+ export type Auth0UserInfo = {
180
+ sub: string;
181
+ nickname: string;
182
+ name: string;
183
+ picture: string;
184
+ updated_at: string;
185
+ };
130
186
  //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/types/index.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@devtion/backend",
3
- "version": "0.0.0-4088679",
3
+ "version": "0.0.0-477457c",
4
4
  "description": "MPC Phase 2 backend for Firebase services management",
5
5
  "repository": "git@github.com:privacy-scaling-explorations/p0tion.git",
6
6
  "homepage": "https://github.com/privacy-scaling-explorations/p0tion",
@@ -13,7 +13,7 @@
13
13
  },
14
14
  "types": "dist/types/types/index.d.ts",
15
15
  "engines": {
16
- "node": "16"
16
+ "node": "20"
17
17
  },
18
18
  "files": [
19
19
  "dist/",
@@ -32,8 +32,8 @@
32
32
  "circom"
33
33
  ],
34
34
  "scripts": {
35
- "build": "rimraf dist && rollup -c rollup.config.ts --configPlugin typescript",
36
- "build:watch": "rollup -c rollup.config.ts -w --configPlugin typescript",
35
+ "build": "rimraf dist && rollup -c rollup.config.ts --configPlugin typescript --bundleConfigAsCjs",
36
+ "build:watch": "rollup -c rollup.config.ts -w --configPlugin typescript --bundleConfigAsCjs",
37
37
  "firebase:login": "firebase login",
38
38
  "firebase:logout": "firebase logout",
39
39
  "firebase:init": "firebase init",
@@ -51,13 +51,13 @@
51
51
  },
52
52
  "devDependencies": {
53
53
  "@firebase/rules-unit-testing": "^2.0.7",
54
+ "@rollup/plugin-typescript": "^11.1.6",
54
55
  "@types/rollup-plugin-auto-external": "^2.0.2",
55
56
  "@types/uuid": "^9.0.1",
56
57
  "firebase-functions-test": "^3.1.0",
57
58
  "firebase-tools": "^12.0.0",
58
59
  "rollup-plugin-auto-external": "^2.0.0",
59
60
  "rollup-plugin-cleanup": "^3.2.1",
60
- "rollup-plugin-typescript2": "^0.34.1",
61
61
  "typescript": "^5.0.4"
62
62
  },
63
63
  "dependencies": {
@@ -67,6 +67,7 @@
67
67
  "@aws-sdk/client-ssm": "^3.357.0",
68
68
  "@aws-sdk/middleware-endpoint": "^3.329.0",
69
69
  "@aws-sdk/s3-request-presigner": "^3.329.0",
70
+ "@bandada/api-sdk": "^1.0.0-beta.1",
70
71
  "@devtion/actions": "latest",
71
72
  "blakejs": "^1.2.1",
72
73
  "dotenv": "^16.0.3",
@@ -76,7 +77,7 @@
76
77
  "html-entities": "^2.3.3",
77
78
  "rimraf": "^5.0.0",
78
79
  "rollup": "^3.21.6",
79
- "snarkjs": "^0.6.11",
80
+ "snarkjs": "0.7.3",
80
81
  "solc": "^0.8.19",
81
82
  "timer-node": "^5.0.7",
82
83
  "uuid": "^9.0.0",
@@ -85,5 +86,5 @@
85
86
  "publishConfig": {
86
87
  "access": "public"
87
88
  },
88
- "gitHead": "29b7f515737e345691adf023491fe9930fbe861a"
89
+ "gitHead": "a160aad10b1d03b9d4307a44aa00d13405767d90"
89
90
  }
@@ -0,0 +1,154 @@
1
+ import dotenv from "dotenv"
2
+ import * as functions from "firebase-functions"
3
+ import { ApiSdk } from "@bandada/api-sdk"
4
+ import { groth16 } from "snarkjs"
5
+ import { getAuth } from "firebase-admin/auth"
6
+ import admin from "firebase-admin"
7
+ import { BandadaValidateProof, VerifiedBandadaResponse } from "../types/index"
8
+
9
+ dotenv.config()
10
+
11
+ const { BANDADA_API_URL, BANDADA_GROUP_ID } = process.env
12
+
13
+ const bandadaApi = new ApiSdk(BANDADA_API_URL)
14
+
15
+ export const bandadaValidateProof = functions
16
+ .region("europe-west1")
17
+ .runWith({
18
+ memory: "1GB"
19
+ })
20
+ .https.onCall(async (data: BandadaValidateProof): Promise<VerifiedBandadaResponse> => {
21
+ const VKEY_DATA = {
22
+ protocol: "groth16",
23
+ curve: "bn128",
24
+ nPublic: 3,
25
+ vk_alpha_1: [
26
+ "20491192805390485299153009773594534940189261866228447918068658471970481763042",
27
+ "9383485363053290200918347156157836566562967994039712273449902621266178545958",
28
+ "1"
29
+ ],
30
+ vk_beta_2: [
31
+ [
32
+ "6375614351688725206403948262868962793625744043794305715222011528459656738731",
33
+ "4252822878758300859123897981450591353533073413197771768651442665752259397132"
34
+ ],
35
+ [
36
+ "10505242626370262277552901082094356697409835680220590971873171140371331206856",
37
+ "21847035105528745403288232691147584728191162732299865338377159692350059136679"
38
+ ],
39
+ ["1", "0"]
40
+ ],
41
+ vk_gamma_2: [
42
+ [
43
+ "10857046999023057135944570762232829481370756359578518086990519993285655852781",
44
+ "11559732032986387107991004021392285783925812861821192530917403151452391805634"
45
+ ],
46
+ [
47
+ "8495653923123431417604973247489272438418190587263600148770280649306958101930",
48
+ "4082367875863433681332203403145435568316851327593401208105741076214120093531"
49
+ ],
50
+ ["1", "0"]
51
+ ],
52
+ vk_delta_2: [
53
+ [
54
+ "3697618915467790705869942236922063775466274665053173890632463796679068973252",
55
+ "14948341351907992175709156460547989243732741534604949238422596319735704165658"
56
+ ],
57
+ [
58
+ "3028459181652799888716942141752307629938889957960373621898607910203491239368",
59
+ "11380736494786911280692284374675752681598754560757720296073023058533044108340"
60
+ ],
61
+ ["1", "0"]
62
+ ],
63
+ vk_alphabeta_12: [
64
+ [
65
+ [
66
+ "2029413683389138792403550203267699914886160938906632433982220835551125967885",
67
+ "21072700047562757817161031222997517981543347628379360635925549008442030252106"
68
+ ],
69
+ [
70
+ "5940354580057074848093997050200682056184807770593307860589430076672439820312",
71
+ "12156638873931618554171829126792193045421052652279363021382169897324752428276"
72
+ ],
73
+ [
74
+ "7898200236362823042373859371574133993780991612861777490112507062703164551277",
75
+ "7074218545237549455313236346927434013100842096812539264420499035217050630853"
76
+ ]
77
+ ],
78
+ [
79
+ [
80
+ "7077479683546002997211712695946002074877511277312570035766170199895071832130",
81
+ "10093483419865920389913245021038182291233451549023025229112148274109565435465"
82
+ ],
83
+ [
84
+ "4595479056700221319381530156280926371456704509942304414423590385166031118820",
85
+ "19831328484489333784475432780421641293929726139240675179672856274388269393268"
86
+ ],
87
+ [
88
+ "11934129596455521040620786944827826205713621633706285934057045369193958244500",
89
+ "8037395052364110730298837004334506829870972346962140206007064471173334027475"
90
+ ]
91
+ ]
92
+ ],
93
+ IC: [
94
+ [
95
+ "12951059800758687233303204819298121944551181861362200875212570257618182506154",
96
+ "5751958719396509176593242305268064754837298673622815112953832050159760501392",
97
+ "1"
98
+ ],
99
+ [
100
+ "9561588427935871983444704959674198910445823619407211599507208879011862515257",
101
+ "14576201570478094842467636169770180675293504492823217349086195663150934064643",
102
+ "1"
103
+ ],
104
+ [
105
+ "4811967233483727873912563574622036989372099129165459921963463310078093941559",
106
+ "1874883809855039536107616044787862082553628089593740724610117059083415551067",
107
+ "1"
108
+ ],
109
+ [
110
+ "12252730267779308452229639835051322390696643456253768618882001876621526827161",
111
+ "7899194018737016222260328309937800777948677569409898603827268776967707173231",
112
+ "1"
113
+ ]
114
+ ]
115
+ }
116
+ if (!BANDADA_GROUP_ID) throw new Error("BANDADA_GROUP_ID is not defined in .env")
117
+
118
+ const { proof, publicSignals } = data
119
+ const isCorrect = groth16.verify(VKEY_DATA, publicSignals, proof)
120
+ if (!isCorrect)
121
+ return {
122
+ valid: false,
123
+ message: "Invalid proof",
124
+ token: ""
125
+ }
126
+
127
+ const commitment = data.publicSignals[1]
128
+ const isMember = await bandadaApi.isGroupMember(BANDADA_GROUP_ID, commitment)
129
+ if (!isMember)
130
+ return {
131
+ valid: false,
132
+ message: "Not a member of the group",
133
+ token: ""
134
+ }
135
+ const auth = getAuth()
136
+ try {
137
+ await admin.auth().createUser({
138
+ uid: commitment
139
+ })
140
+ } catch (error: any) {
141
+ // if user already exist then just pass
142
+ if (error.code !== "auth/uid-already-exists") {
143
+ throw new Error(error)
144
+ }
145
+ }
146
+ const token = await auth.createCustomToken(commitment)
147
+ return {
148
+ valid: true,
149
+ message: "Valid proof and group member",
150
+ token
151
+ }
152
+ })
153
+
154
+ export default bandadaValidateProof
@@ -46,7 +46,7 @@ dotenv.config()
46
46
  export const startCeremony = functions
47
47
  .region("europe-west1")
48
48
  .runWith({
49
- memory: "512MB"
49
+ memory: "1GB"
50
50
  })
51
51
  .pubsub.schedule(`every 30 minutes`)
52
52
  .onRun(async () => {
@@ -71,7 +71,7 @@ export const startCeremony = functions
71
71
  export const stopCeremony = functions
72
72
  .region("europe-west1")
73
73
  .runWith({
74
- memory: "512MB"
74
+ memory: "1GB"
75
75
  })
76
76
  .pubsub.schedule(`every 30 minutes`)
77
77
  .onRun(async () => {
@@ -96,7 +96,7 @@ export const stopCeremony = functions
96
96
  export const setupCeremony = functions
97
97
  .region("europe-west1")
98
98
  .runWith({
99
- memory: "512MB"
99
+ memory: "1GB"
100
100
  })
101
101
  .https.onCall(async (data: SetupCeremonyData, context: functions.https.CallableContext): Promise<any> => {
102
102
  // Check if the user has the coordinator claim.
@@ -141,7 +141,9 @@ export const setupCeremony = functions
141
141
  let vmInstanceId: string = ""
142
142
 
143
143
  // Get a new circuit document.
144
- const circuitDoc = await firestore.collection(getCircuitsCollectionPath(ceremonyDoc.ref.id)).doc().get()
144
+ const ccp = getCircuitsCollectionPath(ceremonyDoc.ref.id)
145
+ printLog(`CircuitsCollectionPath = ${ccp}`, LogLevel.DEBUG)
146
+ const circuitDoc = await firestore.collection(ccp).doc().get()
145
147
 
146
148
  // Check if using the VM approach for contribution verification.
147
149
  if (circuit.verification.cfOrVm === CircuitContributionVerificationMechanism.VM) {
@@ -166,7 +168,11 @@ export const setupCeremony = functions
166
168
 
167
169
  // Upload the post-startup commands script file.
168
170
  printLog(`Uploading VM post-startup commands script file ${vmBootstrapScriptFilename}`, LogLevel.DEBUG)
169
- await uploadFileToBucketNoFile(bucketName, `circuits/${circuit.name!}/${vmBootstrapScriptFilename}`, vmCommands.join("\n"))
171
+ await uploadFileToBucketNoFile(
172
+ bucketName,
173
+ `circuits/${circuit.name!}/${vmBootstrapScriptFilename}`,
174
+ vmCommands.join("\n")
175
+ )
170
176
 
171
177
  // Compute the VM disk space requirement (in GB).
172
178
  const vmDiskSize = computeDiskSizeForVM(circuit.zKeySizeInBytes!, circuit.metadata?.pot!)
@@ -202,6 +208,7 @@ export const setupCeremony = functions
202
208
  // Encode circuit data.
203
209
  const encodedCircuit = htmlEncodeCircuitData(circuit)
204
210
 
211
+ printLog(`writing circuit data...`, LogLevel.DEBUG)
205
212
  // Prepare tx to write circuit data.
206
213
  batch.create(circuitDoc.ref, {
207
214
  ...encodedCircuit,
@@ -209,6 +216,7 @@ export const setupCeremony = functions
209
216
  })
210
217
  }
211
218
 
219
+ printLog(`Done handling circuits...`, LogLevel.DEBUG)
212
220
  // Send txs in a batch (to avoid race conditions).
213
221
  await batch.commit()
214
222
 
@@ -224,7 +232,7 @@ export const setupCeremony = functions
224
232
  export const initEmptyWaitingQueueForCircuit = functions
225
233
  .region("europe-west1")
226
234
  .runWith({
227
- memory: "512MB"
235
+ memory: "1GB"
228
236
  })
229
237
  .firestore.document(
230
238
  `/${commonTerms.collections.ceremonies.name}/{ceremony}/${commonTerms.collections.circuits.name}/{circuit}`
@@ -269,7 +277,7 @@ export const initEmptyWaitingQueueForCircuit = functions
269
277
  export const finalizeCeremony = functions
270
278
  .region("europe-west1")
271
279
  .runWith({
272
- memory: "512MB"
280
+ memory: "1GB"
273
281
  })
274
282
  .https.onCall(async (data: { ceremonyId: string }, context: functions.https.CallableContext): Promise<any> => {
275
283
  if (!context.auth || !context.auth.token.coordinator) logAndThrowError(COMMON_ERRORS.CM_NOT_COORDINATOR_ROLE)
@@ -294,7 +302,7 @@ export const finalizeCeremony = functions
294
302
  const circuits = await getCeremonyCircuits(ceremonyId)
295
303
 
296
304
  // Get final contribution for each circuit.
297
- // nb. the `getFinalContributionDocument` checks the existance of the final contribution document (if not present, throws).
305
+ // nb. the `getFinalContributionDocument` checks the existence of the final contribution document (if not present, throws).
298
306
  // Therefore, we just need to call the method without taking any data to verify the pre-condition of having already computed
299
307
  // the final contributions for each ceremony circuit.
300
308
  for await (const circuit of circuits) await getFinalContribution(ceremonyId, circuit.id)