@netacea/akamai 5.0.49 → 5.0.50
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/CHANGELOG.md +8 -0
- package/dist/package.json +3 -3
- package/dist/src/AkamaiV1.d.ts +1 -1
- package/dist/src/AkamaiV2.js +16 -0
- package/dist/src/AkamaiV2.js.map +1 -1
- package/dist/src/CachedEncryption.d.ts +5 -2
- package/dist/src/CachedEncryption.js +11 -0
- package/dist/src/CachedEncryption.js.map +1 -1
- package/dist/src/ConfigLoader.d.ts +1 -6
- package/dist/src/ConfigLoader.js +8 -1
- package/dist/src/ConfigLoader.js.map +1 -1
- package/dist/src/captchaGet.d.ts +4 -0
- package/dist/src/captchaGet.js +63 -0
- package/dist/src/captchaGet.js.map +1 -0
- package/dist/src/errors/APIError.d.ts +4 -0
- package/dist/src/errors/APIError.js +24 -0
- package/dist/src/errors/APIError.js.map +1 -0
- package/dist/src/helpers/buildCookieFromValues.d.ts +2 -0
- package/dist/src/helpers/buildCookieFromValues.js +13 -0
- package/dist/src/helpers/buildCookieFromValues.js.map +1 -0
- package/dist/src/helpers/buildCookieHeader.d.ts +3 -0
- package/dist/src/helpers/buildCookieHeader.js +7 -0
- package/dist/src/helpers/buildCookieHeader.js.map +1 -0
- package/dist/src/helpers/constructWebLog.d.ts +3 -0
- package/dist/src/helpers/constructWebLog.js +60 -0
- package/dist/src/helpers/constructWebLog.js.map +1 -0
- package/dist/src/helpers/createMitata.d.ts +13 -0
- package/dist/src/helpers/createMitata.js +15 -0
- package/dist/src/helpers/createMitata.js.map +1 -0
- package/dist/src/helpers/createProtoMitata.d.ts +1 -0
- package/dist/src/helpers/createProtoMitata.js +13 -0
- package/dist/src/helpers/createProtoMitata.js.map +1 -0
- package/dist/src/helpers/encryptionCheck.d.ts +1 -0
- package/dist/src/helpers/encryptionCheck.js +5 -0
- package/dist/src/helpers/encryptionCheck.js.map +1 -0
- package/dist/src/helpers/findBestMitigation.d.ts +3 -0
- package/dist/src/helpers/findBestMitigation.js +35 -0
- package/dist/src/helpers/findBestMitigation.js.map +1 -0
- package/dist/src/helpers/getHeaderValueOrDefault.d.ts +3 -0
- package/dist/src/helpers/getHeaderValueOrDefault.js +5 -0
- package/dist/src/helpers/getHeaderValueOrDefault.js.map +1 -0
- package/dist/src/helpers/getMitataCaptchaFromHeaders.d.ts +4 -0
- package/dist/src/helpers/getMitataCaptchaFromHeaders.js +14 -0
- package/dist/src/helpers/getMitataCaptchaFromHeaders.js.map +1 -0
- package/dist/src/helpers/getProtoMitataFromRequestVar.d.ts +3 -0
- package/dist/src/helpers/getProtoMitataFromRequestVar.js +13 -0
- package/dist/src/helpers/getProtoMitataFromRequestVar.js.map +1 -0
- package/dist/src/helpers/getQuery.d.ts +1 -0
- package/dist/src/helpers/getQuery.js +11 -0
- package/dist/src/helpers/getQuery.js.map +1 -0
- package/dist/src/helpers/getResponseHeaders.d.ts +5 -0
- package/dist/src/helpers/getResponseHeaders.js +9 -0
- package/dist/src/helpers/getResponseHeaders.js.map +1 -0
- package/dist/src/helpers/getVariable.d.ts +2 -0
- package/dist/src/helpers/getVariable.js +4 -0
- package/dist/src/helpers/getVariable.js.map +1 -0
- package/dist/src/helpers/logToDataStream.d.ts +3 -0
- package/dist/src/helpers/logToDataStream.js +31 -0
- package/dist/src/helpers/logToDataStream.js.map +1 -0
- package/dist/src/helpers/makeRequest.d.ts +3 -0
- package/dist/src/helpers/makeRequest.js +38 -0
- package/dist/src/helpers/makeRequest.js.map +1 -0
- package/dist/src/helpers/readCookie.d.ts +2 -0
- package/dist/src/helpers/readCookie.js +28 -0
- package/dist/src/helpers/readCookie.js.map +1 -0
- package/dist/src/index.d.ts +2 -1
- package/dist/src/index.js.map +1 -1
- package/dist/src/ingest/ingest.d.ts +3 -0
- package/dist/src/ingest/ingest.js +47 -0
- package/dist/src/ingest/ingest.js.map +1 -0
- package/dist/src/ingest/makeIngestAPICall.d.ts +6 -0
- package/dist/src/ingest/makeIngestAPICall.js +28 -0
- package/dist/src/ingest/makeIngestAPICall.js.map +1 -0
- package/dist/src/mitigation/getApiCallResponseFromResponse.d.ts +3 -0
- package/dist/src/mitigation/getApiCallResponseFromResponse.js +43 -0
- package/dist/src/mitigation/getApiCallResponseFromResponse.js.map +1 -0
- package/dist/src/mitigation/mitigationApiCall.d.ts +15 -0
- package/dist/src/mitigation/mitigationApiCall.js +45 -0
- package/dist/src/mitigation/mitigationApiCall.js.map +1 -0
- package/dist/src/netaceaPaths.d.ts +1 -0
- package/dist/src/netaceaPaths.js +6 -0
- package/dist/src/netaceaPaths.js.map +1 -1
- package/dist/src/types.d.ts +57 -0
- package/dist/src/types.js +2 -0
- package/dist/src/types.js.map +1 -0
- package/package.json +3 -3
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,14 @@
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
+
## 5.0.50 (2023-09-15)
|
|
7
|
+
|
|
8
|
+
**Note:** Version bump only for package @netacea/akamai
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
|
|
6
14
|
## 5.0.49 (2023-09-04)
|
|
7
15
|
|
|
8
16
|
**Note:** Version bump only for package @netacea/akamai
|
package/dist/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@netacea/akamai",
|
|
3
|
-
"version": "5.0.
|
|
3
|
+
"version": "5.0.50",
|
|
4
4
|
"description": "Netacea Akamai CDN Integration",
|
|
5
5
|
"main": "dist/src/index.js",
|
|
6
6
|
"types": "dist/src/index.d.ts",
|
|
@@ -20,7 +20,7 @@
|
|
|
20
20
|
},
|
|
21
21
|
"license": "ISC",
|
|
22
22
|
"dependencies": {
|
|
23
|
-
"@netacea/netaceaintegrationbase": "^1.16.
|
|
23
|
+
"@netacea/netaceaintegrationbase": "^1.16.56",
|
|
24
24
|
"buffer": "^6.0.3",
|
|
25
25
|
"jssha": "^3.3.0"
|
|
26
26
|
},
|
|
@@ -67,5 +67,5 @@
|
|
|
67
67
|
"tslib": "^2.0.3",
|
|
68
68
|
"typescript": "^4.0.3"
|
|
69
69
|
},
|
|
70
|
-
"gitHead": "
|
|
70
|
+
"gitHead": "c9fda244751fa68f83dfd4b84c61670e4323a265"
|
|
71
71
|
}
|
package/dist/src/AkamaiV1.d.ts
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
import { InjectResponse, ComposeResultResponse, MakeRequestArgs, MakeRequestResponse, MitigateResponse, NetaceaBaseArgs, NetaceaMitigationType, NetaceaIngestType, NetaceaLogVersion, NetaceaMitigationResponse, IngestArgs, WebLog, V2WebLog, FindBestMitigationResponse, APICallResponse, NetaceaResponseBase, ProcessMitigateRequestArgs, NetaceaWorker } from '@netacea/netaceaintegrationbase';
|
|
3
3
|
import { CachedEncryption } from './CachedEncryption';
|
|
4
4
|
import type { HttpResponse, RequestBody } from 'http-request';
|
|
5
|
-
import { AkamaiWorkerConfig } from './
|
|
5
|
+
import { AkamaiWorkerConfig } from './types';
|
|
6
6
|
export interface ResponseProperties {
|
|
7
7
|
headers: Record<string, string>;
|
|
8
8
|
body?: string | undefined;
|
package/dist/src/AkamaiV2.js
CHANGED
|
@@ -1,13 +1,22 @@
|
|
|
1
1
|
import AkamaiLegacyWorker from './AkamaiV1';
|
|
2
2
|
import { httpRequest } from 'http-request';
|
|
3
3
|
import { logger } from 'log';
|
|
4
|
+
import { NetaceaIngestType } from '@netacea/netaceaintegrationbase';
|
|
4
5
|
import ConfigLoader from './ConfigLoader';
|
|
6
|
+
import { isUrlCaptchaGet } from './netaceaPaths';
|
|
7
|
+
import { createMitata, handleCaptchaGet } from './captchaGet';
|
|
8
|
+
import { ingest } from './ingest/ingest';
|
|
9
|
+
import { logToDataStream } from './helpers/logToDataStream';
|
|
5
10
|
export default class Akamai {
|
|
6
11
|
constructor(defaultConfig) {
|
|
7
12
|
this.configLoader = new ConfigLoader(defaultConfig);
|
|
8
13
|
}
|
|
9
14
|
async requestHandler(request) {
|
|
10
15
|
const config = this.configLoader.loadConfig(request);
|
|
16
|
+
if (isUrlCaptchaGet(request.path, request.method, config.netaceaCaptchaPath)) {
|
|
17
|
+
await handleCaptchaGet(request, config);
|
|
18
|
+
return await logToDataStream(request, config);
|
|
19
|
+
}
|
|
11
20
|
const legacyWorker = new AkamaiLegacyWorker(config, {
|
|
12
21
|
httpRequest,
|
|
13
22
|
logger
|
|
@@ -16,6 +25,13 @@ export default class Akamai {
|
|
|
16
25
|
}
|
|
17
26
|
async responseHandler(request, response) {
|
|
18
27
|
const config = this.configLoader.loadConfig(request);
|
|
28
|
+
if (isUrlCaptchaGet(request.path, request.method, config.netaceaCaptchaPath)) {
|
|
29
|
+
await createMitata(request, response, config);
|
|
30
|
+
if (config.ingestType === NetaceaIngestType.HTTP) {
|
|
31
|
+
await ingest(request, response, config);
|
|
32
|
+
}
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
19
35
|
const legacyWorker = new AkamaiLegacyWorker(config, {
|
|
20
36
|
httpRequest,
|
|
21
37
|
logger
|
package/dist/src/AkamaiV2.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AkamaiV2.js","sourceRoot":"","sources":["../../src/AkamaiV2.ts"],"names":[],"mappings":"AAAA,OAAO,kBAEN,MAAM,YAAY,CAAA;AAEnB,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAA;AAC1C,OAAO,EAAE,MAAM,EAAE,MAAM,KAAK,CAAA;AAC5B,OAAO,YAAY,MAAM,gBAAgB,CAAA;
|
|
1
|
+
{"version":3,"file":"AkamaiV2.js","sourceRoot":"","sources":["../../src/AkamaiV2.ts"],"names":[],"mappings":"AAAA,OAAO,kBAEN,MAAM,YAAY,CAAA;AAEnB,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAA;AAC1C,OAAO,EAAE,MAAM,EAAE,MAAM,KAAK,CAAA;AAC5B,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AACnE,OAAO,YAAY,MAAM,gBAAgB,CAAA;AACzC,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAA;AAChD,OAAO,EAAE,YAAY,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAA;AAC7D,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAA;AACxC,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAE3D,MAAM,CAAC,OAAO,OAAO,MAAM;IAGzB,YAAa,aAA0C;QACrD,IAAI,CAAC,YAAY,GAAG,IAAI,YAAY,CAAC,aAAa,CAAC,CAAA;IACrD,CAAC;IAED,KAAK,CAAC,cAAc,CAClB,OAAgC;QAEhC,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,OAAO,CAAC,CAAA;QAEpD,IAAI,eAAe,CAAC,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC,MAAM,EAAE,MAAM,CAAC,kBAAkB,CAAC,EAAE;YAC5E,MAAM,gBAAgB,CAAC,OAAO,EAAE,MAAM,CAAC,CAAA;YACvC,OAAO,MAAM,eAAe,CAAC,OAAO,EAAE,MAAM,CAAC,CAAA;SAC9C;QAED,MAAM,YAAY,GAAG,IAAI,kBAAkB,CAAC,MAAM,EAAE;YAClD,WAAW;YACX,MAAM;SACP,CAAC,CAAA;QAEF,OAAO,MAAM,YAAY,CAAC,cAAc,CAAC,OAAO,CAAC,CAAA;IACnD,CAAC;IAED,KAAK,CAAC,eAAe,CACnB,OAAgC,EAChC,QAAiC;QAEjC,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,OAAO,CAAC,CAAA;QAEpD,IAAI,eAAe,CAAC,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC,MAAM,EAAE,MAAM,CAAC,kBAAkB,CAAC,EAAE;YAC5E,MAAM,YAAY,CAAC,OAAO,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAA;YAE7C,IAAI,MAAM,CAAC,UAAU,KAAK,iBAAiB,CAAC,IAAI,EAAE;gBAChD,MAAM,MAAM,CAAC,OAAO,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAA;aACxC;YAED,OAAM;SACP;QAED,MAAM,YAAY,GAAG,IAAI,kBAAkB,CAAC,MAAM,EAAE;YAClD,WAAW;YACX,MAAM;SACP,CAAC,CAAA;QAEF,OAAO,MAAM,YAAY,CAAC,eAAe,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;IAC9D,CAAC;CACF"}
|
|
@@ -1,10 +1,13 @@
|
|
|
1
|
+
import { AkamaiWorkerConfig } from './types';
|
|
1
2
|
export declare class CachedEncryption {
|
|
2
|
-
private encryptionKey;
|
|
3
|
-
private cache;
|
|
3
|
+
private readonly encryptionKey;
|
|
4
|
+
private readonly cache;
|
|
5
|
+
private static instance;
|
|
4
6
|
constructor(args: {
|
|
5
7
|
encryptionKey: string;
|
|
6
8
|
cacheMaxSize?: number;
|
|
7
9
|
});
|
|
10
|
+
static getInstance(config: Readonly<AkamaiWorkerConfig>): CachedEncryption;
|
|
8
11
|
getCacheSize(): number;
|
|
9
12
|
private memoizeFn;
|
|
10
13
|
encrypt(plaintext: string): Promise<string>;
|
|
@@ -28,6 +28,17 @@ export class CachedEncryption {
|
|
|
28
28
|
this.encryptionKey = args.encryptionKey;
|
|
29
29
|
this.cache = new Cache(args.cacheMaxSize ?? 5);
|
|
30
30
|
}
|
|
31
|
+
static getInstance(config) {
|
|
32
|
+
if (this.instance === undefined) {
|
|
33
|
+
if (config.cookieEncryptionKey === undefined) {
|
|
34
|
+
throw new Error('Cookie encryption key is not defined!');
|
|
35
|
+
}
|
|
36
|
+
this.instance = new CachedEncryption({
|
|
37
|
+
encryptionKey: config.cookieEncryptionKey
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
return this.instance;
|
|
41
|
+
}
|
|
31
42
|
getCacheSize() {
|
|
32
43
|
return this.cache.getCacheSize();
|
|
33
44
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CachedEncryption.js","sourceRoot":"","sources":["../../src/CachedEncryption.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;
|
|
1
|
+
{"version":3,"file":"CachedEncryption.js","sourceRoot":"","sources":["../../src/CachedEncryption.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,11 +1,6 @@
|
|
|
1
1
|
/// <reference types="akamai-edgeworkers" />
|
|
2
2
|
import type { LegacyAkamaiConstructorArgs } from './AkamaiV1';
|
|
3
|
-
|
|
4
|
-
enableMitigationProxyPass: boolean;
|
|
5
|
-
enableIngestProxyPass: boolean;
|
|
6
|
-
netaceaCookieAttributes: string;
|
|
7
|
-
netaceaCaptchaCookieAttributes: string;
|
|
8
|
-
}
|
|
3
|
+
import { AkamaiWorkerConfig } from './types';
|
|
9
4
|
export default class ConfigLoader {
|
|
10
5
|
defaults: Readonly<LegacyAkamaiConstructorArgs>;
|
|
11
6
|
constructor(defaultConfig: Readonly<LegacyAkamaiConstructorArgs>);
|
package/dist/src/ConfigLoader.js
CHANGED
|
@@ -31,6 +31,11 @@ export default class ConfigLoader {
|
|
|
31
31
|
const fetchedCookieAttr = vL.getString('COOKIE_ATTR');
|
|
32
32
|
const fetchedCaptchaCookieAttr = vL.getString('CAP_COOKIE_ATTR');
|
|
33
33
|
const { cookieAttribute, captchaCookieAttribute } = configureCookiesDomain(fetchedCookieAttr, fetchedCaptchaCookieAttr);
|
|
34
|
+
let netaceaCaptchaPath = vL.getString('CAPT_PATH');
|
|
35
|
+
const captchaPathIsDefined = netaceaCaptchaPath !== undefined && netaceaCaptchaPath.length > 0;
|
|
36
|
+
if (captchaPathIsDefined && netaceaCaptchaPath?.[0] !== '/') {
|
|
37
|
+
netaceaCaptchaPath = `/${netaceaCaptchaPath}`;
|
|
38
|
+
}
|
|
34
39
|
const config = {
|
|
35
40
|
...this.defaults,
|
|
36
41
|
apiKey: vL.getString('API_KEY', this.defaults.apiKey),
|
|
@@ -44,8 +49,10 @@ export default class ConfigLoader {
|
|
|
44
49
|
netaceaCookieAttributes: cookieAttribute ?? '',
|
|
45
50
|
netaceaCookieExpirySeconds: configureMitataExpiry(this.defaults, mitigationType),
|
|
46
51
|
netaceaCookieName: vL.getString('COOKIE_NAME', this.defaults.netaceaCookieName),
|
|
52
|
+
netaceaCaptchaPath,
|
|
47
53
|
secretKey: vL.getString('SECRET_KEY', this.defaults.secretKey),
|
|
48
|
-
useCaptchaRelAssets: vL.getBoolean('CAPT_REL_ASSETS', this.defaults.useCaptchaRelAssets) ?? false
|
|
54
|
+
useCaptchaRelAssets: vL.getBoolean('CAPT_REL_ASSETS', this.defaults.useCaptchaRelAssets) ?? false,
|
|
55
|
+
protoMitataVariableName: 'PMUSER_NETACEA_PROTO_MITATA'
|
|
49
56
|
};
|
|
50
57
|
const mitigationServiceUrlVar = vL.getString('MITIGATION_URL');
|
|
51
58
|
if (mitigationServiceUrlVar !== undefined) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ConfigLoader.js","sourceRoot":"","sources":["../../src/ConfigLoader.ts"],"names":[],"mappings":"AAAA,OAAO,EAAqB,qBAAqB,EAAE,MAAM,iCAAiC,CAAA;AAE1F,OAAO,EAAE,sBAAsB,EAAE,MAAM,2BAA2B,CAAA;
|
|
1
|
+
{"version":3,"file":"ConfigLoader.js","sourceRoot":"","sources":["../../src/ConfigLoader.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
/// <reference types="akamai-edgeworkers" />
|
|
2
|
+
import type { AkamaiWorkerConfig } from './types';
|
|
3
|
+
export declare function handleCaptchaGet(request: EW.IngressClientRequest, config: Readonly<AkamaiWorkerConfig>): Promise<void>;
|
|
4
|
+
export declare function createMitata(request: EW.IngressClientRequest, response: EW.EgressClientResponse, config: Readonly<AkamaiWorkerConfig>): Promise<void>;
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { captchaGetAPICall } from './mitigation/mitigationApiCall';
|
|
2
|
+
import { readCookie } from './helpers/readCookie';
|
|
3
|
+
import { getHeaderValueOrDefault } from './helpers/getHeaderValueOrDefault';
|
|
4
|
+
import { getVariableOrDefault } from './helpers/getVariable';
|
|
5
|
+
import { checkMitataCookie } from './mitataCookie';
|
|
6
|
+
import { getQuery } from './helpers/getQuery';
|
|
7
|
+
import { extractAndRemoveCookieAttr } from './netaceaCookieAttributes';
|
|
8
|
+
import { createAkamaiMitata } from './helpers/createMitata';
|
|
9
|
+
export async function handleCaptchaGet(request, config) {
|
|
10
|
+
const cookies = getHeaderValueOrDefault(request, 'cookie');
|
|
11
|
+
const mitataCookie = await readCookie(config.netaceaCookieName, cookies, config);
|
|
12
|
+
const mitataCaptcha = await readCookie(config.netaceaCaptchaCookieName, cookies, config);
|
|
13
|
+
const clientIP = getVariableOrDefault(request, 'PMUSER_CLIENT_IP');
|
|
14
|
+
const userAgent = getHeaderValueOrDefault(request, 'user-agent');
|
|
15
|
+
const mitataInfo = await checkMitataCookie(mitataCookie, clientIP, config.secretKey ?? '');
|
|
16
|
+
const captchaGetResponse = await captchaGetAPICall({
|
|
17
|
+
apiKey: config.apiKey ?? '',
|
|
18
|
+
clientIP,
|
|
19
|
+
userAgent,
|
|
20
|
+
userId: mitataInfo.mitata?.userId,
|
|
21
|
+
captchaCookie: mitataCaptcha,
|
|
22
|
+
trackingId: getQuery(request.query, 'trackingId'),
|
|
23
|
+
captchaSiteKey: config.captchaSiteKey,
|
|
24
|
+
captchaSecretKey: config.captchaSecretKey
|
|
25
|
+
}, config, {
|
|
26
|
+
match: 0,
|
|
27
|
+
mitigate: 0,
|
|
28
|
+
captcha: 1
|
|
29
|
+
});
|
|
30
|
+
const protoMitata = await readCookie('_proto-mitata', captchaGetResponse.setCookie, config);
|
|
31
|
+
if (protoMitata !== undefined) {
|
|
32
|
+
request.setVariable(config.protoMitataVariableName, protoMitata);
|
|
33
|
+
}
|
|
34
|
+
request.respondWith(403, {}, captchaGetResponse.body);
|
|
35
|
+
}
|
|
36
|
+
export async function createMitata(request, response, config) {
|
|
37
|
+
const protoMitataJson = getVariableOrDefault(request, config.protoMitataVariableName);
|
|
38
|
+
const protoMitata = JSON.parse(protoMitataJson);
|
|
39
|
+
if (protoMitata !== undefined) {
|
|
40
|
+
let cookieAttributes = '';
|
|
41
|
+
let maxAge = config.netaceaCookieExpirySeconds ?? 86400;
|
|
42
|
+
if (config.netaceaCookieAttributes !== '') {
|
|
43
|
+
const result = extractAndRemoveCookieAttr(config.netaceaCookieAttributes, 'Max-Age');
|
|
44
|
+
maxAge = typeof result.extractedAttribute === 'string' ? parseInt(result.extractedAttribute, 10) : maxAge;
|
|
45
|
+
cookieAttributes = result.cookieAttributes;
|
|
46
|
+
}
|
|
47
|
+
const cookie = await createAkamaiMitata({
|
|
48
|
+
clientIP: protoMitata.clientIP,
|
|
49
|
+
userId: protoMitata.userId,
|
|
50
|
+
match: protoMitata.match,
|
|
51
|
+
mitigate: protoMitata.mitigate,
|
|
52
|
+
captcha: protoMitata.captcha,
|
|
53
|
+
maxAge,
|
|
54
|
+
config
|
|
55
|
+
});
|
|
56
|
+
const responseCookies = response.getHeader('set-cookie') ?? [];
|
|
57
|
+
response.setHeader('set-cookie', [
|
|
58
|
+
...responseCookies.filter(c => !c.startsWith('_proto-mitata=')),
|
|
59
|
+
cookieAttributes !== '' ? `${cookie}; ${cookieAttributes}` : cookie
|
|
60
|
+
]);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
//# sourceMappingURL=captchaGet.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"captchaGet.js","sourceRoot":"","sources":["../../src/captchaGet.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
export class APIError extends Error {
|
|
2
|
+
static fromResponse(response) {
|
|
3
|
+
let message = 'Unknown error';
|
|
4
|
+
switch (response.status) {
|
|
5
|
+
case 403:
|
|
6
|
+
message = 'Invalid credentials';
|
|
7
|
+
break;
|
|
8
|
+
case 500:
|
|
9
|
+
message = 'Server error';
|
|
10
|
+
break;
|
|
11
|
+
case 502:
|
|
12
|
+
message = 'Bad Gateway';
|
|
13
|
+
break;
|
|
14
|
+
case 503:
|
|
15
|
+
message = 'Service Unavailable';
|
|
16
|
+
break;
|
|
17
|
+
case 400:
|
|
18
|
+
message = 'Invalid request';
|
|
19
|
+
break;
|
|
20
|
+
}
|
|
21
|
+
return new APIError(message);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=APIError.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"APIError.js","sourceRoot":"","sources":["../../../src/errors/APIError.ts"],"names":[],"mappings":"AAEA,MAAM,OAAO,QAAS,SAAQ,KAAK;IACjC,MAAM,CAAC,YAAY,CAAE,QAAyB;QAC5C,IAAI,OAAO,GAAG,eAAe,CAAA;QAE7B,QAAQ,QAAQ,CAAC,MAAM,EAAE;YACvB,KAAK,GAAG;gBACN,OAAO,GAAG,qBAAqB,CAAA;gBAC/B,MAAK;YACP,KAAK,GAAG;gBACN,OAAO,GAAG,cAAc,CAAA;gBACxB,MAAK;YACP,KAAK,GAAG;gBACN,OAAO,GAAG,aAAa,CAAA;gBACvB,MAAK;YACP,KAAK,GAAG;gBACN,OAAO,GAAG,qBAAqB,CAAA;gBAC/B,MAAK;YACP,KAAK,GAAG;gBACN,OAAO,GAAG,iBAAiB,CAAA;gBAC3B,MAAK;SACR;QAED,OAAO,IAAI,QAAQ,CAAC,OAAO,CAAC,CAAA;IAC9B,CAAC;CACF"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { CachedEncryption } from '../CachedEncryption';
|
|
2
|
+
export async function buildCookieFromValues(cookieName, value, maxAge, config, path = '/') {
|
|
3
|
+
const encryptedCookies = [
|
|
4
|
+
config.netaceaCookieName,
|
|
5
|
+
config.netaceaCaptchaCookieName
|
|
6
|
+
];
|
|
7
|
+
if (encryptedCookies.includes(cookieName) && config.cookieEncryptionKey !== undefined) {
|
|
8
|
+
const encryptedValue = await CachedEncryption.getInstance(config).encrypt(value);
|
|
9
|
+
return `${cookieName}=${encryptedValue}; Max-Age=${maxAge}; Path=${path}`;
|
|
10
|
+
}
|
|
11
|
+
return `${cookieName}=${value}; Max-Age=${maxAge}; Path=${path}`;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=buildCookieFromValues.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildCookieFromValues.js","sourceRoot":"","sources":["../../../src/helpers/buildCookieFromValues.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAA;AAGtD,MAAM,CAAC,KAAK,UAAU,qBAAqB,CACzC,UAAkB,EAClB,KAAa,EACb,MAAc,EACd,MAAoC,EACpC,IAAI,GAAG,GAAG;IAEV,MAAM,gBAAgB,GAAG;QACvB,MAAM,CAAC,iBAAiB;QACxB,MAAM,CAAC,wBAAwB;KAChC,CAAA;IACD,IAAI,gBAAgB,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,MAAM,CAAC,mBAAmB,KAAK,SAAS,EAAE;QACrF,MAAM,cAAc,GAAG,MAAM,gBAAgB,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;QAChF,OAAO,GAAG,UAAU,IAAI,cAAc,aAAa,MAAM,UAAU,IAAI,EAAE,CAAA;KAC1E;IACD,OAAO,GAAG,UAAU,IAAI,KAAK,aAAa,MAAM,UAAU,IAAI,EAAE,CAAA;AAClE,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildCookieHeader.js","sourceRoot":"","sources":["../../../src/helpers/buildCookieHeader.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,iBAAiB,CAAE,OAA4C;IAC7E,OAAO,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC;SAC3B,MAAM,CAAC,CAAC,CAAC,EAAE,WAAW,CAAC,EAAE,EAAE,CAAC,WAAW,KAAK,SAAS,CAAC;SACtD,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;SAC/B,IAAI,CAAC,IAAI,CAAC,CAAA;AACf,CAAC"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { NetaceaLogVersion, matchMitataCookie, safeParseInt } from '@netacea/netaceaintegrationbase';
|
|
2
|
+
export function constructWebLog(args, config) {
|
|
3
|
+
args.bytesSent = args.bytesSent === '' ? '0' : args.bytesSent;
|
|
4
|
+
if (config.logVersion === NetaceaLogVersion.V2) {
|
|
5
|
+
return constructV2WebLog(args);
|
|
6
|
+
}
|
|
7
|
+
return constructV1WebLog(args);
|
|
8
|
+
}
|
|
9
|
+
function constructV2WebLog({ ip, userAgent, status, method, path, protocol, referer, bytesSent, requestTime, mitataCookie, sessionStatus, integrationType, integrationVersion }) {
|
|
10
|
+
const now = new Date();
|
|
11
|
+
if (path[0] !== '/') {
|
|
12
|
+
path = `/${path}`;
|
|
13
|
+
}
|
|
14
|
+
let actualQuery;
|
|
15
|
+
const splitPath = path.split('?');
|
|
16
|
+
if (splitPath.length > 1) {
|
|
17
|
+
actualQuery = `?${splitPath[1]}`;
|
|
18
|
+
}
|
|
19
|
+
const actualPath = splitPath[0];
|
|
20
|
+
const userId = matchMitataCookie(mitataCookie)?.userId;
|
|
21
|
+
const log = {
|
|
22
|
+
status,
|
|
23
|
+
method,
|
|
24
|
+
'bytes_sent': safeParseInt(bytesSent),
|
|
25
|
+
'referrer': referer === '' ? undefined : referer,
|
|
26
|
+
'request': `${method} ${actualPath}${actualQuery ?? ''} ${protocol}`,
|
|
27
|
+
'request_time': safeParseInt(requestTime),
|
|
28
|
+
'integration_type': integrationType,
|
|
29
|
+
'integration_version': integrationVersion,
|
|
30
|
+
'client': ip,
|
|
31
|
+
'user_agent': userAgent,
|
|
32
|
+
'bc_type': sessionStatus === '' ? undefined : sessionStatus,
|
|
33
|
+
'hour': now.getUTCHours(),
|
|
34
|
+
'minute': now.getUTCMinutes(),
|
|
35
|
+
'@timestamp': now.toISOString().replace('Z', '+00:00'),
|
|
36
|
+
'path': actualPath,
|
|
37
|
+
protocol,
|
|
38
|
+
'query': actualQuery,
|
|
39
|
+
'user_id': userId
|
|
40
|
+
};
|
|
41
|
+
return log;
|
|
42
|
+
}
|
|
43
|
+
function constructV1WebLog({ ip, userAgent, status, method, path, protocol, referer, bytesSent, requestTime, mitataCookie, sessionStatus, integrationType, integrationVersion }) {
|
|
44
|
+
const timestamp = new Date().toUTCString();
|
|
45
|
+
return {
|
|
46
|
+
Request: `${method} ${path} ${protocol}`,
|
|
47
|
+
TimeLocal: timestamp,
|
|
48
|
+
RealIp: ip,
|
|
49
|
+
UserAgent: userAgent,
|
|
50
|
+
Status: status,
|
|
51
|
+
RequestTime: requestTime?.toString(),
|
|
52
|
+
BytesSent: bytesSent?.toString(),
|
|
53
|
+
Referer: referer === '' ? '-' : referer,
|
|
54
|
+
NetaceaUserIdCookie: mitataCookie ?? '',
|
|
55
|
+
NetaceaMitigationApplied: sessionStatus ?? '',
|
|
56
|
+
IntegrationType: integrationType ?? '',
|
|
57
|
+
IntegrationVersion: integrationVersion ?? ''
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=constructWebLog.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constructWebLog.js","sourceRoot":"","sources":["../../../src/helpers/constructWebLog.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { AkamaiWorkerConfig } from '../types';
|
|
2
|
+
interface CreateMitataOptions {
|
|
3
|
+
clientIP: string;
|
|
4
|
+
userId?: string;
|
|
5
|
+
match: number;
|
|
6
|
+
mitigate: number;
|
|
7
|
+
captcha: number;
|
|
8
|
+
maxAge: number;
|
|
9
|
+
expiry?: number;
|
|
10
|
+
config: Readonly<AkamaiWorkerConfig>;
|
|
11
|
+
}
|
|
12
|
+
export declare function createAkamaiMitata({ clientIP, userId, match, mitigate, captcha, maxAge, expiry, config }: CreateMitataOptions): Promise<string>;
|
|
13
|
+
export {};
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { buildCookieFromValues } from './buildCookieFromValues';
|
|
2
|
+
import { createMitataCookie } from '../mitataCookie';
|
|
3
|
+
export async function createAkamaiMitata({ clientIP, userId, match, mitigate, captcha, maxAge = 86400, expiry = undefined, config }) {
|
|
4
|
+
const expirySeconds = config.netaceaCookieExpirySeconds;
|
|
5
|
+
const isCaptchaServe = [1, 3, 5].includes(captcha);
|
|
6
|
+
const expiryDelta = isCaptchaServe ? -expirySeconds : expirySeconds;
|
|
7
|
+
const mitataExpiry = expiry ?? Math.floor(Date.now() / 1000) + expiryDelta;
|
|
8
|
+
if (config.secretKey === undefined) {
|
|
9
|
+
throw new Error('Cannot build cookie without secret key.');
|
|
10
|
+
}
|
|
11
|
+
const mitataCode = [match, mitigate, captcha].join('');
|
|
12
|
+
const mitataValue = await createMitataCookie(clientIP, userId, mitataExpiry, config.secretKey, mitataCode);
|
|
13
|
+
return await buildCookieFromValues(config.netaceaCookieName, mitataValue, maxAge, config);
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=createMitata.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createMitata.js","sourceRoot":"","sources":["../../../src/helpers/createMitata.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,yBAAyB,CAAA;AAC/D,OAAO,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAA;AAcpD,MAAM,CAAC,KAAK,UAAU,kBAAkB,CAAE,EACxC,QAAQ,EACR,MAAM,EACN,KAAK,EACL,QAAQ,EACR,OAAO,EACP,MAAM,GAAG,KAAK,EACd,MAAM,GAAG,SAAS,EAClB,MAAM,EACc;IAEpB,MAAM,aAAa,GAAG,MAAM,CAAC,0BAAoC,CAAA;IACjE,MAAM,cAAc,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAA;IAClD,MAAM,WAAW,GAAG,cAAc,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,aAAa,CAAA;IACnE,MAAM,YAAY,GAAG,MAAM,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,WAAW,CAAA;IAE1E,IAAI,MAAM,CAAC,SAAS,KAAK,SAAS,EAAE;QAClC,MAAM,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAA;KAC3D;IACD,MAAM,UAAU,GAAG,CAAC,KAAK,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;IACtD,MAAM,WAAW,GAAG,MAAM,kBAAkB,CAC1C,QAAQ,EACR,MAAM,EACN,YAAY,EACZ,MAAM,CAAC,SAAS,EAChB,UAAU,CACX,CAAA;IACD,OAAO,MAAM,qBAAqB,CAChC,MAAM,CAAC,iBAA2B,EAClC,WAAW,EACX,MAAM,EACN,MAAM,CACP,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function createProtoMitata(clientIP: string, userId: string | undefined, match: number, mitigate: number, captcha: number, maxAge?: number): Promise<string>;
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { generateId } from '../mitataCookie';
|
|
2
|
+
export async function createProtoMitata(clientIP, userId, match, mitigate, captcha, maxAge = 86400) {
|
|
3
|
+
const AkamaiCookieObj = {
|
|
4
|
+
clientIP,
|
|
5
|
+
userId: userId ?? generateId(),
|
|
6
|
+
match,
|
|
7
|
+
mitigate,
|
|
8
|
+
captcha,
|
|
9
|
+
mitataMaxAge: maxAge
|
|
10
|
+
};
|
|
11
|
+
return `_proto-mitata=${JSON.stringify(AkamaiCookieObj)}`;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=createProtoMitata.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createProtoMitata.js","sourceRoot":"","sources":["../../../src/helpers/createProtoMitata.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAE5C,MAAM,CAAC,KAAK,UAAU,iBAAiB,CACrC,QAAgB,EAChB,MAA0B,EAC1B,KAAa,EACb,QAAgB,EAChB,OAAe,EACf,MAAM,GAAG,KAAK;IAEd,MAAM,eAAe,GAAG;QACtB,QAAQ;QACR,MAAM,EAAE,MAAM,IAAI,UAAU,EAAE;QAC9B,KAAK;QACL,QAAQ;QACR,OAAO;QACP,YAAY,EAAE,MAAM;KACrB,CAAA;IACD,OAAO,iBAAiB,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC,EAAE,CAAA;AAC3D,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function isJweEncrypted(str: string): boolean;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"encryptionCheck.js","sourceRoot":"","sources":["../../../src/helpers/encryptionCheck.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,cAAc,CAAE,GAAW;IACzC,MAAM,QAAQ,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;IAC/B,OAAO,QAAQ,CAAC,MAAM,KAAK,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAA;AACpD,CAAC"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import type { FindBestMitigationResponse } from '@netacea/netaceaintegrationbase';
|
|
2
|
+
import type { AkamaiWorkerConfig } from '../types';
|
|
3
|
+
export declare function findBestMitigation(match: number, mitigate: number, captcha: number, isCaptchaPost: boolean, config: Readonly<AkamaiWorkerConfig>): FindBestMitigationResponse;
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { dictionary, NetaceaMitigationType } from '@netacea/netaceaintegrationbase';
|
|
2
|
+
export function findBestMitigation(match, mitigate, captcha, isCaptchaPost, config) {
|
|
3
|
+
const UNKNOWN = 'unknown';
|
|
4
|
+
if (!isCaptchaPost) {
|
|
5
|
+
if (captcha === 2) {
|
|
6
|
+
captcha = 4;
|
|
7
|
+
}
|
|
8
|
+
else if (captcha === 3) {
|
|
9
|
+
captcha = 5;
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
let sessionStatus = dictionary.matchMap[match] ?? (UNKNOWN + '_');
|
|
13
|
+
sessionStatus += dictionary.mitigateMap[mitigate] ?? UNKNOWN;
|
|
14
|
+
let mitigation = dictionary.bestMitigationMap[mitigate];
|
|
15
|
+
if (captcha !== 0) {
|
|
16
|
+
sessionStatus += ',' + (dictionary.captchaMap[captcha] ?? UNKNOWN);
|
|
17
|
+
const bestCaptchaMitigation = dictionary.bestMitigationCaptchaMap[captcha];
|
|
18
|
+
if (bestCaptchaMitigation !== undefined) {
|
|
19
|
+
mitigation = bestCaptchaMitigation;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
if (config.mitigationType === NetaceaMitigationType.INJECT) {
|
|
23
|
+
mitigation = dictionary.mitigationTypes.none;
|
|
24
|
+
}
|
|
25
|
+
return {
|
|
26
|
+
sessionStatus,
|
|
27
|
+
mitigation,
|
|
28
|
+
parts: {
|
|
29
|
+
match,
|
|
30
|
+
mitigate,
|
|
31
|
+
captcha
|
|
32
|
+
}
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=findBestMitigation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"findBestMitigation.js","sourceRoot":"","sources":["../../../src/helpers/findBestMitigation.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,qBAAqB,EAAE,MAAM,iCAAiC,CAAA;AAEnF,MAAM,UAAU,kBAAkB,CAAE,KAAa,EAC/C,QAAgB,EAChB,OAAe,EACf,aAAsB,EACtB,MAAoC;IAEpC,MAAM,OAAO,GAAG,SAAS,CAAA;IACzB,IAAI,CAAC,aAAa,EAAE;QAClB,IAAI,OAAO,KAAK,CAAC,EAAE;YACjB,OAAO,GAAG,CAAC,CAAA;SACZ;aAAM,IAAI,OAAO,KAAK,CAAC,EAAE;YACxB,OAAO,GAAG,CAAC,CAAA;SACZ;KACF;IAED,IAAI,aAAa,GAAG,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC,CAAA;IACjE,aAAa,IAAI,UAAU,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,OAAO,CAAA;IAC5D,IAAI,UAAU,GAAG,UAAU,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAA;IACvD,IAAI,OAAO,KAAK,CAAC,EAAE;QACjB,aAAa,IAAI,GAAG,GAAG,CAAC,UAAU,CAAC,UAAU,CAAC,OAAO,CAAC,IAAI,OAAO,CAAC,CAAA;QAClE,MAAM,qBAAqB,GAAG,UAAU,CAAC,wBAAwB,CAAC,OAAO,CAAC,CAAA;QAC1E,IAAI,qBAAqB,KAAK,SAAS,EAAE;YACvC,UAAU,GAAG,qBAAqB,CAAA;SACnC;KACF;IACD,IAAI,MAAM,CAAC,cAAc,KAAK,qBAAqB,CAAC,MAAM,EAAE;QAC1D,UAAU,GAAG,UAAU,CAAC,eAAe,CAAC,IAAI,CAAA;KAC7C;IACD,OAAO;QACL,aAAa;QACb,UAAU;QACV,KAAK,EAAE;YACL,KAAK;YACL,QAAQ;YACR,OAAO;SACR;KACF,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getHeaderValueOrDefault.js","sourceRoot":"","sources":["../../../src/helpers/getHeaderValueOrDefault.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,uBAAuB,CACrC,QAA0E,EAC1E,GAAW,EACX,UAAU,GAAG,EAAE;IAEf,MAAM,MAAM,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,CAAA;IAC1D,OAAO,MAAM,IAAI,UAAU,CAAA;AAC7B,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { dictionary } from '@netacea/netaceaintegrationbase';
|
|
2
|
+
import { buildCookieFromValues } from './buildCookieFromValues';
|
|
3
|
+
export async function getMitataCaptchaFromHeaders(headers, config) {
|
|
4
|
+
if (Object.prototype.hasOwnProperty.call(headers, dictionary.netaceaHeaders.mitataCaptcha)) {
|
|
5
|
+
const mitataCaptcha = headers[dictionary.netaceaHeaders.mitataCaptcha];
|
|
6
|
+
const mitataCaptchaExpiry = parseInt(headers[dictionary.netaceaHeaders.mitataCaptchaExpiry]);
|
|
7
|
+
const mitataCaptchaCookie = await buildCookieFromValues(config.netaceaCaptchaCookieName, mitataCaptcha, mitataCaptchaExpiry, config);
|
|
8
|
+
if (mitataCaptchaCookie !== undefined) {
|
|
9
|
+
return mitataCaptchaCookie;
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
return undefined;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=getMitataCaptchaFromHeaders.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getMitataCaptchaFromHeaders.js","sourceRoot":"","sources":["../../../src/helpers/getMitataCaptchaFromHeaders.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAA;AAC5D,OAAO,EAAE,qBAAqB,EAAE,MAAM,yBAAyB,CAAA;AAG/D,MAAM,CAAC,KAAK,UAAU,2BAA2B,CAC/C,OAAgC,EAChC,MAAoC;IAEpC,IAAI,MAAM,CAAC,SAAS,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC,cAAc,CAAC,aAAa,CAAC,EAAE;QAC1F,MAAM,aAAa,GAAG,OAAO,CAAC,UAAU,CAAC,cAAc,CAAC,aAAa,CAAC,CAAA;QACtE,MAAM,mBAAmB,GAAG,QAAQ,CAAC,OAAO,CAAC,UAAU,CAAC,cAAc,CAAC,mBAAmB,CAAC,CAAC,CAAA;QAC5F,MAAM,mBAAmB,GAAG,MAAM,qBAAqB,CACrD,MAAM,CAAC,wBAAkC,EACzC,aAAa,EACb,mBAAmB,EACnB,MAAM,CACP,CAAA;QAED,IAAI,mBAAmB,KAAK,SAAS,EAAE;YACrC,OAAO,mBAAmB,CAAA;SAC3B;KACF;IACD,OAAO,SAAS,CAAA;AAClB,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export function getProtoMitataFromRequestVar(request, config) {
|
|
2
|
+
const protoMitataString = request.getVariable(config.protoMitataVariableName);
|
|
3
|
+
if (protoMitataString === undefined || protoMitataString === '') {
|
|
4
|
+
return undefined;
|
|
5
|
+
}
|
|
6
|
+
try {
|
|
7
|
+
return JSON.parse(protoMitataString);
|
|
8
|
+
}
|
|
9
|
+
catch {
|
|
10
|
+
return undefined;
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=getProtoMitataFromRequestVar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getProtoMitataFromRequestVar.js","sourceRoot":"","sources":["../../../src/helpers/getProtoMitataFromRequestVar.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,4BAA4B,CAC1C,OAAgC,EAChC,MAAoC;IAEpC,MAAM,iBAAiB,GAAG,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC,uBAAuB,CAAC,CAAA;IAG7E,IAAI,iBAAiB,KAAK,SAAS,IAAI,iBAAiB,KAAK,EAAE,EAAE;QAC/D,OAAO,SAAS,CAAA;KACjB;IAED,IAAI;QACF,OAAO,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAA;KACrC;IAAC,MAAM;QACN,OAAO,SAAS,CAAA;KACjB;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function getQuery(queryStr: string, key: string): string | undefined;
|