@xyo-network/url-safety-plugin 2.70.12 → 2.70.14

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.
@@ -1,10 +1,10 @@
1
1
  import { PayloadSetSchema } from '@xyo-network/payload-model';
2
2
  import { createPayloadSetWitnessPlugin } from '@xyo-network/payloadset-plugin';
3
- import { UrlSchema } from '@xyo-network/url-payload-plugin';
4
- import { UrlWitness } from './Witness';
5
- export const UrlPlugin = () => createPayloadSetWitnessPlugin({ required: { [UrlSchema]: 1 }, schema: PayloadSetSchema }, {
3
+ import { UrlSafetySchema } from '@xyo-network/url-safety-payload-plugin';
4
+ import { UrlSafetyWitness } from './Witness';
5
+ export const UrlSafetyPlugin = () => createPayloadSetWitnessPlugin({ required: { [UrlSafetySchema]: 1 }, schema: PayloadSetSchema }, {
6
6
  witness: async (params) => {
7
- const result = await UrlWitness.create(params);
7
+ const result = await UrlSafetyWitness.create(params);
8
8
  return result;
9
9
  },
10
10
  });
@@ -1 +1 @@
1
- {"version":3,"file":"Plugin.js","sourceRoot":"","sources":["../../src/Plugin.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAA;AAC7D,OAAO,EAAE,6BAA6B,EAAE,MAAM,gCAAgC,CAAA;AAC9E,OAAO,EAAE,SAAS,EAAE,MAAM,iCAAiC,CAAA;AAE3D,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAA;AAEtC,MAAM,CAAC,MAAM,SAAS,GAAG,GAAG,EAAE,CAC5B,6BAA6B,CAC3B,EAAE,QAAQ,EAAE,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC,EAAE,EAAE,MAAM,EAAE,gBAAgB,EAAE,EAC1D;IACE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE;QACxB,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;QAC9C,OAAO,MAAM,CAAA;IACf,CAAC;CACF,CACF,CAAA"}
1
+ {"version":3,"file":"Plugin.js","sourceRoot":"","sources":["../../src/Plugin.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAA;AAC7D,OAAO,EAAE,6BAA6B,EAAE,MAAM,gCAAgC,CAAA;AAC9E,OAAO,EAAE,eAAe,EAAE,MAAM,wCAAwC,CAAA;AAExE,OAAO,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAA;AAE5C,MAAM,CAAC,MAAM,eAAe,GAAG,GAAG,EAAE,CAClC,6BAA6B,CAC3B,EAAE,QAAQ,EAAE,EAAE,CAAC,eAAe,CAAC,EAAE,CAAC,EAAE,EAAE,MAAM,EAAE,gBAAgB,EAAE,EAChE;IACE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE;QACxB,MAAM,MAAM,GAAG,MAAM,gBAAgB,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;QACpD,OAAO,MAAM,CAAA;IACf,CAAC;CACF,CACF,CAAA"}
@@ -1,10 +1,12 @@
1
1
  import { AxiosJson } from '@xyo-network/axios';
2
2
  import { UrlSchema } from '@xyo-network/url-payload-plugin';
3
+ import { UrlSafetySchema } from '@xyo-network/url-safety-payload-plugin';
3
4
  import { AbstractWitness } from '@xyo-network/witness';
4
5
  import { UrlSafetyWitnessConfigSchema } from './Config';
6
+ export const GoogleSafeBrowsingMatchSchema = 'com.google.safebrowsing.match';
5
7
  const checkUrlSafety = async (urls, config) => {
6
8
  const axios = new AxiosJson();
7
- const endPoint = config?.endPoint ?? 'https://safebrowsing.googleapis.com/v5/threatMatches:find';
9
+ const endPoint = config?.endPoint ?? 'https://safebrowsing.googleapis.com/v4/threatMatches:find';
8
10
  const key = config?.key;
9
11
  const mutatedUrls = urls.map((url) => url.replace('ipfs://', 'https://cloudflare-ipfs.com/'));
10
12
  if (mutatedUrls.length === 0) {
@@ -22,12 +24,17 @@ const checkUrlSafety = async (urls, config) => {
22
24
  threatTypes: ['SOCIAL_ENGINEERING', 'POTENTIALLY_HARMFUL_APPLICATION', 'UNWANTED_SOFTWARE', 'THREAT_TYPE_UNSPECIFIED'],
23
25
  },
24
26
  };
25
- const result = (await axios.post(`${endPoint}?key=${key}`, postData)).data;
26
- console.log(`checkUrlSafety: ${JSON.stringify(result, null, 2)}`);
27
- return [];
27
+ console.log(`checkUrlSafetyIn: ${JSON.stringify(postData, null, 2)}`);
28
+ const result = (await axios.post(`${endPoint}?key=${key}`, postData, { headers: { referer: 'http://localhost:3000' } }))
29
+ .data;
30
+ console.log(`checkUrlSafetyOut: ${JSON.stringify(result, null, 2)}`);
31
+ return result.matches?.map((match) => ({ ...match, schema: GoogleSafeBrowsingMatchSchema })) ?? [];
28
32
  };
29
- export class UrlWitness extends AbstractWitness {
33
+ export class UrlSafetyWitness extends AbstractWitness {
30
34
  static configSchemas = [UrlSafetyWitnessConfigSchema];
35
+ get key() {
36
+ return this.params.google?.safeBrowsing?.key;
37
+ }
31
38
  get urls() {
32
39
  return this.config?.urls;
33
40
  }
@@ -38,7 +45,20 @@ export class UrlWitness extends AbstractWitness {
38
45
  .map((p) => {
39
46
  return p.url;
40
47
  });
41
- return await checkUrlSafety(urls);
48
+ const matches = await checkUrlSafety(urls, { key: this.key });
49
+ return urls.map((url) => {
50
+ const payload = matches.reduce((prev, match) => {
51
+ if (match.threat.url === url) {
52
+ prev.threatTypes = prev.threatTypes ?? [];
53
+ if (!prev.threatTypes.includes(match.threatEntryType)) {
54
+ prev.threatTypes.push(match.threatEntryType);
55
+ }
56
+ }
57
+ return prev;
58
+ }, { schema: UrlSafetySchema, url });
59
+ payload.threatTypes = payload.threatTypes?.sort();
60
+ return payload;
61
+ });
42
62
  }
43
63
  }
44
64
  //# sourceMappingURL=Witness.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Witness.js","sourceRoot":"","sources":["../../../src/Witness/Witness.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAA;AAC9C,OAAO,EAAc,SAAS,EAAE,MAAM,iCAAiC,CAAA;AAEvE,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AAEtD,OAAO,EAAE,4BAA4B,EAAE,MAAM,UAAU,CAAA;AAGvD,MAAM,cAAc,GAAG,KAAK,EAC1B,IAAc,EACd,MAGC,EAC4B,EAAE;IAC/B,MAAM,KAAK,GAAG,IAAI,SAAS,EAAE,CAAA;IAC7B,MAAM,QAAQ,GAAG,MAAM,EAAE,QAAQ,IAAI,2DAA2D,CAAA;IAChG,MAAM,GAAG,GAAG,MAAM,EAAE,GAAG,CAAA;IACvB,MAAM,WAAW,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,SAAS,EAAE,8BAA8B,CAAC,CAAC,CAAA;IAC7F,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE;QAC5B,OAAO,EAAE,CAAA;KACV;IACD,MAAM,QAAQ,GAAG;QACf,MAAM,EAAE;YACN,QAAQ,EAAE,aAAa;YACvB,aAAa,EAAE,KAAK;SACrB;QACD,UAAU,EAAE;YACV,aAAa,EAAE,CAAC,SAAS,EAAE,OAAO,EAAE,KAAK,CAAC;YAC1C,aAAa,EAAE,WAAW,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;YAClD,gBAAgB,EAAE,CAAC,KAAK,CAAC;YACzB,WAAW,EAAE,CAAC,oBAAoB,EAAE,iCAAiC,EAAE,mBAAmB,EAAE,yBAAyB,CAAC;SACvH;KACF,CAAA;IACD,MAAM,MAAM,GAAG,CAAC,MAAM,KAAK,CAAC,IAAI,CAAC,GAAG,QAAQ,QAAQ,GAAG,EAAE,EAAE,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAA;IAC1E,OAAO,CAAC,GAAG,CAAC,mBAAmB,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,CAAC,CAAA;IACjE,OAAO,EAAE,CAAA;AACX,CAAC,CAAA;AAED,MAAM,OAAO,UAA4E,SAAQ,eAAwB;IACvH,MAAM,CAAU,aAAa,GAAG,CAAC,4BAA4B,CAAC,CAAA;IAE9D,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,MAAM,EAAE,IAAI,CAAA;IAC1B,CAAC;IAEkB,KAAK,CAAC,cAAc,CAAC,WAAyB,EAAE;QACjE,MAAM,IAAI,GACR,IAAI,CAAC,IAAI;YACT,QAAQ;iBACL,MAAM,CAAC,CAAC,CAAC,EAAmB,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,SAAS,CAAC;iBACtD,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;gBACT,OAAO,CAAC,CAAC,GAAG,CAAA;YACd,CAAC,CAAC,CAAA;QAEN,OAAO,MAAM,cAAc,CAAC,IAAI,CAAC,CAAA;IACnC,CAAC"}
1
+ {"version":3,"file":"Witness.js","sourceRoot":"","sources":["../../../src/Witness/Witness.ts"],"names":[],"mappings":"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"}
package/dist/esm/index.js CHANGED
@@ -1,6 +1,6 @@
1
- import { UrlPlugin } from './Plugin';
1
+ import { UrlSafetyPlugin } from './Plugin';
2
2
  export * from './Witness';
3
- export { UrlPlugin };
3
+ export { UrlSafetyPlugin };
4
4
  // eslint-disable-next-line import/no-default-export
5
- export default UrlPlugin;
5
+ export default UrlSafetyPlugin;
6
6
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAA;AAEpC,cAAc,WAAW,CAAA;AAEzB,OAAO,EAAE,SAAS,EAAE,CAAA;AAEpB,oDAAoD;AACpD,eAAe,SAAS,CAAA"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAE1C,cAAc,WAAW,CAAA;AAEzB,OAAO,EAAE,eAAe,EAAE,CAAA;AAE1B,oDAAoD;AACpD,eAAe,eAAe,CAAA"}
@@ -1,5 +1,5 @@
1
- import { UrlWitness } from './Witness';
2
- export declare const UrlPlugin: () => import("@xyo-network/payloadset-plugin").PayloadSetWitnessPlugin<UrlWitness<import("@xyo-network/core").BaseParamsFields & {
1
+ import { UrlSafetyWitness } from './Witness';
2
+ export declare const UrlSafetyPlugin: () => import("@xyo-network/payloadset-plugin").PayloadSetWitnessPlugin<UrlSafetyWitness<import("@xyo-network/core").BaseParamsFields & {
3
3
  account?: import("@xyo-network/account-model").AccountInstance | "random" | undefined;
4
4
  accountDerivationPath?: string | undefined;
5
5
  config: import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
@@ -1 +1 @@
1
- {"version":3,"file":"Plugin.d.ts","sourceRoot":"","sources":["../../src/Plugin.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAA;AAEtC,eAAO,MAAM,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GASnB,CAAA"}
1
+ {"version":3,"file":"Plugin.d.ts","sourceRoot":"","sources":["../../src/Plugin.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAA;AAE5C,eAAO,MAAM,eAAe;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GASzB,CAAA"}
@@ -1,9 +1,23 @@
1
+ import { Payload } from '@xyo-network/payload-model';
1
2
  import { UrlPayload } from '@xyo-network/url-payload-plugin';
2
3
  import { UrlSafetyPayload } from '@xyo-network/url-safety-payload-plugin';
3
4
  import { AbstractWitness } from '@xyo-network/witness';
4
5
  import { UrlSafetyWitnessParams } from './Params';
5
- export declare class UrlWitness<TParams extends UrlSafetyWitnessParams = UrlSafetyWitnessParams> extends AbstractWitness<TParams> {
6
+ export type GoogleSafeBrowsingMatchSchema = 'com.google.safebrowsing.match';
7
+ export declare const GoogleSafeBrowsingMatchSchema: GoogleSafeBrowsingMatchSchema;
8
+ export interface GoogleSafeBrowsingMatch {
9
+ cacheDuration: string;
10
+ platformType: string;
11
+ threat: {
12
+ url: string;
13
+ };
14
+ threatEntryType: string;
15
+ threatType: string;
16
+ }
17
+ export type GoogleSafeBrowsingMatchPayload = Payload<GoogleSafeBrowsingMatch, GoogleSafeBrowsingMatchSchema>;
18
+ export declare class UrlSafetyWitness<TParams extends UrlSafetyWitnessParams = UrlSafetyWitnessParams> extends AbstractWitness<TParams> {
6
19
  static configSchemas: "network.xyo.url.safety.witness.config"[];
20
+ get key(): string | undefined;
7
21
  get urls(): string[] | undefined;
8
22
  protected observeHandler(payloads?: UrlPayload[]): Promise<UrlSafetyPayload[]>;
9
23
  }
@@ -1 +1 @@
1
- {"version":3,"file":"Witness.d.ts","sourceRoot":"","sources":["../../../src/Witness/Witness.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAa,MAAM,iCAAiC,CAAA;AACvE,OAAO,EAAE,gBAAgB,EAAE,MAAM,wCAAwC,CAAA;AACzE,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AAGtD,OAAO,EAAE,sBAAsB,EAAE,MAAM,UAAU,CAAA;AAiCjD,qBAAa,UAAU,CAAC,OAAO,SAAS,sBAAsB,GAAG,sBAAsB,CAAE,SAAQ,eAAe,CAAC,OAAO,CAAC;IACvH,OAAgB,aAAa,4CAAiC;IAE9D,IAAI,IAAI,yBAEP;cAEwB,cAAc,CAAC,QAAQ,GAAE,UAAU,EAAO,GAAG,OAAO,CAAC,gBAAgB,EAAE,CAAC;CAWlG"}
1
+ {"version":3,"file":"Witness.d.ts","sourceRoot":"","sources":["../../../src/Witness/Witness.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EAAE,UAAU,EAAa,MAAM,iCAAiC,CAAA;AACvE,OAAO,EAAE,gBAAgB,EAAwC,MAAM,wCAAwC,CAAA;AAC/G,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AAGtD,OAAO,EAAE,sBAAsB,EAAE,MAAM,UAAU,CAAA;AAEjD,MAAM,MAAM,6BAA6B,GAAG,+BAA+B,CAAA;AAC3E,eAAO,MAAM,6BAA6B,EAAE,6BAA+D,CAAA;AAE3G,MAAM,WAAW,uBAAuB;IACtC,aAAa,EAAE,MAAM,CAAA;IACrB,YAAY,EAAE,MAAM,CAAA;IACpB,MAAM,EAAE;QACN,GAAG,EAAE,MAAM,CAAA;KACZ,CAAA;IACD,eAAe,EAAE,MAAM,CAAA;IACvB,UAAU,EAAE,MAAM,CAAA;CACnB;AAED,MAAM,MAAM,8BAA8B,GAAG,OAAO,CAAC,uBAAuB,EAAE,6BAA6B,CAAC,CAAA;AAuC5G,qBAAa,gBAAgB,CAAC,OAAO,SAAS,sBAAsB,GAAG,sBAAsB,CAAE,SAAQ,eAAe,CAAC,OAAO,CAAC;IAC7H,OAAgB,aAAa,4CAAiC;IAE9D,IAAI,GAAG,uBAEN;IAED,IAAI,IAAI,yBAEP;cAEwB,cAAc,CAAC,QAAQ,GAAE,UAAU,EAAO,GAAG,OAAO,CAAC,gBAAgB,EAAE,CAAC;CA4BlG"}
@@ -1,5 +1,5 @@
1
- import { UrlPlugin } from './Plugin';
1
+ import { UrlSafetyPlugin } from './Plugin';
2
2
  export * from './Witness';
3
- export { UrlPlugin };
4
- export default UrlPlugin;
3
+ export { UrlSafetyPlugin };
4
+ export default UrlSafetyPlugin;
5
5
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAA;AAEpC,cAAc,WAAW,CAAA;AAEzB,OAAO,EAAE,SAAS,EAAE,CAAA;AAGpB,eAAe,SAAS,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAE1C,cAAc,WAAW,CAAA;AAEzB,OAAO,EAAE,eAAe,EAAE,CAAA;AAG1B,eAAe,eAAe,CAAA"}
package/package.json CHANGED
@@ -10,13 +10,14 @@
10
10
  "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js/issues"
11
11
  },
12
12
  "dependencies": {
13
- "@xyo-network/axios": "~2.70.12",
14
- "@xyo-network/module": "~2.70.12",
15
- "@xyo-network/payload-model": "~2.70.12",
16
- "@xyo-network/payloadset-plugin": "~2.70.12",
17
- "@xyo-network/url-payload-plugin": "~2.70.12",
18
- "@xyo-network/url-safety-payload-plugin": "~2.70.12",
19
- "@xyo-network/witness": "~2.70.12"
13
+ "@xyo-network/axios": "~2.70.14",
14
+ "@xyo-network/core": "~2.70.14",
15
+ "@xyo-network/module": "~2.70.14",
16
+ "@xyo-network/payload-model": "~2.70.14",
17
+ "@xyo-network/payloadset-plugin": "~2.70.14",
18
+ "@xyo-network/url-payload-plugin": "~2.70.14",
19
+ "@xyo-network/url-safety-payload-plugin": "~2.70.14",
20
+ "@xyo-network/witness": "~2.70.14"
20
21
  },
21
22
  "devDependencies": {
22
23
  "@xylabs/ts-scripts-yarn3": "^2.19.0",
@@ -56,5 +57,5 @@
56
57
  },
57
58
  "sideEffects": false,
58
59
  "types": "dist/types/index.d.ts",
59
- "version": "2.70.12"
60
+ "version": "2.70.14"
60
61
  }
package/src/Plugin.ts CHANGED
@@ -1,15 +1,15 @@
1
1
  import { PayloadSetSchema } from '@xyo-network/payload-model'
2
2
  import { createPayloadSetWitnessPlugin } from '@xyo-network/payloadset-plugin'
3
- import { UrlSchema } from '@xyo-network/url-payload-plugin'
3
+ import { UrlSafetySchema } from '@xyo-network/url-safety-payload-plugin'
4
4
 
5
- import { UrlWitness } from './Witness'
5
+ import { UrlSafetyWitness } from './Witness'
6
6
 
7
- export const UrlPlugin = () =>
8
- createPayloadSetWitnessPlugin<UrlWitness>(
9
- { required: { [UrlSchema]: 1 }, schema: PayloadSetSchema },
7
+ export const UrlSafetyPlugin = () =>
8
+ createPayloadSetWitnessPlugin<UrlSafetyWitness>(
9
+ { required: { [UrlSafetySchema]: 1 }, schema: PayloadSetSchema },
10
10
  {
11
11
  witness: async (params) => {
12
- const result = await UrlWitness.create(params)
12
+ const result = await UrlSafetyWitness.create(params)
13
13
  return result
14
14
  },
15
15
  },
@@ -1,20 +1,40 @@
1
1
  import { AxiosJson } from '@xyo-network/axios'
2
+ import { Payload } from '@xyo-network/payload-model'
2
3
  import { UrlPayload, UrlSchema } from '@xyo-network/url-payload-plugin'
3
- import { UrlSafetyPayload } from '@xyo-network/url-safety-payload-plugin'
4
+ import { UrlSafetyPayload, UrlSafetySchema, UrlSafetyThreatType } from '@xyo-network/url-safety-payload-plugin'
4
5
  import { AbstractWitness } from '@xyo-network/witness'
5
6
 
6
7
  import { UrlSafetyWitnessConfigSchema } from './Config'
7
8
  import { UrlSafetyWitnessParams } from './Params'
8
9
 
10
+ export type GoogleSafeBrowsingMatchSchema = 'com.google.safebrowsing.match'
11
+ export const GoogleSafeBrowsingMatchSchema: GoogleSafeBrowsingMatchSchema = 'com.google.safebrowsing.match'
12
+
13
+ export interface GoogleSafeBrowsingMatch {
14
+ cacheDuration: string
15
+ platformType: string
16
+ threat: {
17
+ url: string
18
+ }
19
+ threatEntryType: string
20
+ threatType: string
21
+ }
22
+
23
+ export type GoogleSafeBrowsingMatchPayload = Payload<GoogleSafeBrowsingMatch, GoogleSafeBrowsingMatchSchema>
24
+
25
+ interface GoogleSafeBrowsingResult {
26
+ matches?: GoogleSafeBrowsingMatch[]
27
+ }
28
+
9
29
  const checkUrlSafety = async (
10
30
  urls: string[],
11
31
  config?: {
12
32
  endPoint?: string
13
33
  key?: string
14
34
  },
15
- ): Promise<UrlSafetyPayload[]> => {
35
+ ): Promise<GoogleSafeBrowsingMatchPayload[]> => {
16
36
  const axios = new AxiosJson()
17
- const endPoint = config?.endPoint ?? 'https://safebrowsing.googleapis.com/v5/threatMatches:find'
37
+ const endPoint = config?.endPoint ?? 'https://safebrowsing.googleapis.com/v4/threatMatches:find'
18
38
  const key = config?.key
19
39
  const mutatedUrls = urls.map((url) => url.replace('ipfs://', 'https://cloudflare-ipfs.com/'))
20
40
  if (mutatedUrls.length === 0) {
@@ -32,14 +52,20 @@ const checkUrlSafety = async (
32
52
  threatTypes: ['SOCIAL_ENGINEERING', 'POTENTIALLY_HARMFUL_APPLICATION', 'UNWANTED_SOFTWARE', 'THREAT_TYPE_UNSPECIFIED'],
33
53
  },
34
54
  }
35
- const result = (await axios.post(`${endPoint}?key=${key}`, postData)).data
36
- console.log(`checkUrlSafety: ${JSON.stringify(result, null, 2)}`)
37
- return []
55
+ console.log(`checkUrlSafetyIn: ${JSON.stringify(postData, null, 2)}`)
56
+ const result = (await axios.post<GoogleSafeBrowsingResult>(`${endPoint}?key=${key}`, postData, { headers: { referer: 'http://localhost:3000' } }))
57
+ .data
58
+ console.log(`checkUrlSafetyOut: ${JSON.stringify(result, null, 2)}`)
59
+ return result.matches?.map<GoogleSafeBrowsingMatchPayload>((match) => ({ ...match, schema: GoogleSafeBrowsingMatchSchema })) ?? []
38
60
  }
39
61
 
40
- export class UrlWitness<TParams extends UrlSafetyWitnessParams = UrlSafetyWitnessParams> extends AbstractWitness<TParams> {
62
+ export class UrlSafetyWitness<TParams extends UrlSafetyWitnessParams = UrlSafetyWitnessParams> extends AbstractWitness<TParams> {
41
63
  static override configSchemas = [UrlSafetyWitnessConfigSchema]
42
64
 
65
+ get key() {
66
+ return this.params.google?.safeBrowsing?.key
67
+ }
68
+
43
69
  get urls() {
44
70
  return this.config?.urls
45
71
  }
@@ -53,6 +79,23 @@ export class UrlWitness<TParams extends UrlSafetyWitnessParams = UrlSafetyWitnes
53
79
  return p.url
54
80
  })
55
81
 
56
- return await checkUrlSafety(urls)
82
+ const matches = await checkUrlSafety(urls, { key: this.key })
83
+
84
+ return urls.map((url) => {
85
+ const payload = matches.reduce<UrlSafetyPayload>(
86
+ (prev, match) => {
87
+ if (match.threat.url === url) {
88
+ prev.threatTypes = prev.threatTypes ?? []
89
+ if (!prev.threatTypes.includes(match.threatEntryType as UrlSafetyThreatType)) {
90
+ prev.threatTypes.push(match.threatEntryType as UrlSafetyThreatType)
91
+ }
92
+ }
93
+ return prev
94
+ },
95
+ { schema: UrlSafetySchema, url },
96
+ )
97
+ payload.threatTypes = payload.threatTypes?.sort()
98
+ return payload
99
+ })
57
100
  }
58
101
  }
package/src/index.ts CHANGED
@@ -1,8 +1,8 @@
1
- import { UrlPlugin } from './Plugin'
1
+ import { UrlSafetyPlugin } from './Plugin'
2
2
 
3
3
  export * from './Witness'
4
4
 
5
- export { UrlPlugin }
5
+ export { UrlSafetyPlugin }
6
6
 
7
7
  // eslint-disable-next-line import/no-default-export
8
- export default UrlPlugin
8
+ export default UrlSafetyPlugin