@prosopo/provider 2.1.0 → 2.1.1

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 (46) hide show
  1. package/coverage/base.css +224 -0
  2. package/coverage/block-navigation.js +87 -0
  3. package/coverage/clover.xml +6 -0
  4. package/coverage/coverage-final.json +1 -0
  5. package/coverage/favicon.png +0 -0
  6. package/coverage/index.html +101 -0
  7. package/coverage/prettify.css +1 -0
  8. package/coverage/prettify.js +2 -0
  9. package/coverage/sort-arrow-sprite.png +0 -0
  10. package/coverage/sorter.js +196 -0
  11. package/dist/api/admin.d.ts.map +1 -1
  12. package/dist/api/admin.js +19 -8
  13. package/dist/api/admin.js.map +1 -1
  14. package/dist/api/authMiddleware.d.ts +2 -3
  15. package/dist/api/authMiddleware.d.ts.map +1 -1
  16. package/dist/api/authMiddleware.js +16 -9
  17. package/dist/api/authMiddleware.js.map +1 -1
  18. package/dist/api/captcha.d.ts.map +1 -1
  19. package/dist/api/captcha.js +50 -23
  20. package/dist/api/captcha.js.map +1 -1
  21. package/dist/cjs/api/admin.cjs +17 -7
  22. package/dist/cjs/api/authMiddleware.cjs +16 -9
  23. package/dist/cjs/api/captcha.cjs +51 -24
  24. package/dist/cjs/tasks/client/clientTasks.cjs +7 -0
  25. package/dist/cjs/tasks/imgCaptcha/imgCaptchaTasks.cjs +1 -0
  26. package/dist/cjs/tasks/powCaptcha/powTasks.cjs +1 -0
  27. package/dist/tasks/client/clientTasks.d.ts +1 -0
  28. package/dist/tasks/client/clientTasks.d.ts.map +1 -1
  29. package/dist/tasks/client/clientTasks.js +7 -0
  30. package/dist/tasks/client/clientTasks.js.map +1 -1
  31. package/dist/tasks/imgCaptcha/imgCaptchaTasks.d.ts.map +1 -1
  32. package/dist/tasks/imgCaptcha/imgCaptchaTasks.js.map +1 -1
  33. package/dist/tasks/powCaptcha/powTasks.d.ts.map +1 -1
  34. package/dist/tasks/powCaptcha/powTasks.js.map +1 -1
  35. package/dist/tests/integration/imgCaptcha.integration.test.js +25 -7
  36. package/dist/tests/integration/imgCaptcha.integration.test.js.map +1 -1
  37. package/dist/tests/integration/powCaptcha.integration.test.js +62 -6
  38. package/dist/tests/integration/powCaptcha.integration.test.js.map +1 -1
  39. package/dist/tests/integration/registerSitekey.d.ts +2 -0
  40. package/dist/tests/integration/registerSitekey.d.ts.map +1 -0
  41. package/dist/tests/integration/registerSitekey.js +17 -0
  42. package/dist/tests/integration/registerSitekey.js.map +1 -0
  43. package/dist/tests/unit/api/authMiddleware.unit.test.js +6 -6
  44. package/dist/tests/unit/api/authMiddleware.unit.test.js.map +1 -1
  45. package/package.json +12 -14
  46. package/vite.test.config.ts +2 -16
package/dist/api/admin.js CHANGED
@@ -1,15 +1,12 @@
1
- import { AdminApiPaths } from "@prosopo/types";
1
+ import { logError } from "@prosopo/common";
2
+ import { AdminApiPaths, VerifyPowCaptchaSolutionBody, } from "@prosopo/types";
2
3
  import { Router } from "express";
3
4
  import { Tasks } from "../index.js";
4
5
  import { authMiddleware } from "./authMiddleware.js";
5
- const apiBatchCommitConfig = {
6
- interval: 0,
7
- maxBatchExtrinsicPercentage: 59,
8
- };
9
6
  export function prosopoAdminRouter(env) {
10
7
  const router = Router();
11
8
  const tasks = new Tasks(env);
12
- router.use(authMiddleware(tasks, env));
9
+ router.use(authMiddleware(env));
13
10
  router.post(AdminApiPaths.UpdateDataset, async (req, res, next) => {
14
11
  try {
15
12
  const result = await tasks.datasetManager.providerSetDataset(req.body);
@@ -17,8 +14,22 @@ export function prosopoAdminRouter(env) {
17
14
  res.status(200).send(result);
18
15
  }
19
16
  catch (err) {
20
- console.error(err);
21
- res.status(500).send(err);
17
+ logError(err, tasks.logger);
18
+ res.status(500).send("An internal server error occurred.");
19
+ }
20
+ });
21
+ router.post(AdminApiPaths.SiteKeyRegister, async (req, res, next) => {
22
+ try {
23
+ const parsed = VerifyPowCaptchaSolutionBody.parse(req.body);
24
+ await tasks.clientTaskManager.registerSiteKey(parsed.siteKey);
25
+ const response = {
26
+ status: "success",
27
+ };
28
+ res.json(response);
29
+ }
30
+ catch (err) {
31
+ logError(err, tasks.logger);
32
+ res.status(500).send("An internal server error occurred.");
22
33
  }
23
34
  });
24
35
  return router;
@@ -1 +1 @@
1
- {"version":3,"file":"admin.js","sourceRoot":"","sources":["../../src/api/admin.ts"],"names":[],"mappings":"AAaA,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAE/C,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AACjC,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AACpC,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAGrD,MAAM,oBAAoB,GAAG;IAC5B,QAAQ,EAAE,CAAC;IACX,2BAA2B,EAAE,EAAE;CAC/B,CAAC;AAEF,MAAM,UAAU,kBAAkB,CAAC,GAAwB;IAC1D,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC;IACxB,MAAM,KAAK,GAAG,IAAI,KAAK,CAAC,GAAG,CAAC,CAAC;IAG7B,MAAM,CAAC,GAAG,CAAC,cAAc,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC;IAEvC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,aAAa,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;QACjE,IAAI,CAAC;YACJ,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,cAAc,CAAC,kBAAkB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAEvE,OAAO,CAAC,IAAI,CAAC,4BAA4B,MAAM,EAAE,CAAC,CAAC;YACnD,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC9B,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACd,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YACnB,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC3B,CAAC;IACF,CAAC,CAAC,CAAC;IAEH,OAAO,MAAM,CAAC;AACf,CAAC"}
1
+ {"version":3,"file":"admin.js","sourceRoot":"","sources":["../../src/api/admin.ts"],"names":[],"mappings":"AAAA,OAAO,EAAU,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAcnD,OAAO,EACN,aAAa,EAEb,4BAA4B,GAC5B,MAAM,gBAAgB,CAAC;AAExB,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AACjC,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AACpC,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAErD,MAAM,UAAU,kBAAkB,CAAC,GAAwB;IAC1D,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC;IACxB,MAAM,KAAK,GAAG,IAAI,KAAK,CAAC,GAAG,CAAC,CAAC;IAG7B,MAAM,CAAC,GAAG,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC;IAEhC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,aAAa,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;QACjE,IAAI,CAAC;YACJ,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,cAAc,CAAC,kBAAkB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAEvE,OAAO,CAAC,IAAI,CAAC,4BAA4B,MAAM,EAAE,CAAC,CAAC;YACnD,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC9B,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACd,QAAQ,CAAC,GAAG,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;YAC5B,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,oCAAoC,CAAC,CAAC;QAC5D,CAAC;IACF,CAAC,CAAC,CAAC;IAEH,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,eAAe,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;QACnE,IAAI,CAAC;YACJ,MAAM,MAAM,GAAG,4BAA4B,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAC5D,MAAM,KAAK,CAAC,iBAAiB,CAAC,eAAe,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;YAC9D,MAAM,QAAQ,GAAgB;gBAC7B,MAAM,EAAE,SAAS;aACjB,CAAC;YACF,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACpB,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACd,QAAQ,CAAC,GAAG,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;YAC5B,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,oCAAoC,CAAC,CAAC;QAC5D,CAAC;IACF,CAAC,CAAC,CAAC;IAEH,OAAO,MAAM,CAAC;AACf,CAAC"}
@@ -1,7 +1,6 @@
1
1
  import type { KeyringPair } from "@polkadot/keyring/types";
2
2
  import type { ProviderEnvironment } from "@prosopo/types-env";
3
3
  import type { NextFunction, Request, Response } from "express";
4
- import type { Tasks } from "../index.js";
5
- export declare const authMiddleware: (tasks: Tasks, env: ProviderEnvironment) => (req: Request, res: Response, next: NextFunction) => Promise<void>;
6
- export declare const verifySignature: (signature: string, blockNumber: string, pair: KeyringPair) => void;
4
+ export declare const authMiddleware: (env: ProviderEnvironment) => (req: Request, res: Response, next: NextFunction) => Promise<void>;
5
+ export declare const verifySignature: (signature: string, timestamp: string, pair: KeyringPair) => void;
7
6
  //# sourceMappingURL=authMiddleware.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"authMiddleware.d.ts","sourceRoot":"","sources":["../../src/api/authMiddleware.ts"],"names":[],"mappings":"AAaA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAG3D,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAC9D,OAAO,KAAK,EAAE,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAC/D,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AAEzC,eAAO,MAAM,cAAc,UAAW,KAAK,OAAO,mBAAmB,WACjD,OAAO,OAAO,QAAQ,QAAQ,YAAY,kBAiB7D,CAAC;AA+BF,eAAO,MAAM,eAAe,cAChB,MAAM,eACJ,MAAM,QACb,WAAW,SASjB,CAAC"}
1
+ {"version":3,"file":"authMiddleware.d.ts","sourceRoot":"","sources":["../../src/api/authMiddleware.ts"],"names":[],"mappings":"AAaA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAG3D,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAC9D,OAAO,KAAK,EAAE,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAG/D,eAAO,MAAM,cAAc,QAAS,mBAAmB,WACnC,OAAO,OAAO,QAAQ,QAAQ,YAAY,kBAiB7D,CAAC;AAwCF,eAAO,MAAM,eAAe,cAChB,MAAM,aACN,MAAM,QACX,WAAW,SASjB,CAAC"}
@@ -1,14 +1,14 @@
1
1
  import { hexToU8a, isHex } from "@polkadot/util";
2
2
  import { ProsopoApiError, ProsopoEnvError } from "@prosopo/common";
3
- export const authMiddleware = (tasks, env) => {
3
+ export const authMiddleware = (env) => {
4
4
  return async (req, res, next) => {
5
5
  try {
6
- const { signature, blocknumber } = extractHeaders(req);
6
+ const { signature, timestamp } = extractHeaders(req);
7
7
  if (!env.pair) {
8
8
  throw new ProsopoEnvError("CONTRACT.CANNOT_FIND_KEYPAIR");
9
9
  }
10
10
  verifyEnvironmentKeyPair(env);
11
- verifySignature(signature, blocknumber, env.pair);
11
+ verifySignature(signature, timestamp, env.pair);
12
12
  next();
13
13
  }
14
14
  catch (err) {
@@ -19,29 +19,36 @@ export const authMiddleware = (tasks, env) => {
19
19
  };
20
20
  const extractHeaders = (req) => {
21
21
  const signature = req.headers.signature;
22
- const blocknumber = req.headers.blocknumber;
23
- if (!signature || !blocknumber) {
22
+ const timestamp = req.headers.timestamp;
23
+ if (!signature || !timestamp) {
24
24
  throw new ProsopoApiError("CONTRACT.INVALID_DATA_FORMAT", {
25
25
  context: { error: "Missing signature or block number", code: 400 },
26
26
  });
27
27
  }
28
28
  if (Array.isArray(signature) ||
29
- Array.isArray(blocknumber) ||
29
+ Array.isArray(timestamp) ||
30
30
  !isHex(signature)) {
31
31
  throw new ProsopoApiError("CONTRACT.INVALID_DATA_FORMAT", {
32
32
  context: { error: "Invalid header format", code: 400 },
33
33
  });
34
34
  }
35
- return { signature, blocknumber };
35
+ const now = new Date().getTime();
36
+ const ts = Number.parseInt(timestamp, 10);
37
+ if (now - ts > 300000) {
38
+ throw new ProsopoApiError("GENERAL.INVALID_TIMESTAMP", {
39
+ context: { error: "Timestamp is too old", code: 400 },
40
+ });
41
+ }
42
+ return { signature, timestamp };
36
43
  };
37
44
  const verifyEnvironmentKeyPair = (env) => {
38
45
  if (!env.pair) {
39
46
  throw new ProsopoEnvError("CONTRACT.CANNOT_FIND_KEYPAIR");
40
47
  }
41
48
  };
42
- export const verifySignature = (signature, blockNumber, pair) => {
49
+ export const verifySignature = (signature, timestamp, pair) => {
43
50
  const u8Sig = hexToU8a(signature);
44
- if (!pair.verify(blockNumber, u8Sig, pair.publicKey)) {
51
+ if (!pair.verify(timestamp, u8Sig, pair.publicKey)) {
45
52
  throw new ProsopoApiError("GENERAL.INVALID_SIGNATURE", {
46
53
  context: { error: "Signature verification failed", code: 401 },
47
54
  });
@@ -1 +1 @@
1
- {"version":3,"file":"authMiddleware.js","sourceRoot":"","sources":["../../src/api/authMiddleware.ts"],"names":[],"mappings":"AAcA,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAKnE,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,KAAY,EAAE,GAAwB,EAAE,EAAE;IACxE,OAAO,KAAK,EAAE,GAAY,EAAE,GAAa,EAAE,IAAkB,EAAE,EAAE;QAChE,IAAI,CAAC;YACJ,MAAM,EAAE,SAAS,EAAE,WAAW,EAAE,GAAG,cAAc,CAAC,GAAG,CAAC,CAAC;YAEvD,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC;gBACf,MAAM,IAAI,eAAe,CAAC,8BAA8B,CAAC,CAAC;YAC3D,CAAC;YAED,wBAAwB,CAAC,GAAG,CAAC,CAAC;YAC9B,eAAe,CAAC,SAAS,EAAE,WAAW,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC;YAElD,IAAI,EAAE,CAAC;QACR,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACd,OAAO,CAAC,KAAK,CAAC,wBAAwB,EAAE,GAAG,CAAC,CAAC;YAC7C,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,cAAc,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,CAAC;QAC/D,CAAC;IACF,CAAC,CAAC;AACH,CAAC,CAAC;AAEF,MAAM,cAAc,GAAG,CAAC,GAAY,EAAE,EAAE;IACvC,MAAM,SAAS,GAAG,GAAG,CAAC,OAAO,CAAC,SAAmB,CAAC;IAClD,MAAM,WAAW,GAAG,GAAG,CAAC,OAAO,CAAC,WAAqB,CAAC;IAEtD,IAAI,CAAC,SAAS,IAAI,CAAC,WAAW,EAAE,CAAC;QAChC,MAAM,IAAI,eAAe,CAAC,8BAA8B,EAAE;YACzD,OAAO,EAAE,EAAE,KAAK,EAAE,mCAAmC,EAAE,IAAI,EAAE,GAAG,EAAE;SAClE,CAAC,CAAC;IACJ,CAAC;IAED,IACC,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC;QACxB,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC;QAC1B,CAAC,KAAK,CAAC,SAAS,CAAC,EAChB,CAAC;QACF,MAAM,IAAI,eAAe,CAAC,8BAA8B,EAAE;YACzD,OAAO,EAAE,EAAE,KAAK,EAAE,uBAAuB,EAAE,IAAI,EAAE,GAAG,EAAE;SACtD,CAAC,CAAC;IACJ,CAAC;IAED,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,CAAC;AACnC,CAAC,CAAC;AAEF,MAAM,wBAAwB,GAAG,CAAC,GAAwB,EAAE,EAAE;IAC7D,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC;QACf,MAAM,IAAI,eAAe,CAAC,8BAA8B,CAAC,CAAC;IAC3D,CAAC;AACF,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,eAAe,GAAG,CAC9B,SAAiB,EACjB,WAAmB,EACnB,IAAiB,EAChB,EAAE;IACH,MAAM,KAAK,GAAG,QAAQ,CAAC,SAAS,CAAC,CAAC;IAElC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC;QACtD,MAAM,IAAI,eAAe,CAAC,2BAA2B,EAAE;YACtD,OAAO,EAAE,EAAE,KAAK,EAAE,+BAA+B,EAAE,IAAI,EAAE,GAAG,EAAE;SAC9D,CAAC,CAAC;IACJ,CAAC;AACF,CAAC,CAAC"}
1
+ {"version":3,"file":"authMiddleware.js","sourceRoot":"","sources":["../../src/api/authMiddleware.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"captcha.d.ts","sourceRoot":"","sources":["../../src/api/captcha.ts"],"names":[],"mappings":"AAgCA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAE9D,OAAgB,EAAE,KAAK,MAAM,EAAE,MAAM,SAAS,CAAC;AAwB/C,wBAAgB,aAAa,CAAC,GAAG,EAAE,mBAAmB,GAAG,MAAM,CAyN9D"}
1
+ {"version":3,"file":"captcha.d.ts","sourceRoot":"","sources":["../../src/api/captcha.ts"],"names":[],"mappings":"AAgCA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAE9D,OAAgB,EAAE,KAAK,MAAM,EAAE,MAAM,SAAS,CAAC;AAY/C,wBAAgB,aAAa,CAAC,GAAG,EAAE,mBAAmB,GAAG,MAAM,CAwQ9D"}
@@ -2,27 +2,30 @@ import { validateAddress } from "@polkadot/util-crypto/address";
2
2
  import { ProsopoApiError } from "@prosopo/common";
3
3
  import { parseCaptchaAssets } from "@prosopo/datasets";
4
4
  import { ApiParams, ApiPaths, CaptchaRequestBody, CaptchaSolutionBody, GetPowCaptchaChallengeRequestBody, SubmitPowCaptchaSolutionBody, } from "@prosopo/types";
5
- import { version } from "@prosopo/util";
5
+ import { flatten, version } from "@prosopo/util";
6
6
  import express from "express";
7
7
  import { Tasks } from "../tasks/tasks.js";
8
8
  import { handleErrors } from "./errorHandler.js";
9
9
  const NO_IP_ADDRESS = "NO_IP_ADDRESS";
10
- const flattenHeaders = (headers) => {
11
- return Object.fromEntries(Object.entries(headers).map(([key, value]) => [
12
- key,
13
- Array.isArray(value) ? value.join(",") : value || "",
14
- ]));
15
- };
16
10
  export function prosopoRouter(env) {
17
11
  const router = express.Router();
18
12
  const tasks = new Tasks(env);
19
13
  const GetImageCaptchaChallengePath = `${ApiPaths.GetImageCaptchaChallenge}/:${ApiParams.datasetId}/:${ApiParams.user}/:${ApiParams.dapp}`;
20
14
  router.get(GetImageCaptchaChallengePath, async (req, res, next) => {
21
15
  try {
22
- const { datasetId, user } = CaptchaRequestBody.parse(req.params);
16
+ const { datasetId, user, dapp } = CaptchaRequestBody.parse(req.params);
23
17
  validateAddress(user, false, 42);
24
- const taskData = await tasks.imgCaptchaManager.getRandomCaptchasAndRequestHash(datasetId, user, req.ip || NO_IP_ADDRESS, flattenHeaders(req.headers));
18
+ validateAddress(dapp, false, 42);
19
+ const clientRecord = await tasks.db.getClientRecord(dapp);
20
+ if (!clientRecord) {
21
+ return res.json({
22
+ error: req.i18n.t("API.SITE_KEY_NOT_REGISTERED"),
23
+ code: 200,
24
+ });
25
+ }
26
+ const taskData = await tasks.imgCaptchaManager.getRandomCaptchasAndRequestHash(datasetId, user, req.ip || NO_IP_ADDRESS, flatten(req.headers, ","));
25
27
  const captchaResponse = {
28
+ [ApiParams.status]: "ok",
26
29
  [ApiParams.captchas]: taskData.captchas.map((captcha) => ({
27
30
  ...captcha,
28
31
  items: captcha.items.map((item) => parseCaptchaAssets(item, env.assetsResolver)),
@@ -55,7 +58,14 @@ export function prosopoRouter(env) {
55
58
  }));
56
59
  }
57
60
  try {
58
- const result = await tasks.imgCaptchaManager.dappUserSolution(parsed[ApiParams.user], parsed[ApiParams.dapp], parsed[ApiParams.requestHash], parsed[ApiParams.captchas], parsed[ApiParams.signature].user.requestHash, Number.parseInt(parsed[ApiParams.timestamp]), parsed[ApiParams.signature].provider.requestHash, req.ip || NO_IP_ADDRESS, flattenHeaders(req.headers));
61
+ const clientRecord = await tasks.db.getClientRecord(parsed.dapp);
62
+ if (!clientRecord) {
63
+ return res.json({
64
+ error: req.i18n.t("API.SITE_KEY_NOT_REGISTERED"),
65
+ code: 200,
66
+ });
67
+ }
68
+ const result = await tasks.imgCaptchaManager.dappUserSolution(parsed[ApiParams.user], parsed[ApiParams.dapp], parsed[ApiParams.requestHash], parsed[ApiParams.captchas], parsed[ApiParams.signature].user.requestHash, Number.parseInt(parsed[ApiParams.timestamp]), parsed[ApiParams.signature].provider.requestHash, req.ip || NO_IP_ADDRESS, flatten(req.headers, ","));
59
69
  const returnValue = {
60
70
  status: req.i18n.t(result.verified ? "API.CAPTCHA_PASSED" : "API.CAPTCHA_FAILED"),
61
71
  ...result,
@@ -72,25 +82,35 @@ export function prosopoRouter(env) {
72
82
  router.post(ApiPaths.GetPowCaptchaChallenge, async (req, res, next) => {
73
83
  try {
74
84
  const { user, dapp } = GetPowCaptchaChallengeRequestBody.parse(req.body);
85
+ validateAddress(user, false, 42);
86
+ validateAddress(dapp, false, 42);
87
+ const clientRecord = await tasks.db.getClientRecord(dapp);
88
+ if (!clientRecord) {
89
+ return res.json({
90
+ error: req.i18n.t("API.SITE_KEY_NOT_REGISTERED"),
91
+ code: 200,
92
+ });
93
+ }
75
94
  const origin = req.headers.origin;
76
95
  if (!origin) {
77
- throw new ProsopoApiError("API.BAD_REQUEST", {
78
- context: { code: 400, error: "origin header not found" },
79
- });
96
+ return next(new ProsopoApiError("API.BAD_REQUEST", {
97
+ context: { error: "origin header not found", code: 400 },
98
+ }));
80
99
  }
81
100
  const challenge = await tasks.powCaptchaManager.getPowCaptchaChallenge(user, dapp, origin);
82
101
  await tasks.db.storePowCaptchaRecord(challenge.challenge, {
83
102
  requestedAtTimestamp: challenge.requestedAtTimestamp,
84
103
  userAccount: user,
85
104
  dappAccount: dapp,
86
- }, challenge.difficulty, challenge.providerSignature, req.ip || NO_IP_ADDRESS, flattenHeaders(req.headers));
105
+ }, challenge.difficulty, challenge.providerSignature, req.ip || NO_IP_ADDRESS, flatten(req.headers, ","));
87
106
  const getPowCaptchaResponse = {
88
- challenge: challenge.challenge,
89
- difficulty: challenge.difficulty,
90
- timestamp: challenge.requestedAtTimestamp.toString(),
91
- signature: {
92
- provider: {
93
- challenge: challenge.providerSignature,
107
+ [ApiParams.status]: "ok",
108
+ [ApiParams.challenge]: challenge.challenge,
109
+ [ApiParams.difficulty]: challenge.difficulty,
110
+ [ApiParams.timestamp]: challenge.requestedAtTimestamp.toString(),
111
+ [ApiParams.signature]: {
112
+ [ApiParams.provider]: {
113
+ [ApiParams.challenge]: challenge.providerSignature,
94
114
  },
95
115
  },
96
116
  };
@@ -105,9 +125,16 @@ export function prosopoRouter(env) {
105
125
  });
106
126
  router.post(ApiPaths.SubmitPowCaptchaSolution, async (req, res, next) => {
107
127
  try {
108
- const { challenge, difficulty, signature, nonce, verifiedTimeout } = SubmitPowCaptchaSolutionBody.parse(req.body);
109
- const verified = await tasks.powCaptchaManager.verifyPowCaptchaSolution(challenge, difficulty, signature.provider.challenge, nonce, verifiedTimeout, signature.user.timestamp, req.ip || NO_IP_ADDRESS, flattenHeaders(req.headers));
110
- const response = { verified };
128
+ const { challenge, difficulty, signature, nonce, verifiedTimeout, dapp } = SubmitPowCaptchaSolutionBody.parse(req.body);
129
+ const clientRecord = await tasks.db.getClientRecord(dapp);
130
+ if (!clientRecord) {
131
+ return res.json({
132
+ error: req.i18n.t("API.SITE_KEY_NOT_REGISTERED"),
133
+ code: 200,
134
+ });
135
+ }
136
+ const verified = await tasks.powCaptchaManager.verifyPowCaptchaSolution(challenge, difficulty, signature.provider.challenge, nonce, verifiedTimeout, signature.user.timestamp, req.ip || NO_IP_ADDRESS, flatten(req.headers, ","));
137
+ const response = { status: "ok", verified };
111
138
  return res.json(response);
112
139
  }
113
140
  catch (err) {
@@ -1 +1 @@
1
- {"version":3,"file":"captcha.js","sourceRoot":"","sources":["../../src/api/captcha.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"captcha.js","sourceRoot":"","sources":["../../src/api/captcha.ts"],"names":[],"mappings":"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"}
@@ -1,26 +1,36 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const common = require("@prosopo/common");
3
4
  const types = require("@prosopo/types");
4
5
  const express = require("express");
5
6
  require("../index.cjs");
6
7
  const authMiddleware = require("./authMiddleware.cjs");
7
8
  const tasks = require("../tasks/tasks.cjs");
8
- const apiBatchCommitConfig = {
9
- interval: 0,
10
- maxBatchExtrinsicPercentage: 59
11
- };
12
9
  function prosopoAdminRouter(env) {
13
10
  const router = express.Router();
14
11
  const tasks$1 = new tasks.Tasks(env);
15
- router.use(authMiddleware.authMiddleware(tasks$1, env));
12
+ router.use(authMiddleware.authMiddleware(env));
16
13
  router.post(types.AdminApiPaths.UpdateDataset, async (req, res, next) => {
17
14
  try {
18
15
  const result = await tasks$1.datasetManager.providerSetDataset(req.body);
19
16
  console.info(`Dataset update complete: ${result}`);
20
17
  res.status(200).send(result);
21
18
  } catch (err) {
22
- console.error(err);
23
- res.status(500).send(err);
19
+ common.logError(err, tasks$1.logger);
20
+ res.status(500).send("An internal server error occurred.");
21
+ }
22
+ });
23
+ router.post(types.AdminApiPaths.SiteKeyRegister, async (req, res, next) => {
24
+ try {
25
+ const parsed = types.VerifyPowCaptchaSolutionBody.parse(req.body);
26
+ await tasks$1.clientTaskManager.registerSiteKey(parsed.siteKey);
27
+ const response = {
28
+ status: "success"
29
+ };
30
+ res.json(response);
31
+ } catch (err) {
32
+ common.logError(err, tasks$1.logger);
33
+ res.status(500).send("An internal server error occurred.");
24
34
  }
25
35
  });
26
36
  return router;
@@ -2,15 +2,15 @@
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const util = require("@polkadot/util");
4
4
  const common = require("@prosopo/common");
5
- const authMiddleware = (tasks, env) => {
5
+ const authMiddleware = (env) => {
6
6
  return async (req, res, next) => {
7
7
  try {
8
- const { signature, blocknumber } = extractHeaders(req);
8
+ const { signature, timestamp } = extractHeaders(req);
9
9
  if (!env.pair) {
10
10
  throw new common.ProsopoEnvError("CONTRACT.CANNOT_FIND_KEYPAIR");
11
11
  }
12
12
  verifyEnvironmentKeyPair(env);
13
- verifySignature(signature, blocknumber, env.pair);
13
+ verifySignature(signature, timestamp, env.pair);
14
14
  next();
15
15
  } catch (err) {
16
16
  console.error("Auth Middleware Error:", err);
@@ -20,27 +20,34 @@ const authMiddleware = (tasks, env) => {
20
20
  };
21
21
  const extractHeaders = (req) => {
22
22
  const signature = req.headers.signature;
23
- const blocknumber = req.headers.blocknumber;
24
- if (!signature || !blocknumber) {
23
+ const timestamp = req.headers.timestamp;
24
+ if (!signature || !timestamp) {
25
25
  throw new common.ProsopoApiError("CONTRACT.INVALID_DATA_FORMAT", {
26
26
  context: { error: "Missing signature or block number", code: 400 }
27
27
  });
28
28
  }
29
- if (Array.isArray(signature) || Array.isArray(blocknumber) || !util.isHex(signature)) {
29
+ if (Array.isArray(signature) || Array.isArray(timestamp) || !util.isHex(signature)) {
30
30
  throw new common.ProsopoApiError("CONTRACT.INVALID_DATA_FORMAT", {
31
31
  context: { error: "Invalid header format", code: 400 }
32
32
  });
33
33
  }
34
- return { signature, blocknumber };
34
+ const now = (/* @__PURE__ */ new Date()).getTime();
35
+ const ts = Number.parseInt(timestamp, 10);
36
+ if (now - ts > 3e5) {
37
+ throw new common.ProsopoApiError("GENERAL.INVALID_TIMESTAMP", {
38
+ context: { error: "Timestamp is too old", code: 400 }
39
+ });
40
+ }
41
+ return { signature, timestamp };
35
42
  };
36
43
  const verifyEnvironmentKeyPair = (env) => {
37
44
  if (!env.pair) {
38
45
  throw new common.ProsopoEnvError("CONTRACT.CANNOT_FIND_KEYPAIR");
39
46
  }
40
47
  };
41
- const verifySignature = (signature, blockNumber, pair) => {
48
+ const verifySignature = (signature, timestamp, pair) => {
42
49
  const u8Sig = util.hexToU8a(signature);
43
- if (!pair.verify(blockNumber, u8Sig, pair.publicKey)) {
50
+ if (!pair.verify(timestamp, u8Sig, pair.publicKey)) {
44
51
  throw new common.ProsopoApiError("GENERAL.INVALID_SIGNATURE", {
45
52
  context: { error: "Signature verification failed", code: 401 }
46
53
  });
@@ -9,29 +9,30 @@ const express = require("express");
9
9
  const tasks = require("../tasks/tasks.cjs");
10
10
  const errorHandler = require("./errorHandler.cjs");
11
11
  const NO_IP_ADDRESS = "NO_IP_ADDRESS";
12
- const flattenHeaders = (headers) => {
13
- return Object.fromEntries(
14
- Object.entries(headers).map(([key, value]) => [
15
- key,
16
- Array.isArray(value) ? value.join(",") : value || ""
17
- ])
18
- );
19
- };
20
12
  function prosopoRouter(env) {
21
13
  const router = express.Router();
22
14
  const tasks$1 = new tasks.Tasks(env);
23
15
  const GetImageCaptchaChallengePath = `${types.ApiPaths.GetImageCaptchaChallenge}/:${types.ApiParams.datasetId}/:${types.ApiParams.user}/:${types.ApiParams.dapp}`;
24
16
  router.get(GetImageCaptchaChallengePath, async (req, res, next) => {
25
17
  try {
26
- const { datasetId, user } = types.CaptchaRequestBody.parse(req.params);
18
+ const { datasetId, user, dapp } = types.CaptchaRequestBody.parse(req.params);
27
19
  address.validateAddress(user, false, 42);
20
+ address.validateAddress(dapp, false, 42);
21
+ const clientRecord = await tasks$1.db.getClientRecord(dapp);
22
+ if (!clientRecord) {
23
+ return res.json({
24
+ error: req.i18n.t("API.SITE_KEY_NOT_REGISTERED"),
25
+ code: 200
26
+ });
27
+ }
28
28
  const taskData = await tasks$1.imgCaptchaManager.getRandomCaptchasAndRequestHash(
29
29
  datasetId,
30
30
  user,
31
31
  req.ip || NO_IP_ADDRESS,
32
- flattenHeaders(req.headers)
32
+ util.flatten(req.headers, ",")
33
33
  );
34
34
  const captchaResponse = {
35
+ [types.ApiParams.status]: "ok",
35
36
  [types.ApiParams.captchas]: taskData.captchas.map((captcha) => ({
36
37
  ...captcha,
37
38
  items: captcha.items.map(
@@ -68,6 +69,13 @@ function prosopoRouter(env) {
68
69
  );
69
70
  }
70
71
  try {
72
+ const clientRecord = await tasks$1.db.getClientRecord(parsed.dapp);
73
+ if (!clientRecord) {
74
+ return res.json({
75
+ error: req.i18n.t("API.SITE_KEY_NOT_REGISTERED"),
76
+ code: 200
77
+ });
78
+ }
71
79
  const result = await tasks$1.imgCaptchaManager.dappUserSolution(
72
80
  parsed[types.ApiParams.user],
73
81
  parsed[types.ApiParams.dapp],
@@ -77,7 +85,7 @@ function prosopoRouter(env) {
77
85
  Number.parseInt(parsed[types.ApiParams.timestamp]),
78
86
  parsed[types.ApiParams.signature].provider.requestHash,
79
87
  req.ip || NO_IP_ADDRESS,
80
- flattenHeaders(req.headers)
88
+ util.flatten(req.headers, ",")
81
89
  );
82
90
  const returnValue = {
83
91
  status: req.i18n.t(
@@ -98,11 +106,22 @@ function prosopoRouter(env) {
98
106
  router.post(types.ApiPaths.GetPowCaptchaChallenge, async (req, res, next) => {
99
107
  try {
100
108
  const { user, dapp } = types.GetPowCaptchaChallengeRequestBody.parse(req.body);
109
+ address.validateAddress(user, false, 42);
110
+ address.validateAddress(dapp, false, 42);
111
+ const clientRecord = await tasks$1.db.getClientRecord(dapp);
112
+ if (!clientRecord) {
113
+ return res.json({
114
+ error: req.i18n.t("API.SITE_KEY_NOT_REGISTERED"),
115
+ code: 200
116
+ });
117
+ }
101
118
  const origin = req.headers.origin;
102
119
  if (!origin) {
103
- throw new common.ProsopoApiError("API.BAD_REQUEST", {
104
- context: { code: 400, error: "origin header not found" }
105
- });
120
+ return next(
121
+ new common.ProsopoApiError("API.BAD_REQUEST", {
122
+ context: { error: "origin header not found", code: 400 }
123
+ })
124
+ );
106
125
  }
107
126
  const challenge = await tasks$1.powCaptchaManager.getPowCaptchaChallenge(
108
127
  user,
@@ -119,15 +138,16 @@ function prosopoRouter(env) {
119
138
  challenge.difficulty,
120
139
  challenge.providerSignature,
121
140
  req.ip || NO_IP_ADDRESS,
122
- flattenHeaders(req.headers)
141
+ util.flatten(req.headers, ",")
123
142
  );
124
143
  const getPowCaptchaResponse = {
125
- challenge: challenge.challenge,
126
- difficulty: challenge.difficulty,
127
- timestamp: challenge.requestedAtTimestamp.toString(),
128
- signature: {
129
- provider: {
130
- challenge: challenge.providerSignature
144
+ [types.ApiParams.status]: "ok",
145
+ [types.ApiParams.challenge]: challenge.challenge,
146
+ [types.ApiParams.difficulty]: challenge.difficulty,
147
+ [types.ApiParams.timestamp]: challenge.requestedAtTimestamp.toString(),
148
+ [types.ApiParams.signature]: {
149
+ [types.ApiParams.provider]: {
150
+ [types.ApiParams.challenge]: challenge.providerSignature
131
151
  }
132
152
  }
133
153
  };
@@ -143,7 +163,14 @@ function prosopoRouter(env) {
143
163
  });
144
164
  router.post(types.ApiPaths.SubmitPowCaptchaSolution, async (req, res, next) => {
145
165
  try {
146
- const { challenge, difficulty, signature, nonce, verifiedTimeout } = types.SubmitPowCaptchaSolutionBody.parse(req.body);
166
+ const { challenge, difficulty, signature, nonce, verifiedTimeout, dapp } = types.SubmitPowCaptchaSolutionBody.parse(req.body);
167
+ const clientRecord = await tasks$1.db.getClientRecord(dapp);
168
+ if (!clientRecord) {
169
+ return res.json({
170
+ error: req.i18n.t("API.SITE_KEY_NOT_REGISTERED"),
171
+ code: 200
172
+ });
173
+ }
147
174
  const verified = await tasks$1.powCaptchaManager.verifyPowCaptchaSolution(
148
175
  challenge,
149
176
  difficulty,
@@ -152,9 +179,9 @@ function prosopoRouter(env) {
152
179
  verifiedTimeout,
153
180
  signature.user.timestamp,
154
181
  req.ip || NO_IP_ADDRESS,
155
- flattenHeaders(req.headers)
182
+ util.flatten(req.headers, ",")
156
183
  );
157
- const response = { verified };
184
+ const response = { status: "ok", verified };
158
185
  return res.json(response);
159
186
  } catch (err) {
160
187
  tasks$1.logger.error(err);
@@ -137,5 +137,12 @@ class ClientTaskManager {
137
137
  );
138
138
  }
139
139
  }
140
+ async registerSiteKey(siteKey) {
141
+ await this.providerDB.updateClientRecords([
142
+ {
143
+ account: siteKey
144
+ }
145
+ ]);
146
+ }
140
147
  }
141
148
  exports.ClientTaskManager = ClientTaskManager;
@@ -98,6 +98,7 @@ class ImgCaptchaManager {
98
98
  * @param timestamp
99
99
  * @param providerRequestHashSignature
100
100
  * @param ipAddress
101
+ * @param headers
101
102
  * @return {Promise<DappUserSolutionResult>} result containing the contract event
102
103
  */
103
104
  async dappUserSolution(userAccount, dappAccount, requestHash, captchas, userRequestHashSignature, timestamp, providerRequestHashSignature, ipAddress, headers) {
@@ -41,6 +41,7 @@ class PowCaptchaManager {
41
41
  * @param {number} timeout - the time in milliseconds since the Provider was selected to provide the PoW captcha
42
42
  * @param {string} userTimestampSignature
43
43
  * @param ipAddress
44
+ * @param headers
44
45
  */
45
46
  async verifyPowCaptchaSolution(challenge, difficulty, providerChallengeSignature, nonce, timeout, userTimestampSignature, ipAddress, headers) {
46
47
  powTasksUtils.checkPowSignature(
@@ -8,5 +8,6 @@ export declare class ClientTaskManager {
8
8
  constructor(config: ProsopoConfigOutput, logger: Logger, db: IProviderDatabase);
9
9
  storeCommitmentsExternal(): Promise<void>;
10
10
  getClientList(): Promise<void>;
11
+ registerSiteKey(siteKey: string): Promise<void>;
11
12
  }
12
13
  //# sourceMappingURL=clientTasks.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"clientTasks.d.ts","sourceRoot":"","sources":["../../../src/tasks/client/clientTasks.ts"],"names":[],"mappings":"AAcA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAE9C,OAAO,EACN,KAAK,mBAAmB,EAGxB,MAAM,gBAAgB,CAAC;AACxB,OAAO,KAAK,EAAgB,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAE/E,qBAAa,iBAAiB;IAC7B,MAAM,EAAE,mBAAmB,CAAC;IAC5B,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,iBAAiB,CAAC;gBAE7B,MAAM,EAAE,mBAAmB,EAC3B,MAAM,EAAE,MAAM,EACd,EAAE,EAAE,iBAAiB;IAWhB,wBAAwB,IAAI,OAAO,CAAC,IAAI,CAAC;IAuGzC,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC;CAqDpC"}
1
+ {"version":3,"file":"clientTasks.d.ts","sourceRoot":"","sources":["../../../src/tasks/client/clientTasks.ts"],"names":[],"mappings":"AAcA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAE9C,OAAO,EACN,KAAK,mBAAmB,EAGxB,MAAM,gBAAgB,CAAC;AACxB,OAAO,KAAK,EAAgB,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAE/E,qBAAa,iBAAiB;IAC7B,MAAM,EAAE,mBAAmB,CAAC;IAC5B,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,iBAAiB,CAAC;gBAE7B,MAAM,EAAE,mBAAmB,EAC3B,MAAM,EAAE,MAAM,EACd,EAAE,EAAE,iBAAiB;IAWhB,wBAAwB,IAAI,OAAO,CAAC,IAAI,CAAC;IAuGzC,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC;IAsD9B,eAAe,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAOrD"}
@@ -76,5 +76,12 @@ export class ClientTaskManager {
76
76
  await this.providerDB.updateScheduledTaskStatus(taskID, ScheduledTaskStatus.Failed, { error: String(e) });
77
77
  }
78
78
  }
79
+ async registerSiteKey(siteKey) {
80
+ await this.providerDB.updateClientRecords([
81
+ {
82
+ account: siteKey,
83
+ },
84
+ ]);
85
+ }
79
86
  }
80
87
  //# sourceMappingURL=clientTasks.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"clientTasks.js","sourceRoot":"","sources":["../../../src/tasks/client/clientTasks.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"clientTasks.js","sourceRoot":"","sources":["../../../src/tasks/client/clientTasks.ts"],"names":[],"mappings":"AAeA,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACpE,OAAO,EAEN,kBAAkB,EAClB,mBAAmB,GACnB,MAAM,gBAAgB,CAAC;AAGxB,MAAM,OAAO,iBAAiB;IAI7B,YACC,MAA2B,EAC3B,MAAc,EACd,EAAqB;QAErB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;IACtB,CAAC;IAMD,KAAK,CAAC,wBAAwB;QAC7B,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,eAAe,EAAE,CAAC;YAClC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;YACtC,OAAO;QACR,CAAC;QAED,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,0BAA0B,CAChE,kBAAkB,CAAC,wBAAwB,EAC3C,mBAAmB,CAAC,SAAS,CAC7B,CAAC;QAEF,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,yBAAyB,CAC7D,kBAAkB,CAAC,wBAAwB,EAC3C,mBAAmB,CAAC,OAAO,CAC3B,CAAC;QAEF,IAAI,CAAC;YACJ,IAAI,WAAW,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,8BAA8B,EAAE,CAAC;YAEzE,IAAI,UAAU,GACb,MAAM,IAAI,CAAC,UAAU,CAAC,iCAAiC,EAAE,CAAC;YAG3D,IAAI,QAAQ,EAAE,CAAC;gBACd,IAAI,CAAC,MAAM,CAAC,IAAI,CACf,kDAAkD,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE,CAC5E,CAAC;gBACF,IAAI,CAAC,MAAM,CAAC,IAAI,CACf,mBAAmB,EACnB,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC,EAC/B,SAAS,EACT,MAAM,CACN,CAAC;gBAEF,WAAW,GAAG,WAAW,CAAC,MAAM,CAC/B,CAAC,UAAU,EAAE,EAAE,CACd,QAAQ,CAAC,OAAO;oBAChB,UAAU,CAAC,oBAAoB;oBAC/B,CAAC,UAAU,CAAC,oBAAoB,GAAG,QAAQ,CAAC,OAAO;wBAClD,CAAC,UAAU,CAAC,oBAAoB,CAAC,CACnC,CAAC;gBAEF,UAAU,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,UAAU,EAAE,EAAE;oBAC7C,OAAO,CACN,QAAQ,CAAC,OAAO;wBAChB,UAAU,CAAC,oBAAoB;wBAG/B,CAAC,UAAU,CAAC,oBAAoB,GAAG,QAAQ,CAAC,OAAO;4BAClD,CAAC,UAAU,CAAC,oBAAoB,CAAC,CAClC,CAAC;gBACH,CAAC,CAAC,CAAC;YACJ,CAAC;YAED,IAAI,WAAW,CAAC,MAAM,IAAI,UAAU,CAAC,MAAM,EAAE,CAAC;gBAC7C,IAAI,CAAC,MAAM,CAAC,IAAI,CACf,WAAW,WAAW,CAAC,MAAM,yBAAyB,CACtD,CAAC;gBAEF,IAAI,CAAC,MAAM,CAAC,IAAI,CACf,WAAW,UAAU,CAAC,MAAM,4BAA4B,CACxD,CAAC;gBAEF,MAAM,SAAS,GAAG,IAAI,eAAe,CACpC,IAAI,CAAC,MAAM,CAAC,eAAe,EAC3B,SAAS,EACT,SAAS,EACT,IAAI,CAAC,MAAM,CACX,CAAC;gBAEF,MAAM,SAAS,CAAC,YAAY,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;gBAEtD,MAAM,IAAI,CAAC,UAAU,CAAC,6BAA6B,CAClD,WAAW,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,CAC9C,CAAC;gBACF,MAAM,IAAI,CAAC,UAAU,CAAC,gCAAgC,CACrD,UAAU,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC,CACpD,CAAC;YACH,CAAC;YACD,MAAM,IAAI,CAAC,UAAU,CAAC,yBAAyB,CAC9C,MAAM,EACN,mBAAmB,CAAC,SAAS,EAC7B;gBACC,IAAI,EAAE;oBACL,WAAW,EAAE,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;oBACzC,UAAU,EAAE,UAAU,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,SAAS,CAAC;iBAChD;aACD,CACD,CAAC;QACH,CAAC;QAAC,OAAO,CAAU,EAAE,CAAC;YACrB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YACrB,MAAM,IAAI,CAAC,UAAU,CAAC,yBAAyB,CAC9C,MAAM,EACN,mBAAmB,CAAC,MAAM,EAC1B,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,CACpB,CAAC;QACH,CAAC;IACF,CAAC;IAMD,KAAK,CAAC,aAAa;QAClB,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC;YACjC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;YACtC,OAAO;QACR,CAAC;QAED,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,0BAA0B,CAChE,kBAAkB,CAAC,aAAa,EAChC,mBAAmB,CAAC,SAAS,CAC7B,CAAC;QAEF,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,yBAAyB,CAC7D,kBAAkB,CAAC,aAAa,EAChC,mBAAmB,CAAC,OAAO,CAC3B,CAAC;QAEF,IAAI,CAAC;YACJ,MAAM,QAAQ,GAAG,IAAI,cAAc,CAClC,IAAI,CAAC,MAAM,CAAC,cAAc,EAC1B,SAAS,EACT,SAAS,EACT,IAAI,CAAC,MAAM,CACX,CAAC;YAEF,MAAM,kBAAkB,GAAG,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAEhE,OAAO,CAAC,GAAG,CAAC,oBAAoB,EAAE,kBAAkB,CAAC,CAAC;YAEtD,MAAM,gBAAgB,GACrB,MAAM,QAAQ,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,CAAC;YAEtD,IAAI,gBAAgB,EAAE,CAAC;gBACtB,MAAM,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAC,gBAAgB,CAAC,CAAC;YAC7D,CAAC;YAED,MAAM,IAAI,CAAC,UAAU,CAAC,yBAAyB,CAC9C,MAAM,EACN,mBAAmB,CAAC,SAAS,EAC7B;gBACC,IAAI,EAAE;oBACL,aAAa,EAAE,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAe,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;iBACnE;aACD,CACD,CAAC;QACH,CAAC;QAAC,OAAO,CAAU,EAAE,CAAC;YACrB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YACrB,MAAM,IAAI,CAAC,UAAU,CAAC,yBAAyB,CAC9C,MAAM,EACN,mBAAmB,CAAC,MAAM,EAC1B,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,CACpB,CAAC;QACH,CAAC;IACF,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,OAAe;QACpC,MAAM,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAC;YACzC;gBACC,OAAO,EAAE,OAAO;aACA;SACjB,CAAC,CAAC;IACJ,CAAC;CACD"}