@prosopo/provider 2.3.2 → 2.4.2
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/api/admin/apiRegisterSiteKeyEndpoint.d.ts.map +1 -1
- package/dist/api/admin/apiRegisterSiteKeyEndpoint.js +4 -4
- package/dist/api/admin/apiRegisterSiteKeyEndpoint.js.map +1 -1
- package/dist/api/admin/createApiAdminRoutesProvider.d.ts +1 -2
- package/dist/api/admin/createApiAdminRoutesProvider.d.ts.map +1 -1
- package/dist/api/admin/createApiAdminRoutesProvider.js +1 -2
- package/dist/api/admin/createApiAdminRoutesProvider.js.map +1 -1
- package/dist/api/authMiddleware.d.ts.map +1 -1
- package/dist/api/authMiddleware.js +20 -6
- package/dist/api/authMiddleware.js.map +1 -1
- package/dist/api/captcha.d.ts.map +1 -1
- package/dist/api/captcha.js +104 -83
- package/dist/api/captcha.js.map +1 -1
- package/dist/api/domainMiddleware.d.ts.map +1 -1
- package/dist/api/domainMiddleware.js +17 -12
- package/dist/api/domainMiddleware.js.map +1 -1
- package/dist/api/headerCheckMiddleware.d.ts.map +1 -1
- package/dist/api/headerCheckMiddleware.js +5 -1
- package/dist/api/headerCheckMiddleware.js.map +1 -1
- package/dist/api/public.d.ts.map +1 -1
- package/dist/api/public.js +1 -2
- package/dist/api/public.js.map +1 -1
- package/dist/api/validateAddress.d.ts +4 -0
- package/dist/api/validateAddress.d.ts.map +1 -0
- package/dist/api/validateAddress.js +16 -0
- package/dist/api/validateAddress.js.map +1 -0
- package/dist/api/verify.d.ts.map +1 -1
- package/dist/api/verify.js +13 -15
- package/dist/api/verify.js.map +1 -1
- package/dist/index.d.ts +1 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -2
- package/dist/index.js.map +1 -1
- package/dist/tasks/captchaManager.d.ts +25 -0
- package/dist/tasks/captchaManager.d.ts.map +1 -0
- package/dist/tasks/captchaManager.js +81 -0
- package/dist/tasks/captchaManager.js.map +1 -0
- package/dist/tasks/client/clientTasks.d.ts +2 -3
- package/dist/tasks/client/clientTasks.d.ts.map +1 -1
- package/dist/tasks/client/clientTasks.js +8 -13
- package/dist/tasks/client/clientTasks.js.map +1 -1
- package/dist/tasks/frictionless/frictionlessTasks.d.ts +13 -7
- package/dist/tasks/frictionless/frictionlessTasks.d.ts.map +1 -1
- package/dist/tasks/frictionless/frictionlessTasks.js +54 -13
- package/dist/tasks/frictionless/frictionlessTasks.js.map +1 -1
- package/dist/tasks/frictionless/frictionlessTasksUtils.d.ts +5 -0
- package/dist/tasks/frictionless/frictionlessTasksUtils.d.ts.map +1 -0
- package/dist/tasks/frictionless/frictionlessTasksUtils.js +6 -0
- package/dist/tasks/frictionless/frictionlessTasksUtils.js.map +1 -0
- package/dist/tasks/imgCaptcha/imgCaptchaTasks.d.ts +7 -8
- package/dist/tasks/imgCaptcha/imgCaptchaTasks.d.ts.map +1 -1
- package/dist/tasks/imgCaptcha/imgCaptchaTasks.js +32 -12
- package/dist/tasks/imgCaptcha/imgCaptchaTasks.js.map +1 -1
- package/dist/tasks/powCaptcha/powTasks.d.ts +8 -5
- package/dist/tasks/powCaptcha/powTasks.d.ts.map +1 -1
- package/dist/tasks/powCaptcha/powTasks.js +22 -15
- package/dist/tasks/powCaptcha/powTasks.js.map +1 -1
- package/dist/tasks/tasks.d.ts.map +1 -1
- package/dist/tasks/tasks.js +3 -3
- package/dist/tasks/tasks.js.map +1 -1
- package/dist/tests/integration/imgCaptcha.integration.test.js +59 -7
- package/dist/tests/integration/imgCaptcha.integration.test.js.map +1 -1
- package/dist/tests/integration/powCaptcha.integration.test.js +57 -13
- package/dist/tests/integration/powCaptcha.integration.test.js.map +1 -1
- package/dist/tests/integration/registerSitekey.d.ts +2 -1
- package/dist/tests/integration/registerSitekey.d.ts.map +1 -1
- package/dist/tests/integration/registerSitekey.js +2 -2
- package/dist/tests/integration/registerSitekey.js.map +1 -1
- package/dist/tests/unit/api/authMiddleware.unit.test.js +8 -1
- package/dist/tests/unit/api/authMiddleware.unit.test.js.map +1 -1
- package/dist/tests/unit/tasks/captchaManager.unit.test.d.ts +2 -0
- package/dist/tests/unit/tasks/captchaManager.unit.test.d.ts.map +1 -0
- package/dist/tests/unit/tasks/captchaManager.unit.test.js +229 -0
- package/dist/tests/unit/tasks/captchaManager.unit.test.js.map +1 -0
- package/dist/tests/unit/tasks/frictionless/frictionlessTasks.unit.test.js +41 -7
- package/dist/tests/unit/tasks/frictionless/frictionlessTasks.unit.test.js.map +1 -1
- package/dist/tests/unit/tasks/frictionless/frictionlessTasksUtils.unit.test.d.ts +2 -0
- package/dist/tests/unit/tasks/frictionless/frictionlessTasksUtils.unit.test.d.ts.map +1 -0
- package/dist/tests/unit/tasks/frictionless/frictionlessTasksUtils.unit.test.js +37 -0
- package/dist/tests/unit/tasks/frictionless/frictionlessTasksUtils.unit.test.js.map +1 -0
- package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasks.unit.test.js +4 -4
- package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasks.unit.test.js.map +1 -1
- package/dist/tests/unit/tasks/powCaptcha/powTasks.unit.test.js +5 -10
- package/dist/tests/unit/tasks/powCaptcha/powTasks.unit.test.js.map +1 -1
- package/package.json +15 -14
- package/vite.cjs.config.ts +1 -1
- package/vite.test.config.ts +1 -1
- package/dist/api/admin/export.d.ts +0 -3
- package/dist/api/admin/export.d.ts.map +0 -1
- package/dist/api/admin/export.js +0 -3
- package/dist/api/admin/export.js.map +0 -1
- package/dist/api/errorHandler.d.ts +0 -5
- package/dist/api/errorHandler.d.ts.map +0 -1
- package/dist/api/errorHandler.js +0 -10
- package/dist/api/errorHandler.js.map +0 -1
- package/dist/api/export.d.ts +0 -2
- package/dist/api/export.d.ts.map +0 -1
- package/dist/api/export.js +0 -2
- package/dist/api/export.js.map +0 -1
- package/dist/tests/unit/api/errorHandler.unit.test.d.ts +0 -2
- package/dist/tests/unit/api/errorHandler.unit.test.d.ts.map +0 -1
- package/dist/tests/unit/api/errorHandler.unit.test.js +0 -105
- package/dist/tests/unit/api/errorHandler.unit.test.js.map +0 -1
|
@@ -1,33 +1,74 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { CaptchaType } from "@prosopo/types";
|
|
2
|
+
import { ApiParams } from "@prosopo/types";
|
|
2
3
|
import { v4 as uuidv4 } from "uuid";
|
|
3
4
|
import { checkLangRules } from "../../rules/lang.js";
|
|
4
|
-
|
|
5
|
-
|
|
5
|
+
import { CaptchaManager } from "../captchaManager.js";
|
|
6
|
+
const DEFAULT_MAX_TIMESTAMP_AGE = 60 * 10 * 1000;
|
|
7
|
+
export class FrictionlessManager extends CaptchaManager {
|
|
8
|
+
constructor(db, pair, config, logger) {
|
|
9
|
+
super(db, pair, logger);
|
|
6
10
|
this.config = config;
|
|
7
|
-
this.pair = pair;
|
|
8
|
-
this.db = db;
|
|
9
11
|
}
|
|
10
12
|
checkLangRules(acceptLanguage) {
|
|
11
13
|
return checkLangRules(this.config, acceptLanguage);
|
|
12
14
|
}
|
|
13
|
-
|
|
14
|
-
return {
|
|
15
|
-
[ApiParams.captchaType]: "image",
|
|
16
|
-
[ApiParams.status]: "ok",
|
|
17
|
-
};
|
|
18
|
-
}
|
|
19
|
-
async sendPowCaptcha(tokenId) {
|
|
15
|
+
async createSession(tokenId, captchaType) {
|
|
20
16
|
const sessionRecord = {
|
|
21
17
|
sessionId: uuidv4(),
|
|
22
18
|
createdAt: new Date(),
|
|
23
19
|
tokenId: tokenId,
|
|
20
|
+
captchaType,
|
|
24
21
|
};
|
|
25
22
|
await this.db.storeSessionRecord(sessionRecord);
|
|
23
|
+
return sessionRecord;
|
|
24
|
+
}
|
|
25
|
+
async sendImageCaptcha(tokenId) {
|
|
26
|
+
const sessionRecord = await this.createSession(tokenId, CaptchaType.image);
|
|
26
27
|
return {
|
|
27
|
-
[ApiParams.captchaType]:
|
|
28
|
+
[ApiParams.captchaType]: CaptchaType.image,
|
|
28
29
|
[ApiParams.sessionId]: sessionRecord.sessionId,
|
|
29
30
|
[ApiParams.status]: "ok",
|
|
30
31
|
};
|
|
31
32
|
}
|
|
33
|
+
async sendPowCaptcha(tokenId) {
|
|
34
|
+
const sessionRecord = await this.createSession(tokenId, CaptchaType.pow);
|
|
35
|
+
return {
|
|
36
|
+
[ApiParams.captchaType]: CaptchaType.pow,
|
|
37
|
+
[ApiParams.sessionId]: sessionRecord.sessionId,
|
|
38
|
+
[ApiParams.status]: "ok",
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
async scoreIncreaseAccessPolicy(accessRule, baseBotScore, botScore, tokenId) {
|
|
42
|
+
const accessPolicyPenalty = accessRule?.score || this.config.penalties.PENALTY_ACCESS_RULE;
|
|
43
|
+
botScore += accessPolicyPenalty;
|
|
44
|
+
this.logger.info({
|
|
45
|
+
message: "Address has an image captcha config defined",
|
|
46
|
+
});
|
|
47
|
+
await this.db.updateFrictionlessTokenRecord(tokenId, {
|
|
48
|
+
score: botScore,
|
|
49
|
+
scoreComponents: {
|
|
50
|
+
baseScore: baseBotScore,
|
|
51
|
+
accessPolicy: accessPolicyPenalty,
|
|
52
|
+
},
|
|
53
|
+
});
|
|
54
|
+
return botScore;
|
|
55
|
+
}
|
|
56
|
+
async scoreIncreaseTimestamp(timestamp, baseBotScore, botScore, tokenId) {
|
|
57
|
+
this.logger.info("Timestamp is older than 10 minutes", new Date(timestamp));
|
|
58
|
+
botScore += this.config.penalties.PENALTY_OLD_TIMESTAMP;
|
|
59
|
+
await this.db.updateFrictionlessTokenRecord(tokenId, {
|
|
60
|
+
score: botScore,
|
|
61
|
+
scoreComponents: {
|
|
62
|
+
baseScore: baseBotScore,
|
|
63
|
+
timeout: this.config.penalties.PENALTY_OLD_TIMESTAMP,
|
|
64
|
+
},
|
|
65
|
+
});
|
|
66
|
+
return botScore;
|
|
67
|
+
}
|
|
68
|
+
static timestampTooOld(timestamp) {
|
|
69
|
+
const now = Date.now();
|
|
70
|
+
const diff = now - timestamp;
|
|
71
|
+
return diff > DEFAULT_MAX_TIMESTAMP_AGE;
|
|
72
|
+
}
|
|
32
73
|
}
|
|
33
74
|
//# sourceMappingURL=frictionlessTasks.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"frictionlessTasks.js","sourceRoot":"","sources":["../../../src/tasks/frictionless/frictionlessTasks.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"frictionlessTasks.js","sourceRoot":"","sources":["../../../src/tasks/frictionless/frictionlessTasks.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"frictionlessTasksUtils.d.ts","sourceRoot":"","sources":["../../../src/tasks/frictionless/frictionlessTasksUtils.ts"],"names":[],"mappings":"AAaA,OAAO,KAAK,EAGX,eAAe,EACf,MAAM,yBAAyB,CAAC;AAEjC,eAAO,MAAM,wBAAwB,oBAEjC;IACA,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAAC;CACrB,GACD,eAAe,KAChB,MASF,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"frictionlessTasksUtils.js","sourceRoot":"","sources":["../../../src/tasks/frictionless/frictionlessTasksUtils.ts"],"names":[],"mappings":"AAmBA,MAAM,CAAC,MAAM,wBAAwB,GAAG,CACvC,eAIkB,EACT,EAAE;IACX,OAAO,MAAM,CACZ,IAAI,CAAC,GAAG,CACP,CAAC,EACD,MAAM,CAAC,MAAM,CAAC,eAAe,CAAC;SAC5B,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,SAAS,CAAC;SAC9B,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,GAAG,GAAG,GAAG,EAAE,CAAC,CAAC,CACpC,CAAC,OAAO,CAAC,CAAC,CAAC,CACZ,CAAC;AACH,CAAC,CAAC"}
|
|
@@ -1,15 +1,13 @@
|
|
|
1
1
|
import type { KeyringPair } from "@polkadot/keyring/types";
|
|
2
2
|
import { type Logger } from "@prosopo/common";
|
|
3
|
-
import { type Captcha, type CaptchaSolution, type DappUserSolutionResult, type Hash, type IPAddress, type ImageVerificationResponse, type
|
|
4
|
-
import type { IProviderDatabase, UserCommitment } from "@prosopo/types-database";
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
pair: KeyringPair;
|
|
8
|
-
logger: Logger;
|
|
3
|
+
import { type Captcha, type CaptchaSolution, type DappUserSolutionResult, type Hash, type IPAddress, type ImageVerificationResponse, type ProsopoCaptchaCountConfigSchemaOutput, type ProsopoConfigOutput, type RequestHeaders } from "@prosopo/types";
|
|
4
|
+
import type { ClientRecord, FrictionlessTokenId, IProviderDatabase, PendingCaptchaRequest, UserCommitment } from "@prosopo/types-database";
|
|
5
|
+
import { CaptchaManager } from "../captchaManager.js";
|
|
6
|
+
export declare class ImgCaptchaManager extends CaptchaManager {
|
|
9
7
|
config: ProsopoConfigOutput;
|
|
10
|
-
constructor(db: IProviderDatabase, pair: KeyringPair,
|
|
8
|
+
constructor(db: IProviderDatabase, pair: KeyringPair, config: ProsopoConfigOutput, logger?: Logger);
|
|
11
9
|
getCaptchaWithProof(datasetId: Hash, solved: boolean, size: number): Promise<Captcha[]>;
|
|
12
|
-
getRandomCaptchasAndRequestHash(datasetId: Hash, userAccount: string, ipAddress: IPAddress, headers: RequestHeaders, captchaConfig: ProsopoCaptchaCountConfigSchemaOutput): Promise<{
|
|
10
|
+
getRandomCaptchasAndRequestHash(datasetId: Hash, userAccount: string, ipAddress: IPAddress, headers: RequestHeaders, captchaConfig: ProsopoCaptchaCountConfigSchemaOutput, frictionlessTokenId?: FrictionlessTokenId): Promise<{
|
|
13
11
|
captchas: Captcha[];
|
|
14
12
|
requestHash: string;
|
|
15
13
|
timestamp: number;
|
|
@@ -26,5 +24,6 @@ export declare class ImgCaptchaManager {
|
|
|
26
24
|
getDappUserCommitmentByAccount(userAccount: string, dappAccount: string): Promise<UserCommitment | undefined>;
|
|
27
25
|
verifyImageCaptchaSolution(user: string, dapp: string, commitmentId: string | undefined, maxVerifiedTime?: number): Promise<ImageVerificationResponse>;
|
|
28
26
|
checkLangRules(acceptLanguage: string): number;
|
|
27
|
+
getVerificationResponse(verified: boolean, clientRecord: ClientRecord, translateFn: (key: string) => string, score?: number, commitmentId?: Hash): ImageVerificationResponse;
|
|
29
28
|
}
|
|
30
29
|
//# sourceMappingURL=imgCaptchaTasks.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"imgCaptchaTasks.d.ts","sourceRoot":"","sources":["../../../src/tasks/imgCaptcha/imgCaptchaTasks.ts"],"names":[],"mappings":"AAcA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAG3D,OAAO,EAAE,KAAK,MAAM,EAAmB,MAAM,iBAAiB,CAAC;AAM/D,OAAO,
|
|
1
|
+
{"version":3,"file":"imgCaptchaTasks.d.ts","sourceRoot":"","sources":["../../../src/tasks/imgCaptcha/imgCaptchaTasks.ts"],"names":[],"mappings":"AAcA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAG3D,OAAO,EAAE,KAAK,MAAM,EAAmB,MAAM,iBAAiB,CAAC;AAM/D,OAAO,EAEN,KAAK,OAAO,EACZ,KAAK,eAAe,EAGpB,KAAK,sBAAsB,EAC3B,KAAK,IAAI,EACT,KAAK,SAAS,EACd,KAAK,yBAAyB,EAC9B,KAAK,qCAAqC,EAC1C,KAAK,mBAAmB,EACxB,KAAK,cAAc,EACnB,MAAM,gBAAgB,CAAC;AACxB,OAAO,KAAK,EACX,YAAY,EACZ,mBAAmB,EACnB,iBAAiB,EACjB,qBAAqB,EACrB,cAAc,EACd,MAAM,yBAAyB,CAAC;AAIjC,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAItD,qBAAa,iBAAkB,SAAQ,cAAc;IACpD,MAAM,EAAE,mBAAmB,CAAC;gBAG3B,EAAE,EAAE,iBAAiB,EACrB,IAAI,EAAE,WAAW,EACjB,MAAM,EAAE,mBAAmB,EAC3B,MAAM,CAAC,EAAE,MAAM;IAMV,mBAAmB,CACxB,SAAS,EAAE,IAAI,EACf,MAAM,EAAE,OAAO,EACf,IAAI,EAAE,MAAM,GACV,OAAO,CAAC,OAAO,EAAE,CAAC;IAgBf,+BAA+B,CACpC,SAAS,EAAE,IAAI,EACf,WAAW,EAAE,MAAM,EACnB,SAAS,EAAE,SAAS,EACpB,OAAO,EAAE,cAAc,EACvB,aAAa,EAAE,qCAAqC,EACpD,mBAAmB,CAAC,EAAE,mBAAmB,GACvC,OAAO,CAAC;QACV,QAAQ,EAAE,OAAO,EAAE,CAAC;QACpB,WAAW,EAAE,MAAM,CAAC;QACpB,SAAS,EAAE,MAAM,CAAC;QAClB,iBAAiB,EAAE,MAAM,CAAC;KAC1B,CAAC;IAmFI,gBAAgB,CACrB,WAAW,EAAE,MAAM,EACnB,WAAW,EAAE,MAAM,EACnB,WAAW,EAAE,MAAM,EACnB,QAAQ,EAAE,eAAe,EAAE,EAC3B,sBAAsB,EAAE,MAAM,EAC9B,SAAS,EAAE,MAAM,EACjB,4BAA4B,EAAE,MAAM,EACpC,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,cAAc,GACrB,OAAO,CAAC,sBAAsB,CAAC;IAmH5B,6CAA6C,CAClD,QAAQ,EAAE,eAAe,EAAE,GACzB,OAAO,CAAC;QACV,cAAc,EAAE,OAAO,EAAE,CAAC;QAC1B,gBAAgB,EAAE,eAAe,EAAE,CAAC;QACpC,UAAU,EAAE,MAAM,EAAE,CAAC;KACrB,CAAC;IAqCI,wCAAwC,CAC7C,WAAW,EAAE,MAAM,EACnB,aAAa,EAAE,qBAAqB,EACpC,WAAW,EAAE,MAAM,EACnB,UAAU,EAAE,MAAM,EAAE,GAClB,OAAO,CAAC,OAAO,CAAC;IA2Bb,yBAAyB,CAC9B,YAAY,EAAE,MAAM,GAClB,OAAO,CAAC,cAAc,CAAC;IAepB,8BAA8B,CACnC,WAAW,EAAE,MAAM,EACnB,WAAW,EAAE,MAAM,GACjB,OAAO,CAAC,cAAc,GAAG,SAAS,CAAC;IAehC,0BAA0B,CAC/B,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,MAAM,EACZ,YAAY,EAAE,MAAM,GAAG,SAAS,EAChC,eAAe,CAAC,EAAE,MAAM,GACtB,OAAO,CAAC,yBAAyB,CAAC;IA+DrC,cAAc,CAAC,cAAc,EAAE,MAAM,GAAG,MAAM;IAIrC,uBAAuB,CAC/B,QAAQ,EAAE,OAAO,EACjB,YAAY,EAAE,YAAY,EAC1B,WAAW,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,MAAM,EACpC,KAAK,CAAC,EAAE,MAAM,EACd,YAAY,CAAC,EAAE,IAAI,GACjB,yBAAyB;CAa5B"}
|
|
@@ -2,16 +2,16 @@ import { stringToHex, u8aToHex } from "@polkadot/util";
|
|
|
2
2
|
import { randomAsHex, signatureVerify } from "@polkadot/util-crypto";
|
|
3
3
|
import { ProsopoEnvError } from "@prosopo/common";
|
|
4
4
|
import { compareCaptchaSolutions, computePendingRequestHash, parseAndSortCaptchaSolutions, } from "@prosopo/datasets";
|
|
5
|
-
import { CaptchaStatus, DEFAULT_IMAGE_CAPTCHA_TIMEOUT, } from "@prosopo/types";
|
|
5
|
+
import { ApiParams, CaptchaStatus, DEFAULT_IMAGE_CAPTCHA_TIMEOUT, } from "@prosopo/types";
|
|
6
6
|
import { at } from "@prosopo/util";
|
|
7
7
|
import { checkLangRules } from "../../rules/lang.js";
|
|
8
8
|
import { shuffleArray } from "../../util.js";
|
|
9
|
+
import { CaptchaManager } from "../captchaManager.js";
|
|
10
|
+
import { computeFrictionlessScore } from "../frictionless/frictionlessTasksUtils.js";
|
|
9
11
|
import { buildTreeAndGetCommitmentId } from "./imgCaptchaTasksUtils.js";
|
|
10
|
-
export class ImgCaptchaManager {
|
|
11
|
-
constructor(db, pair,
|
|
12
|
-
|
|
13
|
-
this.pair = pair;
|
|
14
|
-
this.logger = logger;
|
|
12
|
+
export class ImgCaptchaManager extends CaptchaManager {
|
|
13
|
+
constructor(db, pair, config, logger) {
|
|
14
|
+
super(db, pair, logger);
|
|
15
15
|
this.config = config;
|
|
16
16
|
}
|
|
17
17
|
async getCaptchaWithProof(datasetId, solved, size) {
|
|
@@ -28,7 +28,7 @@ export class ImgCaptchaManager {
|
|
|
28
28
|
}
|
|
29
29
|
return captchaDocs;
|
|
30
30
|
}
|
|
31
|
-
async getRandomCaptchasAndRequestHash(datasetId, userAccount, ipAddress, headers, captchaConfig) {
|
|
31
|
+
async getRandomCaptchasAndRequestHash(datasetId, userAccount, ipAddress, headers, captchaConfig, frictionlessTokenId) {
|
|
32
32
|
const dataset = await this.db.getDatasetDetails(datasetId);
|
|
33
33
|
if (!dataset) {
|
|
34
34
|
throw new ProsopoEnvError("DATABASE.DATASET_GET_FAILED", {
|
|
@@ -45,7 +45,6 @@ export class ImgCaptchaManager {
|
|
|
45
45
|
throw new ProsopoEnvError("CONFIG.INVALID_CAPTCHA_NUMBER");
|
|
46
46
|
}
|
|
47
47
|
const solved = await this.getCaptchaWithProof(datasetId, true, solvedCount);
|
|
48
|
-
console.log("solved", solved);
|
|
49
48
|
let unsolved = [];
|
|
50
49
|
if (unsolvedCount) {
|
|
51
50
|
unsolved = await this.getCaptchaWithProof(datasetId, false, unsolvedCount);
|
|
@@ -59,7 +58,7 @@ export class ImgCaptchaManager {
|
|
|
59
58
|
.map((captcha) => captcha.timeLimitMs || DEFAULT_IMAGE_CAPTCHA_TIMEOUT)
|
|
60
59
|
.reduce((a, b) => a + b, 0);
|
|
61
60
|
const deadlineTs = timeLimit + currentTime;
|
|
62
|
-
await this.db.
|
|
61
|
+
await this.db.storePendingImageCommitment(userAccount, requestHash, salt, deadlineTs, currentTime, ipAddress.bigInt(), frictionlessTokenId);
|
|
63
62
|
return {
|
|
64
63
|
captchas,
|
|
65
64
|
requestHash,
|
|
@@ -90,7 +89,7 @@ export class ImgCaptchaManager {
|
|
|
90
89
|
captchas: [],
|
|
91
90
|
verified: false,
|
|
92
91
|
};
|
|
93
|
-
const pendingRecord = await this.db.
|
|
92
|
+
const pendingRecord = await this.db.getPendingImageCommitment(requestHash);
|
|
94
93
|
const unverifiedCaptchaIds = captchas.map((captcha) => captcha.captchaId);
|
|
95
94
|
const pendingRequest = await this.validateDappUserSolutionRequestIsPending(requestHash, pendingRecord, userAccount, unverifiedCaptchaIds);
|
|
96
95
|
if (pendingRequest) {
|
|
@@ -102,7 +101,7 @@ export class ImgCaptchaManager {
|
|
|
102
101
|
context: { failedFuncName: this.dappUserSolution.name },
|
|
103
102
|
});
|
|
104
103
|
}
|
|
105
|
-
await this.db.
|
|
104
|
+
await this.db.updatePendingImageCommitmentStatus(requestHash);
|
|
106
105
|
const commit = {
|
|
107
106
|
id: commitmentId,
|
|
108
107
|
userAccount: userAccount,
|
|
@@ -116,8 +115,9 @@ export class ImgCaptchaManager {
|
|
|
116
115
|
requestedAtTimestamp: timestamp,
|
|
117
116
|
ipAddress,
|
|
118
117
|
headers,
|
|
118
|
+
frictionlessTokenId: pendingRecord.frictionlessTokenId,
|
|
119
119
|
};
|
|
120
|
-
await this.db.
|
|
120
|
+
await this.db.storeUserImageCaptchaSolution(receivedCaptchas, commit);
|
|
121
121
|
if (compareCaptchaSolutions(receivedCaptchas, storedCaptchas)) {
|
|
122
122
|
response = {
|
|
123
123
|
captchas: captchaIds.map((id) => ({
|
|
@@ -233,14 +233,34 @@ export class ImgCaptchaManager {
|
|
|
233
233
|
}
|
|
234
234
|
}
|
|
235
235
|
const isApproved = solution.result.status === CaptchaStatus.approved;
|
|
236
|
+
let score;
|
|
237
|
+
if (solution.frictionlessTokenId) {
|
|
238
|
+
const tokenRecord = await this.db.getFrictionlessTokenRecordByTokenId(solution.frictionlessTokenId);
|
|
239
|
+
if (tokenRecord) {
|
|
240
|
+
score = computeFrictionlessScore(tokenRecord?.scoreComponents);
|
|
241
|
+
this.logger.info({
|
|
242
|
+
tscoreComponents: tokenRecord?.scoreComponents,
|
|
243
|
+
score: score,
|
|
244
|
+
});
|
|
245
|
+
}
|
|
246
|
+
}
|
|
236
247
|
return {
|
|
237
248
|
status: isApproved ? "API.USER_VERIFIED" : "API.USER_NOT_VERIFIED",
|
|
238
249
|
verified: isApproved,
|
|
239
250
|
commitmentId: solution.id.toString(),
|
|
251
|
+
...(score && { score }),
|
|
240
252
|
};
|
|
241
253
|
}
|
|
242
254
|
checkLangRules(acceptLanguage) {
|
|
243
255
|
return checkLangRules(this.config, acceptLanguage);
|
|
244
256
|
}
|
|
257
|
+
getVerificationResponse(verified, clientRecord, translateFn, score, commitmentId) {
|
|
258
|
+
return {
|
|
259
|
+
...super.getVerificationResponse(verified, clientRecord, translateFn, score),
|
|
260
|
+
...(commitmentId && {
|
|
261
|
+
[ApiParams.commitmentId]: commitmentId,
|
|
262
|
+
}),
|
|
263
|
+
};
|
|
264
|
+
}
|
|
245
265
|
}
|
|
246
266
|
//# sourceMappingURL=imgCaptchaTasks.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"imgCaptchaTasks.js","sourceRoot":"","sources":["../../../src/tasks/imgCaptcha/imgCaptchaTasks.ts"],"names":[],"mappings":"AAeA,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AACvD,OAAO,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AACrE,OAAO,EAAe,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAC/D,OAAO,EACN,uBAAuB,EACvB,yBAAyB,EACzB,4BAA4B,GAC5B,MAAM,mBAAmB,CAAC;AAC3B,OAAO,
|
|
1
|
+
{"version":3,"file":"imgCaptchaTasks.js","sourceRoot":"","sources":["../../../src/tasks/imgCaptcha/imgCaptchaTasks.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,13 +1,16 @@
|
|
|
1
1
|
import type { KeyringPair } from "@polkadot/keyring/types";
|
|
2
|
+
import type { Logger } from "@prosopo/common";
|
|
2
3
|
import { type IPAddress, type PoWCaptcha, type PoWChallengeId, type RequestHeaders } from "@prosopo/types";
|
|
3
4
|
import type { IProviderDatabase } from "@prosopo/types-database";
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
db: IProviderDatabase;
|
|
5
|
+
import { CaptchaManager } from "../captchaManager.js";
|
|
6
|
+
export declare class PowCaptchaManager extends CaptchaManager {
|
|
7
7
|
POW_SEPARATOR: string;
|
|
8
|
-
constructor(pair: KeyringPair,
|
|
8
|
+
constructor(db: IProviderDatabase, pair: KeyringPair, logger?: Logger);
|
|
9
9
|
getPowCaptchaChallenge(userAccount: string, dappAccount: string, origin: string, powDifficulty?: number): Promise<PoWCaptcha>;
|
|
10
10
|
verifyPowCaptchaSolution(challenge: PoWChallengeId, difficulty: number, providerChallengeSignature: string, nonce: number, timeout: number, userTimestampSignature: string, ipAddress: IPAddress, headers: RequestHeaders): Promise<boolean>;
|
|
11
|
-
serverVerifyPowCaptchaSolution(dappAccount: string, challenge: string, timeout: number): Promise<
|
|
11
|
+
serverVerifyPowCaptchaSolution(dappAccount: string, challenge: string, timeout: number): Promise<{
|
|
12
|
+
verified: boolean;
|
|
13
|
+
score?: number;
|
|
14
|
+
}>;
|
|
12
15
|
}
|
|
13
16
|
//# sourceMappingURL=powTasks.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"powTasks.d.ts","sourceRoot":"","sources":["../../../src/tasks/powCaptcha/powTasks.ts"],"names":[],"mappings":"AAaA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAO3D,OAAO,EAIN,KAAK,SAAS,EAEd,KAAK,UAAU,EACf,KAAK,cAAc,
|
|
1
|
+
{"version":3,"file":"powTasks.d.ts","sourceRoot":"","sources":["../../../src/tasks/powCaptcha/powTasks.ts"],"names":[],"mappings":"AAaA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAO3D,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAIN,KAAK,SAAS,EAEd,KAAK,UAAU,EACf,KAAK,cAAc,EAEnB,KAAK,cAAc,EACnB,MAAM,gBAAgB,CAAC;AACxB,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAEjE,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAMtD,qBAAa,iBAAkB,SAAQ,cAAc;IACpD,aAAa,EAAE,MAAM,CAAC;gBAEV,EAAE,EAAE,iBAAiB,EAAE,IAAI,EAAE,WAAW,EAAE,MAAM,CAAC,EAAE,MAAM;IAa/D,sBAAsB,CAC3B,WAAW,EAAE,MAAM,EACnB,WAAW,EAAE,MAAM,EACnB,MAAM,EAAE,MAAM,EACd,aAAa,CAAC,EAAE,MAAM,GACpB,OAAO,CAAC,UAAU,CAAC;IA8BhB,wBAAwB,CAC7B,SAAS,EAAE,cAAc,EACzB,UAAU,EAAE,MAAM,EAClB,0BAA0B,EAAE,MAAM,EAClC,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,MAAM,EACf,sBAAsB,EAAE,MAAM,EAC9B,SAAS,EAAE,SAAS,EACpB,OAAO,EAAE,cAAc,GACrB,OAAO,CAAC,OAAO,CAAC;IAuEb,8BAA8B,CACnC,WAAW,EAAE,MAAM,EACnB,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,MAAM,GACb,OAAO,CAAC;QAAE,QAAQ,EAAE,OAAO,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;CAsDjD"}
|
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
import { stringToHex, u8aToHex } from "@polkadot/util";
|
|
2
|
-
import { ProsopoApiError, ProsopoEnvError,
|
|
2
|
+
import { ProsopoApiError, ProsopoEnvError, } from "@prosopo/common";
|
|
3
3
|
import { ApiParams, CaptchaStatus, POW_SEPARATOR, } from "@prosopo/types";
|
|
4
4
|
import { at, verifyRecency } from "@prosopo/util";
|
|
5
|
+
import { CaptchaManager } from "../captchaManager.js";
|
|
6
|
+
import { computeFrictionlessScore } from "../frictionless/frictionlessTasksUtils.js";
|
|
5
7
|
import { checkPowSignature, validateSolution } from "./powTasksUtils.js";
|
|
6
|
-
const logger = getLoggerDefault();
|
|
7
8
|
const DEFAULT_POW_DIFFICULTY = 4;
|
|
8
|
-
export class PowCaptchaManager {
|
|
9
|
-
constructor(pair,
|
|
10
|
-
|
|
11
|
-
this.db = db;
|
|
9
|
+
export class PowCaptchaManager extends CaptchaManager {
|
|
10
|
+
constructor(db, pair, logger) {
|
|
11
|
+
super(db, pair, logger);
|
|
12
12
|
this.POW_SEPARATOR = POW_SEPARATOR;
|
|
13
13
|
}
|
|
14
14
|
async getPowCaptchaChallenge(userAccount, dappAccount, origin, powDifficulty) {
|
|
@@ -32,7 +32,7 @@ export class PowCaptchaManager {
|
|
|
32
32
|
checkPowSignature(timestamp.toString(), userTimestampSignature, userAccount, ApiParams.timestamp);
|
|
33
33
|
const challengeRecord = await this.db.getPowCaptchaRecordByChallenge(challenge);
|
|
34
34
|
if (!challengeRecord) {
|
|
35
|
-
logger.debug("No record of this challenge");
|
|
35
|
+
this.logger.debug("No record of this challenge");
|
|
36
36
|
return false;
|
|
37
37
|
}
|
|
38
38
|
if (!verifyRecency(challenge, timeout)) {
|
|
@@ -56,12 +56,8 @@ export class PowCaptchaManager {
|
|
|
56
56
|
async serverVerifyPowCaptchaSolution(dappAccount, challenge, timeout) {
|
|
57
57
|
const challengeRecord = await this.db.getPowCaptchaRecordByChallenge(challenge);
|
|
58
58
|
if (!challengeRecord) {
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
failedFuncName: this.serverVerifyPowCaptchaSolution.name,
|
|
62
|
-
challenge,
|
|
63
|
-
},
|
|
64
|
-
});
|
|
59
|
+
this.logger.debug(`No record of this challenge: ${challenge}`);
|
|
60
|
+
return { verified: false };
|
|
65
61
|
}
|
|
66
62
|
if (challengeRecord.result.status !== CaptchaStatus.approved) {
|
|
67
63
|
throw new ProsopoApiError("CAPTCHA.INVALID_SOLUTION", {
|
|
@@ -72,7 +68,7 @@ export class PowCaptchaManager {
|
|
|
72
68
|
});
|
|
73
69
|
}
|
|
74
70
|
if (challengeRecord.serverChecked)
|
|
75
|
-
return false;
|
|
71
|
+
return { verified: false };
|
|
76
72
|
const challengeDappAccount = challengeRecord.dappAccount;
|
|
77
73
|
if (dappAccount !== challengeDappAccount) {
|
|
78
74
|
throw new ProsopoEnvError("CAPTCHA.DAPP_USER_SOLUTION_NOT_FOUND", {
|
|
@@ -87,7 +83,18 @@ export class PowCaptchaManager {
|
|
|
87
83
|
await this.db.markDappUserPoWCommitmentsChecked([
|
|
88
84
|
challengeRecord.challenge,
|
|
89
85
|
]);
|
|
90
|
-
|
|
86
|
+
let score;
|
|
87
|
+
if (challengeRecord.frictionlessTokenId) {
|
|
88
|
+
const tokenRecord = await this.db.getFrictionlessTokenRecordByTokenId(challengeRecord.frictionlessTokenId);
|
|
89
|
+
if (tokenRecord) {
|
|
90
|
+
score = computeFrictionlessScore(tokenRecord?.scoreComponents);
|
|
91
|
+
this.logger.info({
|
|
92
|
+
tscoreComponents: tokenRecord?.scoreComponents,
|
|
93
|
+
score: score,
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
return { verified: true, ...(score ? { score } : {}) };
|
|
91
98
|
}
|
|
92
99
|
}
|
|
93
100
|
//# sourceMappingURL=powTasks.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"powTasks.js","sourceRoot":"","sources":["../../../src/tasks/powCaptcha/powTasks.ts"],"names":[],"mappings":"AAcA,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AACvD,OAAO,EACN,eAAe,EACf,eAAe,
|
|
1
|
+
{"version":3,"file":"powTasks.js","sourceRoot":"","sources":["../../../src/tasks/powCaptcha/powTasks.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tasks.d.ts","sourceRoot":"","sources":["../../src/tasks/tasks.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAC3D,OAAO,EAAE,KAAK,MAAM,EAA8B,MAAM,iBAAiB,CAAC;AAc1E,OAAO,KAAK,EACX,qCAAqC,EACrC,mBAAmB,EACnB,MAAM,gBAAgB,CAAC;AACxB,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AACjE,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAC9D,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAC5D,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAC3D,OAAO,EAAE,mBAAmB,EAAE,MAAM,qCAAqC,CAAC;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAC;AACpE,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAK7D,qBAAa,KAAK;IACjB,EAAE,EAAE,iBAAiB,CAAC;IACtB,aAAa,EAAE,qCAAqC,CAAC;IACrD,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,mBAAmB,CAAC;IAC5B,IAAI,EAAE,WAAW,CAAC;IAClB,iBAAiB,EAAE,iBAAiB,CAAC;IACrC,cAAc,EAAE,cAAc,CAAC;IAC/B,iBAAiB,EAAE,iBAAiB,CAAC;IACrC,iBAAiB,EAAE,iBAAiB,CAAC;IACrC,mBAAmB,EAAE,mBAAmB,CAAC;gBAE7B,GAAG,EAAE,mBAAmB;
|
|
1
|
+
{"version":3,"file":"tasks.d.ts","sourceRoot":"","sources":["../../src/tasks/tasks.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAC3D,OAAO,EAAE,KAAK,MAAM,EAA8B,MAAM,iBAAiB,CAAC;AAc1E,OAAO,KAAK,EACX,qCAAqC,EACrC,mBAAmB,EACnB,MAAM,gBAAgB,CAAC;AACxB,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AACjE,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAC9D,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAC5D,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAC3D,OAAO,EAAE,mBAAmB,EAAE,MAAM,qCAAqC,CAAC;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAC;AACpE,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAK7D,qBAAa,KAAK;IACjB,EAAE,EAAE,iBAAiB,CAAC;IACtB,aAAa,EAAE,qCAAqC,CAAC;IACrD,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,mBAAmB,CAAC;IAC5B,IAAI,EAAE,WAAW,CAAC;IAClB,iBAAiB,EAAE,iBAAiB,CAAC;IACrC,cAAc,EAAE,cAAc,CAAC;IAC/B,iBAAiB,EAAE,iBAAiB,CAAC;IACrC,iBAAiB,EAAE,iBAAiB,CAAC;IACrC,mBAAmB,EAAE,mBAAmB,CAAC;gBAE7B,GAAG,EAAE,mBAAmB;CAyCpC"}
|
package/dist/tasks/tasks.js
CHANGED
|
@@ -16,11 +16,11 @@ export class Tasks {
|
|
|
16
16
|
});
|
|
17
17
|
}
|
|
18
18
|
this.pair = env.pair;
|
|
19
|
-
this.powCaptchaManager = new PowCaptchaManager(this.pair, this.
|
|
19
|
+
this.powCaptchaManager = new PowCaptchaManager(this.db, this.pair, this.logger);
|
|
20
20
|
this.datasetManager = new DatasetManager(this.config, this.logger, this.captchaConfig, this.db);
|
|
21
|
-
this.imgCaptchaManager = new ImgCaptchaManager(this.db, this.pair, this.
|
|
21
|
+
this.imgCaptchaManager = new ImgCaptchaManager(this.db, this.pair, this.config, this.logger);
|
|
22
22
|
this.clientTaskManager = new ClientTaskManager(this.config, this.logger, this.db);
|
|
23
|
-
this.frictionlessManager = new FrictionlessManager(this.
|
|
23
|
+
this.frictionlessManager = new FrictionlessManager(this.db, this.pair, this.config, this.logger);
|
|
24
24
|
}
|
|
25
25
|
}
|
|
26
26
|
//# sourceMappingURL=tasks.js.map
|
package/dist/tasks/tasks.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tasks.js","sourceRoot":"","sources":["../../src/tasks/tasks.ts"],"names":[],"mappings":"AACA,OAAO,EAAe,eAAe,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAoB1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAC5D,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAC3D,OAAO,EAAE,mBAAmB,EAAE,MAAM,qCAAqC,CAAC;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAC;AACpE,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAK7D,MAAM,OAAO,KAAK;IAYjB,YAAY,GAAwB;QACnC,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC;QACzB,IAAI,CAAC,EAAE,GAAG,GAAG,CAAC,KAAK,EAAE,CAAC;QACtB,IAAI,CAAC,aAAa,GAAG,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC;QACzC,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;QACtD,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC;YACf,MAAM,IAAI,eAAe,CAAC,iCAAiC,EAAE;gBAC5D,OAAO,EAAE,EAAE,cAAc,EAAE,mBAAmB,EAAE;aAChD,CAAC,CAAC;QACJ,CAAC;QACD,IAAI,CAAC,IAAI,GAAG,GAAG,CAAC,IAAI,CAAC;QAErB,IAAI,CAAC,iBAAiB,GAAG,IAAI,iBAAiB,CAAC,IAAI,CAAC,IAAI,
|
|
1
|
+
{"version":3,"file":"tasks.js","sourceRoot":"","sources":["../../src/tasks/tasks.ts"],"names":[],"mappings":"AACA,OAAO,EAAe,eAAe,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAoB1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAC5D,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAC3D,OAAO,EAAE,mBAAmB,EAAE,MAAM,qCAAqC,CAAC;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAC;AACpE,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAK7D,MAAM,OAAO,KAAK;IAYjB,YAAY,GAAwB;QACnC,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC;QACzB,IAAI,CAAC,EAAE,GAAG,GAAG,CAAC,KAAK,EAAE,CAAC;QACtB,IAAI,CAAC,aAAa,GAAG,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC;QACzC,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;QACtD,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC;YACf,MAAM,IAAI,eAAe,CAAC,iCAAiC,EAAE;gBAC5D,OAAO,EAAE,EAAE,cAAc,EAAE,mBAAmB,EAAE;aAChD,CAAC,CAAC;QACJ,CAAC;QACD,IAAI,CAAC,IAAI,GAAG,GAAG,CAAC,IAAI,CAAC;QAErB,IAAI,CAAC,iBAAiB,GAAG,IAAI,iBAAiB,CAC7C,IAAI,CAAC,EAAE,EACP,IAAI,CAAC,IAAI,EACT,IAAI,CAAC,MAAM,CACX,CAAC;QACF,IAAI,CAAC,cAAc,GAAG,IAAI,cAAc,CACvC,IAAI,CAAC,MAAM,EACX,IAAI,CAAC,MAAM,EACX,IAAI,CAAC,aAAa,EAClB,IAAI,CAAC,EAAE,CACP,CAAC;QACF,IAAI,CAAC,iBAAiB,GAAG,IAAI,iBAAiB,CAC7C,IAAI,CAAC,EAAE,EACP,IAAI,CAAC,IAAI,EACT,IAAI,CAAC,MAAM,EACX,IAAI,CAAC,MAAM,CACX,CAAC;QACF,IAAI,CAAC,iBAAiB,GAAG,IAAI,iBAAiB,CAC7C,IAAI,CAAC,MAAM,EACX,IAAI,CAAC,MAAM,EACX,IAAI,CAAC,EAAE,CACP,CAAC;QACF,IAAI,CAAC,mBAAmB,GAAG,IAAI,mBAAmB,CACjD,IAAI,CAAC,EAAE,EACP,IAAI,CAAC,IAAI,EACT,IAAI,CAAC,MAAM,EACX,IAAI,CAAC,MAAM,CACX,CAAC;IACH,CAAC;CACD"}
|
|
@@ -1,20 +1,22 @@
|
|
|
1
1
|
import { stringToU8a, u8aToHex } from "@polkadot/util";
|
|
2
2
|
import { datasetWithSolutionHashes } from "@prosopo/datasets";
|
|
3
3
|
import { generateMnemonic, getPairAsync } from "@prosopo/keyring";
|
|
4
|
-
import { ApiParams, ApiPaths, } from "@prosopo/types";
|
|
4
|
+
import { ApiParams, ApiPaths, CaptchaType, } from "@prosopo/types";
|
|
5
5
|
import fetch from "node-fetch";
|
|
6
|
-
import {
|
|
6
|
+
import { beforeEach, describe, expect, it } from "vitest";
|
|
7
7
|
import { dummyUserAccount } from "./mocks/solvedTestCaptchas.js";
|
|
8
8
|
import { registerSiteKey } from "./registerSitekey.js";
|
|
9
9
|
const solutions = datasetWithSolutionHashes;
|
|
10
10
|
const baseUrl = "http://localhost:9229";
|
|
11
|
-
const dappAccount = "5GrwvaEF5zXb26Fz9rcQpDWS57CtERHpNehXCPcNoHGKutQY";
|
|
12
11
|
const userAccount = "5FHneW46xGXgs5mUiveU4sbTyGBzmstUspZC92UhjJM694ty";
|
|
13
12
|
describe("Image Captcha Integration Tests", () => {
|
|
13
|
+
let dappAccount;
|
|
14
|
+
let mnemonic;
|
|
15
|
+
beforeEach(async () => {
|
|
16
|
+
[mnemonic, dappAccount] = await generateMnemonic();
|
|
17
|
+
await registerSiteKey(dappAccount, CaptchaType.image);
|
|
18
|
+
});
|
|
14
19
|
describe("GetImageCaptchaChallenge", () => {
|
|
15
|
-
beforeAll(async () => {
|
|
16
|
-
await registerSiteKey(dappAccount);
|
|
17
|
-
});
|
|
18
20
|
it("should supply an image captcha challenge to a Dapp User", async () => {
|
|
19
21
|
const origin = "http://localhost";
|
|
20
22
|
const getImageCaptchaURL = `${baseUrl}${ApiPaths.GetImageCaptchaChallenge}`;
|
|
@@ -80,8 +82,8 @@ describe("Image Captcha Integration Tests", () => {
|
|
|
80
82
|
"Prosopo-User": userAccount,
|
|
81
83
|
},
|
|
82
84
|
});
|
|
83
|
-
expect(response.status).toBe(400);
|
|
84
85
|
const data = (await response.json());
|
|
86
|
+
expect(response.status).toBe(400);
|
|
85
87
|
expect(data).toHaveProperty("error");
|
|
86
88
|
expect(data.error?.message).toBe("Invalid site key");
|
|
87
89
|
});
|
|
@@ -106,6 +108,56 @@ describe("Image Captcha Integration Tests", () => {
|
|
|
106
108
|
});
|
|
107
109
|
expect(response.status).toBe(500);
|
|
108
110
|
});
|
|
111
|
+
it("should return an error if the captcha type is set to pow", async () => {
|
|
112
|
+
const origin = "http://localhost";
|
|
113
|
+
const getImageCaptchaURL = `${baseUrl}${ApiPaths.GetImageCaptchaChallenge}`;
|
|
114
|
+
await registerSiteKey(dappAccount, CaptchaType.pow);
|
|
115
|
+
const body = {
|
|
116
|
+
[ApiParams.dapp]: dappAccount,
|
|
117
|
+
[ApiParams.user]: userAccount,
|
|
118
|
+
[ApiParams.datasetId]: solutions.datasetId,
|
|
119
|
+
};
|
|
120
|
+
const response = await fetch(getImageCaptchaURL, {
|
|
121
|
+
method: "POST",
|
|
122
|
+
body: JSON.stringify(body),
|
|
123
|
+
headers: {
|
|
124
|
+
"Content-Type": "application/json",
|
|
125
|
+
Origin: origin,
|
|
126
|
+
"Prosopo-Site-Key": dappAccount,
|
|
127
|
+
"Prosopo-User": userAccount,
|
|
128
|
+
},
|
|
129
|
+
});
|
|
130
|
+
expect(response.status).toBe(400);
|
|
131
|
+
const data = (await response.json());
|
|
132
|
+
expect(data).toHaveProperty("error");
|
|
133
|
+
expect(data.error?.message).toBe("Incorrect CAPTCHA type");
|
|
134
|
+
expect(data.error?.code).toBe(400);
|
|
135
|
+
});
|
|
136
|
+
});
|
|
137
|
+
it("should return an error if the captcha type is set to frictionless and no sessionID is sent", async () => {
|
|
138
|
+
const origin = "http://localhost";
|
|
139
|
+
const getImageCaptchaURL = `${baseUrl}${ApiPaths.GetImageCaptchaChallenge}`;
|
|
140
|
+
await registerSiteKey(dappAccount, CaptchaType.frictionless);
|
|
141
|
+
const body = {
|
|
142
|
+
[ApiParams.dapp]: dappAccount,
|
|
143
|
+
[ApiParams.user]: userAccount,
|
|
144
|
+
[ApiParams.datasetId]: solutions.datasetId,
|
|
145
|
+
};
|
|
146
|
+
const response = await fetch(getImageCaptchaURL, {
|
|
147
|
+
method: "POST",
|
|
148
|
+
body: JSON.stringify(body),
|
|
149
|
+
headers: {
|
|
150
|
+
"Content-Type": "application/json",
|
|
151
|
+
Origin: origin,
|
|
152
|
+
"Prosopo-Site-Key": dappAccount,
|
|
153
|
+
"Prosopo-User": userAccount,
|
|
154
|
+
},
|
|
155
|
+
});
|
|
156
|
+
expect(response.status).toBe(400);
|
|
157
|
+
const data = (await response.json());
|
|
158
|
+
expect(data).toHaveProperty("error");
|
|
159
|
+
expect(data.error?.message).toBe("Incorrect CAPTCHA type");
|
|
160
|
+
expect(data.error?.code).toBe(400);
|
|
109
161
|
});
|
|
110
162
|
describe("SubmitImageCaptchaSolution", () => {
|
|
111
163
|
it("should verify a correctly completed image captcha as true", async () => {
|