@prosopo/provider 2.3.2 → 2.4.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.
- 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 +4 -1
- package/dist/api/authMiddleware.js.map +1 -1
- package/dist/api/captcha.d.ts.map +1 -1
- package/dist/api/captcha.js +81 -83
- package/dist/api/captcha.js.map +1 -1
- package/dist/api/domainMiddleware.d.ts.map +1 -1
- package/dist/api/domainMiddleware.js +7 -6
- 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 +6 -14
- 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 +4 -12
- 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 +7 -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 +14 -13
- 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
|
@@ -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 () => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"imgCaptcha.integration.test.js","sourceRoot":"","sources":["../../../src/tests/integration/imgCaptcha.integration.test.ts"],"names":[],"mappings":"AAaA,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AACvD,OAAO,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAC9D,OAAO,EAAE,gBAAgB,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAClE,OAAO,EACN,SAAS,EACT,QAAQ,
|
|
1
|
+
{"version":3,"file":"imgCaptcha.integration.test.js","sourceRoot":"","sources":["../../../src/tests/integration/imgCaptcha.integration.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { sha256 } from "@noble/hashes/sha256";
|
|
2
2
|
import { u8aToHex } from "@polkadot/util/u8a";
|
|
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
6
|
import { beforeAll, describe, expect, it } from "vitest";
|
|
7
7
|
import { dummyDappAccount, dummyUserAccount, } from "./mocks/solvedTestCaptchas.js";
|
|
@@ -40,7 +40,7 @@ const failPoW = (data, difficulty) => {
|
|
|
40
40
|
describe("PoW Integration Tests", () => {
|
|
41
41
|
describe("GetPowCaptchaChallenge", () => {
|
|
42
42
|
beforeAll(async () => {
|
|
43
|
-
await registerSiteKey(dappAccount);
|
|
43
|
+
await registerSiteKey(dappAccount, CaptchaType.pow);
|
|
44
44
|
});
|
|
45
45
|
it("should supply a PoW challenge to a Dapp User", async () => {
|
|
46
46
|
const origin = "http://localhost";
|
|
@@ -100,12 +100,12 @@ describe("PoW Integration Tests", () => {
|
|
|
100
100
|
it("should verify a correctly completed PoW captcha as true", async () => {
|
|
101
101
|
const userPair = await getPairAsync(dummyUserAccount.seed, undefined, "sr25519", 42);
|
|
102
102
|
const dappPair = await getPairAsync(dummyDappAccount.seed, undefined, "sr25519", 42);
|
|
103
|
-
const
|
|
104
|
-
await registerSiteKey(
|
|
103
|
+
const dummyDappAccountAddr = dappPair.address;
|
|
104
|
+
await registerSiteKey(dummyDappAccountAddr, CaptchaType.pow);
|
|
105
105
|
const origin = "http://localhost";
|
|
106
106
|
const requestBody = {
|
|
107
107
|
user: userPair.address,
|
|
108
|
-
dapp:
|
|
108
|
+
dapp: dummyDappAccountAddr,
|
|
109
109
|
};
|
|
110
110
|
const captchaRes = await fetch(`${baseUrl}${getPowCaptchaChallengePath}`, {
|
|
111
111
|
method: "POST",
|
|
@@ -113,7 +113,7 @@ describe("PoW Integration Tests", () => {
|
|
|
113
113
|
Connection: "close",
|
|
114
114
|
"Content-Type": "application/json",
|
|
115
115
|
Origin: origin,
|
|
116
|
-
"Prosopo-Site-Key":
|
|
116
|
+
"Prosopo-Site-Key": dummyDappAccountAddr,
|
|
117
117
|
"Prosopo-User": userAccount,
|
|
118
118
|
},
|
|
119
119
|
body: JSON.stringify(requestBody),
|
|
@@ -136,7 +136,7 @@ describe("PoW Integration Tests", () => {
|
|
|
136
136
|
nonce,
|
|
137
137
|
verifiedTimeout,
|
|
138
138
|
user: userPair.address,
|
|
139
|
-
dapp:
|
|
139
|
+
dapp: dummyDappAccountAddr,
|
|
140
140
|
};
|
|
141
141
|
const response = await fetch(`${baseUrl}${ApiPaths.SubmitPowCaptchaSolution}`, {
|
|
142
142
|
method: "POST",
|
|
@@ -144,7 +144,7 @@ describe("PoW Integration Tests", () => {
|
|
|
144
144
|
Connection: "close",
|
|
145
145
|
"Content-Type": "application/json",
|
|
146
146
|
Origin: origin,
|
|
147
|
-
"Prosopo-Site-Key":
|
|
147
|
+
"Prosopo-Site-Key": dummyDappAccountAddr,
|
|
148
148
|
"Prosopo-User": userAccount,
|
|
149
149
|
},
|
|
150
150
|
body: JSON.stringify(submitBody),
|
|
@@ -158,16 +158,18 @@ describe("PoW Integration Tests", () => {
|
|
|
158
158
|
const userPair = await getPairAsync(dummyUserAccount.seed, undefined, "sr25519", 42);
|
|
159
159
|
const userAccount = userPair.address;
|
|
160
160
|
const origin = "http://localhost";
|
|
161
|
+
const dapp = "5C7bfXYwachNuvmasEFtWi9BMS41uBvo6KpYHVSQmad4nWzw";
|
|
162
|
+
await registerSiteKey(dapp, CaptchaType.pow);
|
|
161
163
|
const captchaRes = await fetch(`${baseUrl}${getPowCaptchaChallengePath}`, {
|
|
162
164
|
method: "POST",
|
|
163
165
|
headers: {
|
|
164
166
|
Connection: "close",
|
|
165
167
|
"Content-Type": "application/json",
|
|
166
168
|
Origin: origin,
|
|
167
|
-
"Prosopo-Site-Key":
|
|
169
|
+
"Prosopo-Site-Key": dapp,
|
|
168
170
|
"Prosopo-User": userAccount,
|
|
169
171
|
},
|
|
170
|
-
body: JSON.stringify({ user: userAccount, dapp:
|
|
172
|
+
body: JSON.stringify({ user: userAccount, dapp: dapp }),
|
|
171
173
|
});
|
|
172
174
|
const challengeBody = (await captchaRes.json());
|
|
173
175
|
const challenge = challengeBody.challenge;
|
|
@@ -175,8 +177,6 @@ describe("PoW Integration Tests", () => {
|
|
|
175
177
|
const signature = challengeBody.signature;
|
|
176
178
|
const nonce = failPoW(challenge, difficulty);
|
|
177
179
|
const verifiedTimeout = 120000;
|
|
178
|
-
const dapp = "5C7bfXYwachNuvmasEFtWi9BMS41uBvo6KpYHVSQmad4nWzw";
|
|
179
|
-
await registerSiteKey(dapp);
|
|
180
180
|
const body = {
|
|
181
181
|
challenge,
|
|
182
182
|
difficulty,
|
|
@@ -197,7 +197,7 @@ describe("PoW Integration Tests", () => {
|
|
|
197
197
|
Connection: "close",
|
|
198
198
|
"Content-Type": "application/json",
|
|
199
199
|
Origin: origin,
|
|
200
|
-
"Prosopo-Site-Key":
|
|
200
|
+
"Prosopo-Site-Key": dapp,
|
|
201
201
|
"Prosopo-User": userAccount,
|
|
202
202
|
},
|
|
203
203
|
body: JSON.stringify(body),
|
|
@@ -251,5 +251,49 @@ describe("PoW Integration Tests", () => {
|
|
|
251
251
|
expect(challengeBody).toHaveProperty("error");
|
|
252
252
|
expect(challengeBody.error?.message).toBe("Invalid site key");
|
|
253
253
|
});
|
|
254
|
+
it("should return an error if the captcha type is set to image", async () => {
|
|
255
|
+
const userPair = await getPairAsync(dummyUserAccount.seed, undefined, "sr25519");
|
|
256
|
+
const userAccount = userPair.address;
|
|
257
|
+
const origin = "http://localhost";
|
|
258
|
+
const dapp = "5C7bfXYwachNuvmasEFtWi9BMS41uBvo6KpYHVSQmad4nWzw";
|
|
259
|
+
await registerSiteKey(dapp, CaptchaType.image);
|
|
260
|
+
const captchaRes = await fetch(`${baseUrl}${getPowCaptchaChallengePath}`, {
|
|
261
|
+
method: "POST",
|
|
262
|
+
headers: {
|
|
263
|
+
Connection: "close",
|
|
264
|
+
"Content-Type": "application/json",
|
|
265
|
+
Origin: origin,
|
|
266
|
+
"Prosopo-Site-Key": dapp,
|
|
267
|
+
"Prosopo-User": userAccount,
|
|
268
|
+
},
|
|
269
|
+
body: JSON.stringify({ user: userAccount, dapp }),
|
|
270
|
+
});
|
|
271
|
+
const challengeBody = (await captchaRes.json());
|
|
272
|
+
expect(challengeBody).toHaveProperty("error");
|
|
273
|
+
expect(challengeBody.error?.message).toBe("Incorrect CAPTCHA type");
|
|
274
|
+
expect(challengeBody.error?.code).toBe(400);
|
|
275
|
+
});
|
|
276
|
+
it("should return an error if the captcha type is set to frictionless and no sessionID is sent", async () => {
|
|
277
|
+
const userPair = await getPairAsync(dummyUserAccount.seed, undefined, "sr25519");
|
|
278
|
+
const userAccount = userPair.address;
|
|
279
|
+
const origin = "http://localhost";
|
|
280
|
+
const [mnemonic, dapp] = await generateMnemonic();
|
|
281
|
+
await registerSiteKey(dapp, CaptchaType.frictionless);
|
|
282
|
+
const captchaRes = await fetch(`${baseUrl}${getPowCaptchaChallengePath}`, {
|
|
283
|
+
method: "POST",
|
|
284
|
+
headers: {
|
|
285
|
+
Connection: "close",
|
|
286
|
+
"Content-Type": "application/json",
|
|
287
|
+
Origin: origin,
|
|
288
|
+
"Prosopo-Site-Key": dapp,
|
|
289
|
+
"Prosopo-User": userAccount,
|
|
290
|
+
},
|
|
291
|
+
body: JSON.stringify({ user: userAccount, dapp }),
|
|
292
|
+
});
|
|
293
|
+
const challengeBody = (await captchaRes.json());
|
|
294
|
+
expect(challengeBody).toHaveProperty("error");
|
|
295
|
+
expect(challengeBody.error?.message).toBe("Incorrect CAPTCHA type");
|
|
296
|
+
expect(challengeBody.error?.code).toBe(400);
|
|
297
|
+
});
|
|
254
298
|
});
|
|
255
299
|
//# sourceMappingURL=powCaptcha.integration.test.js.map
|