@xyo-network/url-safety-plugin 2.75.0 → 2.75.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (58) hide show
  1. package/dist/browser/Plugin.d.cts +67 -0
  2. package/dist/browser/Plugin.d.cts.map +1 -0
  3. package/dist/browser/Plugin.js +3 -72
  4. package/dist/browser/Plugin.js.map +1 -1
  5. package/dist/browser/Witness/Config.d.cts +13 -0
  6. package/dist/browser/Witness/Config.d.cts.map +1 -0
  7. package/dist/browser/Witness/Config.js +1 -2
  8. package/dist/browser/Witness/Config.js.map +1 -1
  9. package/dist/browser/Witness/Params.d.cts +12 -0
  10. package/dist/browser/Witness/Params.d.cts.map +1 -0
  11. package/dist/browser/Witness/Witness.d.cts +24 -0
  12. package/dist/browser/Witness/Witness.d.cts.map +1 -0
  13. package/dist/browser/Witness/Witness.js +7 -13
  14. package/dist/browser/Witness/Witness.js.map +1 -1
  15. package/dist/browser/Witness/index.d.cts +4 -0
  16. package/dist/browser/Witness/index.d.cts.map +1 -0
  17. package/dist/browser/Witness/index.js +3 -71
  18. package/dist/browser/Witness/index.js.map +1 -1
  19. package/dist/browser/index.d.cts +5 -0
  20. package/dist/browser/index.d.cts.map +1 -0
  21. package/dist/browser/index.js +2 -87
  22. package/dist/browser/index.js.map +1 -1
  23. package/dist/docs.json +24365 -0
  24. package/dist/node/Plugin.d.cts +67 -0
  25. package/dist/node/Plugin.d.cts.map +1 -0
  26. package/dist/node/Plugin.js +78 -4
  27. package/dist/node/Plugin.js.map +1 -1
  28. package/dist/node/Plugin.mjs +76 -3
  29. package/dist/node/Plugin.mjs.map +1 -1
  30. package/dist/node/Witness/Config.d.cts +13 -0
  31. package/dist/node/Witness/Config.d.cts.map +1 -0
  32. package/dist/node/Witness/Config.js +3 -1
  33. package/dist/node/Witness/Config.js.map +1 -1
  34. package/dist/node/Witness/Config.mjs +2 -1
  35. package/dist/node/Witness/Config.mjs.map +1 -1
  36. package/dist/node/Witness/Params.d.cts +12 -0
  37. package/dist/node/Witness/Params.d.cts.map +1 -0
  38. package/dist/node/Witness/Params.js +2 -0
  39. package/dist/node/Witness/Params.js.map +1 -1
  40. package/dist/node/Witness/Witness.d.cts +24 -0
  41. package/dist/node/Witness/Witness.d.cts.map +1 -0
  42. package/dist/node/Witness/Witness.js +25 -14
  43. package/dist/node/Witness/Witness.js.map +1 -1
  44. package/dist/node/Witness/Witness.mjs +23 -13
  45. package/dist/node/Witness/Witness.mjs.map +1 -1
  46. package/dist/node/Witness/index.d.cts +4 -0
  47. package/dist/node/Witness/index.d.cts.map +1 -0
  48. package/dist/node/Witness/index.js +85 -7
  49. package/dist/node/Witness/index.js.map +1 -1
  50. package/dist/node/Witness/index.mjs +75 -3
  51. package/dist/node/Witness/index.mjs.map +1 -1
  52. package/dist/node/index.d.cts +5 -0
  53. package/dist/node/index.d.cts.map +1 -0
  54. package/dist/node/index.js +99 -6
  55. package/dist/node/index.js.map +1 -1
  56. package/dist/node/index.mjs +91 -2
  57. package/dist/node/index.mjs.map +1 -1
  58. package/package.json +11 -11
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/Witness/Witness.ts"],"sourcesContent":["import { AxiosJson } from '@xyo-network/axios'\nimport { Payload } from '@xyo-network/payload-model'\nimport { UrlPayload, UrlSchema } from '@xyo-network/url-payload-plugin'\nimport { UrlSafetyPayload, UrlSafetySchema, UrlSafetyThreatType } from '@xyo-network/url-safety-payload-plugin'\nimport { AbstractWitness } from '@xyo-network/witness'\n\nimport { UrlSafetyWitnessConfigSchema } from './Config'\nimport { UrlSafetyWitnessParams } from './Params'\n\nexport type GoogleSafeBrowsingMatchSchema = 'com.google.safebrowsing.match'\nexport const GoogleSafeBrowsingMatchSchema: GoogleSafeBrowsingMatchSchema = 'com.google.safebrowsing.match'\n\nexport interface GoogleSafeBrowsingMatch {\n cacheDuration: string\n platformType: string\n threat: {\n url: string\n }\n threatEntryType: string\n threatType: string\n}\n\nexport type GoogleSafeBrowsingMatchPayload = Payload<GoogleSafeBrowsingMatch, GoogleSafeBrowsingMatchSchema>\n\ninterface GoogleSafeBrowsingResult {\n matches?: GoogleSafeBrowsingMatch[]\n}\n\nconst checkUrlSafety = async (\n urls: string[],\n config?: {\n endPoint?: string\n key?: string\n },\n): Promise<GoogleSafeBrowsingMatchPayload[]> => {\n const axios = new AxiosJson()\n const endPoint = config?.endPoint ?? 'https://safebrowsing.googleapis.com/v4/threatMatches:find'\n const key = config?.key\n const mutatedUrls = urls.map((url) => url.replace('ipfs://', 'https://cloudflare-ipfs.com/'))\n if (mutatedUrls.length === 0) {\n return []\n }\n const postData = {\n client: {\n clientId: 'foreventory',\n clientVersion: '1.0',\n },\n threatInfo: {\n platformTypes: ['WINDOWS', 'LINUX', 'OSX'],\n threatEntries: mutatedUrls.map((url) => ({ url })),\n threatEntryTypes: ['URL'],\n threatTypes: ['SOCIAL_ENGINEERING', 'POTENTIALLY_HARMFUL_APPLICATION', 'UNWANTED_SOFTWARE', 'THREAT_TYPE_UNSPECIFIED'],\n },\n }\n console.log(`checkUrlSafetyIn: ${JSON.stringify(postData, null, 2)}`)\n const result = (await axios.post<GoogleSafeBrowsingResult>(`${endPoint}?key=${key}`, postData, { headers: { referer: 'http://localhost:3000' } }))\n .data\n console.log(`checkUrlSafetyOut: ${JSON.stringify(result, null, 2)}`)\n return result.matches?.map<GoogleSafeBrowsingMatchPayload>((match) => ({ ...match, schema: GoogleSafeBrowsingMatchSchema })) ?? []\n}\n\nexport class UrlSafetyWitness<TParams extends UrlSafetyWitnessParams = UrlSafetyWitnessParams> extends AbstractWitness<TParams> {\n static override configSchemas = [UrlSafetyWitnessConfigSchema]\n\n get key() {\n return this.params.google?.safeBrowsing?.key\n }\n\n get urls() {\n return this.config?.urls\n }\n\n protected override async observeHandler(payloads: UrlPayload[] = []): Promise<UrlSafetyPayload[]> {\n const urls: string[] =\n this.urls ??\n payloads\n .filter((p): p is UrlPayload => p.schema === UrlSchema)\n .map((p) => {\n return p.url\n })\n\n const matches = await checkUrlSafety(urls, { key: this.key })\n\n return urls.map((url) => {\n const payload = matches.reduce<UrlSafetyPayload>(\n (prev, match) => {\n if (match.threat.url === url) {\n prev.threatTypes = prev.threatTypes ?? []\n if (!prev.threatTypes.includes(match.threatEntryType as UrlSafetyThreatType)) {\n prev.threatTypes.push(match.threatEntryType as UrlSafetyThreatType)\n }\n }\n return prev\n },\n { schema: UrlSafetySchema, url },\n )\n payload.threatTypes = payload.threatTypes?.sort()\n return payload\n })\n }\n}\n"],"mappings":"AAAA,SAAS,iBAAiB;AAE1B,SAAqB,iBAAiB;AACtC,SAA2B,uBAA4C;AACvE,SAAS,uBAAuB;AAEhC,SAAS,oCAAoC;AAItC,MAAM,gCAA+D;AAkB5E,MAAM,iBAAiB,OACrB,MACA,WAI8C;AAC9C,QAAM,QAAQ,IAAI,UAAU;AAC5B,QAAM,WAAW,QAAQ,YAAY;AACrC,QAAM,MAAM,QAAQ;AACpB,QAAM,cAAc,KAAK,IAAI,CAAC,QAAQ,IAAI,QAAQ,WAAW,8BAA8B,CAAC;AAC5F,MAAI,YAAY,WAAW,GAAG;AAC5B,WAAO,CAAC;AAAA,EACV;AACA,QAAM,WAAW;AAAA,IACf,QAAQ;AAAA,MACN,UAAU;AAAA,MACV,eAAe;AAAA,IACjB;AAAA,IACA,YAAY;AAAA,MACV,eAAe,CAAC,WAAW,SAAS,KAAK;AAAA,MACzC,eAAe,YAAY,IAAI,CAAC,SAAS,EAAE,IAAI,EAAE;AAAA,MACjD,kBAAkB,CAAC,KAAK;AAAA,MACxB,aAAa,CAAC,sBAAsB,mCAAmC,qBAAqB,yBAAyB;AAAA,IACvH;AAAA,EACF;AACA,UAAQ,IAAI,qBAAqB,KAAK,UAAU,UAAU,MAAM,CAAC,CAAC,EAAE;AACpE,QAAM,UAAU,MAAM,MAAM,KAA+B,GAAG,QAAQ,QAAQ,GAAG,IAAI,UAAU,EAAE,SAAS,EAAE,SAAS,wBAAwB,EAAE,CAAC,GAC7I;AACH,UAAQ,IAAI,sBAAsB,KAAK,UAAU,QAAQ,MAAM,CAAC,CAAC,EAAE;AACnE,SAAO,OAAO,SAAS,IAAoC,CAAC,WAAW,EAAE,GAAG,OAAO,QAAQ,8BAA8B,EAAE,KAAK,CAAC;AACnI;AAEO,MAAM,yBAA0F,gBAAyB;AAAA,EAC9H,OAAgB,gBAAgB,CAAC,4BAA4B;AAAA,EAE7D,IAAI,MAAM;AACR,WAAO,KAAK,OAAO,QAAQ,cAAc;AAAA,EAC3C;AAAA,EAEA,IAAI,OAAO;AACT,WAAO,KAAK,QAAQ;AAAA,EACtB;AAAA,EAEA,MAAyB,eAAe,WAAyB,CAAC,GAAgC;AAChG,UAAM,OACJ,KAAK,QACL,SACG,OAAO,CAAC,MAAuB,EAAE,WAAW,SAAS,EACrD,IAAI,CAAC,MAAM;AACV,aAAO,EAAE;AAAA,IACX,CAAC;AAEL,UAAM,UAAU,MAAM,eAAe,MAAM,EAAE,KAAK,KAAK,IAAI,CAAC;AAE5D,WAAO,KAAK,IAAI,CAAC,QAAQ;AACvB,YAAM,UAAU,QAAQ;AAAA,QACtB,CAAC,MAAM,UAAU;AACf,cAAI,MAAM,OAAO,QAAQ,KAAK;AAC5B,iBAAK,cAAc,KAAK,eAAe,CAAC;AACxC,gBAAI,CAAC,KAAK,YAAY,SAAS,MAAM,eAAsC,GAAG;AAC5E,mBAAK,YAAY,KAAK,MAAM,eAAsC;AAAA,YACpE;AAAA,UACF;AACA,iBAAO;AAAA,QACT;AAAA,QACA,EAAE,QAAQ,iBAAiB,IAAI;AAAA,MACjC;AACA,cAAQ,cAAc,QAAQ,aAAa,KAAK;AAChD,aAAO;AAAA,IACT,CAAC;AAAA,EACH;AACF;","names":[]}
1
+ {"version":3,"sources":["../../../src/Witness/Witness.ts","../../../src/Witness/Config.ts"],"sourcesContent":["import { AxiosJson } from '@xyo-network/axios'\nimport { Payload } from '@xyo-network/payload-model'\nimport { UrlPayload, UrlSchema } from '@xyo-network/url-payload-plugin'\nimport { UrlSafetyPayload, UrlSafetySchema, UrlSafetyThreatType } from '@xyo-network/url-safety-payload-plugin'\nimport { AbstractWitness } from '@xyo-network/witness'\n\nimport { UrlSafetyWitnessConfigSchema } from './Config'\nimport { UrlSafetyWitnessParams } from './Params'\n\nexport type GoogleSafeBrowsingMatchSchema = 'com.google.safebrowsing.match'\nexport const GoogleSafeBrowsingMatchSchema: GoogleSafeBrowsingMatchSchema = 'com.google.safebrowsing.match'\n\nexport interface GoogleSafeBrowsingMatch {\n cacheDuration: string\n platformType: string\n threat: {\n url: string\n }\n threatEntryType: string\n threatType: string\n}\n\nexport type GoogleSafeBrowsingMatchPayload = Payload<GoogleSafeBrowsingMatch, GoogleSafeBrowsingMatchSchema>\n\ninterface GoogleSafeBrowsingResult {\n matches?: GoogleSafeBrowsingMatch[]\n}\n\nconst checkUrlSafety = async (\n urls: string[],\n config?: {\n endPoint?: string\n key?: string\n },\n): Promise<GoogleSafeBrowsingMatchPayload[]> => {\n const axios = new AxiosJson()\n const endPoint = config?.endPoint ?? 'https://safebrowsing.googleapis.com/v4/threatMatches:find'\n const key = config?.key\n const mutatedUrls = urls.map((url) => url.replace('ipfs://', 'https://cloudflare-ipfs.com/'))\n if (mutatedUrls.length === 0) {\n return []\n }\n const postData = {\n client: {\n clientId: 'foreventory',\n clientVersion: '1.0',\n },\n threatInfo: {\n platformTypes: ['WINDOWS', 'LINUX', 'OSX'],\n threatEntries: mutatedUrls.map((url) => ({ url })),\n threatEntryTypes: ['URL'],\n threatTypes: ['SOCIAL_ENGINEERING', 'POTENTIALLY_HARMFUL_APPLICATION', 'UNWANTED_SOFTWARE', 'THREAT_TYPE_UNSPECIFIED'],\n },\n }\n console.log(`checkUrlSafetyIn: ${JSON.stringify(postData, null, 2)}`)\n const result = (await axios.post<GoogleSafeBrowsingResult>(`${endPoint}?key=${key}`, postData, { headers: { referer: 'http://localhost:3000' } }))\n .data\n console.log(`checkUrlSafetyOut: ${JSON.stringify(result, null, 2)}`)\n return result.matches?.map<GoogleSafeBrowsingMatchPayload>((match) => ({ ...match, schema: GoogleSafeBrowsingMatchSchema })) ?? []\n}\n\nexport class UrlSafetyWitness<TParams extends UrlSafetyWitnessParams = UrlSafetyWitnessParams> extends AbstractWitness<TParams> {\n static override configSchemas = [UrlSafetyWitnessConfigSchema]\n\n get key() {\n return this.params.google?.safeBrowsing?.key\n }\n\n get urls() {\n return this.config?.urls\n }\n\n protected override async observeHandler(payloads: UrlPayload[] = []): Promise<UrlSafetyPayload[]> {\n const urls: string[] =\n this.urls ??\n payloads\n .filter((p): p is UrlPayload => p.schema === UrlSchema)\n .map((p) => {\n return p.url\n })\n\n const matches = await checkUrlSafety(urls, { key: this.key })\n\n return urls.map((url) => {\n const payload = matches.reduce<UrlSafetyPayload>(\n (prev, match) => {\n if (match.threat.url === url) {\n prev.threatTypes = prev.threatTypes ?? []\n if (!prev.threatTypes.includes(match.threatEntryType as UrlSafetyThreatType)) {\n prev.threatTypes.push(match.threatEntryType as UrlSafetyThreatType)\n }\n }\n return prev\n },\n { schema: UrlSafetySchema, url },\n )\n payload.threatTypes = payload.threatTypes?.sort()\n return payload\n })\n }\n}\n","import { UrlSafetySchema } from '@xyo-network/url-safety-payload-plugin'\nimport { WitnessConfig } from '@xyo-network/witness'\n\nexport const UrlSafetyWitnessConfigSchema = `${UrlSafetySchema}.witness.config` as const\nexport type UrlSafetyWitnessConfigSchema = typeof UrlSafetyWitnessConfigSchema\n\nexport type UrlSafetyWitnessConfig = WitnessConfig<{\n google?: {\n safeBrowsing?: {\n endPoint?: string\n }\n }\n schema: UrlSafetyWitnessConfigSchema\n urls?: string[]\n}>\n"],"mappings":";AAAA,SAAS,iBAAiB;AAE1B,SAAqB,iBAAiB;AACtC,SAA2B,mBAAAA,wBAA4C;AACvE,SAAS,uBAAuB;;;ACJhC,SAAS,uBAAuB;AAGzB,IAAM,+BAA+B,GAAG,eAAe;;;ADOvD,IAAM,gCAA+D;AAkB5E,IAAM,iBAAiB,OACrB,MACA,WAI8C;AAlChD;AAmCE,QAAM,QAAQ,IAAI,UAAU;AAC5B,QAAM,YAAW,iCAAQ,aAAY;AACrC,QAAM,MAAM,iCAAQ;AACpB,QAAM,cAAc,KAAK,IAAI,CAAC,QAAQ,IAAI,QAAQ,WAAW,8BAA8B,CAAC;AAC5F,MAAI,YAAY,WAAW,GAAG;AAC5B,WAAO,CAAC;AAAA,EACV;AACA,QAAM,WAAW;AAAA,IACf,QAAQ;AAAA,MACN,UAAU;AAAA,MACV,eAAe;AAAA,IACjB;AAAA,IACA,YAAY;AAAA,MACV,eAAe,CAAC,WAAW,SAAS,KAAK;AAAA,MACzC,eAAe,YAAY,IAAI,CAAC,SAAS,EAAE,IAAI,EAAE;AAAA,MACjD,kBAAkB,CAAC,KAAK;AAAA,MACxB,aAAa,CAAC,sBAAsB,mCAAmC,qBAAqB,yBAAyB;AAAA,IACvH;AAAA,EACF;AACA,UAAQ,IAAI,qBAAqB,KAAK,UAAU,UAAU,MAAM,CAAC,CAAC,EAAE;AACpE,QAAM,UAAU,MAAM,MAAM,KAA+B,GAAG,QAAQ,QAAQ,GAAG,IAAI,UAAU,EAAE,SAAS,EAAE,SAAS,wBAAwB,EAAE,CAAC,GAC7I;AACH,UAAQ,IAAI,sBAAsB,KAAK,UAAU,QAAQ,MAAM,CAAC,CAAC,EAAE;AACnE,WAAO,YAAO,YAAP,mBAAgB,IAAoC,CAAC,WAAW,EAAE,GAAG,OAAO,QAAQ,8BAA8B,QAAO,CAAC;AACnI;AAEO,IAAM,mBAAN,cAAgG,gBAAyB;AAAA,EAC9H,OAAgB,gBAAgB,CAAC,4BAA4B;AAAA,EAE7D,IAAI,MAAM;AAhEZ;AAiEI,YAAO,gBAAK,OAAO,WAAZ,mBAAoB,iBAApB,mBAAkC;AAAA,EAC3C;AAAA,EAEA,IAAI,OAAO;AApEb;AAqEI,YAAO,UAAK,WAAL,mBAAa;AAAA,EACtB;AAAA,EAEA,MAAyB,eAAe,WAAyB,CAAC,GAAgC;AAChG,UAAM,OACJ,KAAK,QACL,SACG,OAAO,CAAC,MAAuB,EAAE,WAAW,SAAS,EACrD,IAAI,CAAC,MAAM;AACV,aAAO,EAAE;AAAA,IACX,CAAC;AAEL,UAAM,UAAU,MAAM,eAAe,MAAM,EAAE,KAAK,KAAK,IAAI,CAAC;AAE5D,WAAO,KAAK,IAAI,CAAC,QAAQ;AAnF7B;AAoFM,YAAM,UAAU,QAAQ;AAAA,QACtB,CAAC,MAAM,UAAU;AACf,cAAI,MAAM,OAAO,QAAQ,KAAK;AAC5B,iBAAK,cAAc,KAAK,eAAe,CAAC;AACxC,gBAAI,CAAC,KAAK,YAAY,SAAS,MAAM,eAAsC,GAAG;AAC5E,mBAAK,YAAY,KAAK,MAAM,eAAsC;AAAA,YACpE;AAAA,UACF;AACA,iBAAO;AAAA,QACT;AAAA,QACA,EAAE,QAAQC,kBAAiB,IAAI;AAAA,MACjC;AACA,cAAQ,eAAc,aAAQ,gBAAR,mBAAqB;AAC3C,aAAO;AAAA,IACT,CAAC;AAAA,EACH;AACF;","names":["UrlSafetySchema","UrlSafetySchema"]}
@@ -0,0 +1,4 @@
1
+ export * from './Config';
2
+ export * from './Params';
3
+ export * from './Witness';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/Witness/index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAA;AACxB,cAAc,UAAU,CAAA;AACxB,cAAc,WAAW,CAAA"}
@@ -3,6 +3,10 @@ var __defProp = Object.defineProperty;
3
3
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
4
  var __getOwnPropNames = Object.getOwnPropertyNames;
5
5
  var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
6
10
  var __copyProps = (to, from, except, desc) => {
7
11
  if (from && typeof from === "object" || typeof from === "function") {
8
12
  for (let key of __getOwnPropNames(from))
@@ -11,17 +15,91 @@ var __copyProps = (to, from, except, desc) => {
11
15
  }
12
16
  return to;
13
17
  };
14
- var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
15
18
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/Witness/index.ts
16
21
  var Witness_exports = {};
22
+ __export(Witness_exports, {
23
+ GoogleSafeBrowsingMatchSchema: () => GoogleSafeBrowsingMatchSchema,
24
+ UrlSafetyWitness: () => UrlSafetyWitness,
25
+ UrlSafetyWitnessConfigSchema: () => UrlSafetyWitnessConfigSchema
26
+ });
17
27
  module.exports = __toCommonJS(Witness_exports);
18
- __reExport(Witness_exports, require("./Config"), module.exports);
19
- __reExport(Witness_exports, require("./Params"), module.exports);
20
- __reExport(Witness_exports, require("./Witness"), module.exports);
28
+
29
+ // src/Witness/Config.ts
30
+ var import_url_safety_payload_plugin = require("@xyo-network/url-safety-payload-plugin");
31
+ var UrlSafetyWitnessConfigSchema = `${import_url_safety_payload_plugin.UrlSafetySchema}.witness.config`;
32
+
33
+ // src/Witness/Witness.ts
34
+ var import_axios = require("@xyo-network/axios");
35
+ var import_url_payload_plugin = require("@xyo-network/url-payload-plugin");
36
+ var import_url_safety_payload_plugin2 = require("@xyo-network/url-safety-payload-plugin");
37
+ var import_witness = require("@xyo-network/witness");
38
+ var GoogleSafeBrowsingMatchSchema = "com.google.safebrowsing.match";
39
+ var checkUrlSafety = async (urls, config) => {
40
+ var _a;
41
+ const axios = new import_axios.AxiosJson();
42
+ const endPoint = (config == null ? void 0 : config.endPoint) ?? "https://safebrowsing.googleapis.com/v4/threatMatches:find";
43
+ const key = config == null ? void 0 : config.key;
44
+ const mutatedUrls = urls.map((url) => url.replace("ipfs://", "https://cloudflare-ipfs.com/"));
45
+ if (mutatedUrls.length === 0) {
46
+ return [];
47
+ }
48
+ const postData = {
49
+ client: {
50
+ clientId: "foreventory",
51
+ clientVersion: "1.0"
52
+ },
53
+ threatInfo: {
54
+ platformTypes: ["WINDOWS", "LINUX", "OSX"],
55
+ threatEntries: mutatedUrls.map((url) => ({ url })),
56
+ threatEntryTypes: ["URL"],
57
+ threatTypes: ["SOCIAL_ENGINEERING", "POTENTIALLY_HARMFUL_APPLICATION", "UNWANTED_SOFTWARE", "THREAT_TYPE_UNSPECIFIED"]
58
+ }
59
+ };
60
+ console.log(`checkUrlSafetyIn: ${JSON.stringify(postData, null, 2)}`);
61
+ const result = (await axios.post(`${endPoint}?key=${key}`, postData, { headers: { referer: "http://localhost:3000" } })).data;
62
+ console.log(`checkUrlSafetyOut: ${JSON.stringify(result, null, 2)}`);
63
+ return ((_a = result.matches) == null ? void 0 : _a.map((match) => ({ ...match, schema: GoogleSafeBrowsingMatchSchema }))) ?? [];
64
+ };
65
+ var UrlSafetyWitness = class extends import_witness.AbstractWitness {
66
+ static configSchemas = [UrlSafetyWitnessConfigSchema];
67
+ get key() {
68
+ var _a, _b;
69
+ return (_b = (_a = this.params.google) == null ? void 0 : _a.safeBrowsing) == null ? void 0 : _b.key;
70
+ }
71
+ get urls() {
72
+ var _a;
73
+ return (_a = this.config) == null ? void 0 : _a.urls;
74
+ }
75
+ async observeHandler(payloads = []) {
76
+ const urls = this.urls ?? payloads.filter((p) => p.schema === import_url_payload_plugin.UrlSchema).map((p) => {
77
+ return p.url;
78
+ });
79
+ const matches = await checkUrlSafety(urls, { key: this.key });
80
+ return urls.map((url) => {
81
+ var _a;
82
+ const payload = matches.reduce(
83
+ (prev, match) => {
84
+ if (match.threat.url === url) {
85
+ prev.threatTypes = prev.threatTypes ?? [];
86
+ if (!prev.threatTypes.includes(match.threatEntryType)) {
87
+ prev.threatTypes.push(match.threatEntryType);
88
+ }
89
+ }
90
+ return prev;
91
+ },
92
+ { schema: import_url_safety_payload_plugin2.UrlSafetySchema, url }
93
+ );
94
+ payload.threatTypes = (_a = payload.threatTypes) == null ? void 0 : _a.sort();
95
+ return payload;
96
+ });
97
+ }
98
+ };
21
99
  // Annotate the CommonJS export names for ESM import in node:
22
100
  0 && (module.exports = {
23
- ...require("./Config"),
24
- ...require("./Params"),
25
- ...require("./Witness")
101
+ GoogleSafeBrowsingMatchSchema,
102
+ UrlSafetyWitness,
103
+ UrlSafetyWitnessConfigSchema
26
104
  });
27
105
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/Witness/index.ts"],"sourcesContent":["export * from './Config'\nexport * from './Params'\nexport * from './Witness'\n"],"mappings":";;;;;;;;;;;;;;;AAAA;AAAA;AAAA,4BAAc,qBAAd;AACA,4BAAc,qBADd;AAEA,4BAAc,sBAFd;","names":[]}
1
+ {"version":3,"sources":["../../../src/Witness/index.ts","../../../src/Witness/Config.ts","../../../src/Witness/Witness.ts"],"sourcesContent":["export * from './Config'\nexport * from './Params'\nexport * from './Witness'\n","import { UrlSafetySchema } from '@xyo-network/url-safety-payload-plugin'\nimport { WitnessConfig } from '@xyo-network/witness'\n\nexport const UrlSafetyWitnessConfigSchema = `${UrlSafetySchema}.witness.config` as const\nexport type UrlSafetyWitnessConfigSchema = typeof UrlSafetyWitnessConfigSchema\n\nexport type UrlSafetyWitnessConfig = WitnessConfig<{\n google?: {\n safeBrowsing?: {\n endPoint?: string\n }\n }\n schema: UrlSafetyWitnessConfigSchema\n urls?: string[]\n}>\n","import { AxiosJson } from '@xyo-network/axios'\nimport { Payload } from '@xyo-network/payload-model'\nimport { UrlPayload, UrlSchema } from '@xyo-network/url-payload-plugin'\nimport { UrlSafetyPayload, UrlSafetySchema, UrlSafetyThreatType } from '@xyo-network/url-safety-payload-plugin'\nimport { AbstractWitness } from '@xyo-network/witness'\n\nimport { UrlSafetyWitnessConfigSchema } from './Config'\nimport { UrlSafetyWitnessParams } from './Params'\n\nexport type GoogleSafeBrowsingMatchSchema = 'com.google.safebrowsing.match'\nexport const GoogleSafeBrowsingMatchSchema: GoogleSafeBrowsingMatchSchema = 'com.google.safebrowsing.match'\n\nexport interface GoogleSafeBrowsingMatch {\n cacheDuration: string\n platformType: string\n threat: {\n url: string\n }\n threatEntryType: string\n threatType: string\n}\n\nexport type GoogleSafeBrowsingMatchPayload = Payload<GoogleSafeBrowsingMatch, GoogleSafeBrowsingMatchSchema>\n\ninterface GoogleSafeBrowsingResult {\n matches?: GoogleSafeBrowsingMatch[]\n}\n\nconst checkUrlSafety = async (\n urls: string[],\n config?: {\n endPoint?: string\n key?: string\n },\n): Promise<GoogleSafeBrowsingMatchPayload[]> => {\n const axios = new AxiosJson()\n const endPoint = config?.endPoint ?? 'https://safebrowsing.googleapis.com/v4/threatMatches:find'\n const key = config?.key\n const mutatedUrls = urls.map((url) => url.replace('ipfs://', 'https://cloudflare-ipfs.com/'))\n if (mutatedUrls.length === 0) {\n return []\n }\n const postData = {\n client: {\n clientId: 'foreventory',\n clientVersion: '1.0',\n },\n threatInfo: {\n platformTypes: ['WINDOWS', 'LINUX', 'OSX'],\n threatEntries: mutatedUrls.map((url) => ({ url })),\n threatEntryTypes: ['URL'],\n threatTypes: ['SOCIAL_ENGINEERING', 'POTENTIALLY_HARMFUL_APPLICATION', 'UNWANTED_SOFTWARE', 'THREAT_TYPE_UNSPECIFIED'],\n },\n }\n console.log(`checkUrlSafetyIn: ${JSON.stringify(postData, null, 2)}`)\n const result = (await axios.post<GoogleSafeBrowsingResult>(`${endPoint}?key=${key}`, postData, { headers: { referer: 'http://localhost:3000' } }))\n .data\n console.log(`checkUrlSafetyOut: ${JSON.stringify(result, null, 2)}`)\n return result.matches?.map<GoogleSafeBrowsingMatchPayload>((match) => ({ ...match, schema: GoogleSafeBrowsingMatchSchema })) ?? []\n}\n\nexport class UrlSafetyWitness<TParams extends UrlSafetyWitnessParams = UrlSafetyWitnessParams> extends AbstractWitness<TParams> {\n static override configSchemas = [UrlSafetyWitnessConfigSchema]\n\n get key() {\n return this.params.google?.safeBrowsing?.key\n }\n\n get urls() {\n return this.config?.urls\n }\n\n protected override async observeHandler(payloads: UrlPayload[] = []): Promise<UrlSafetyPayload[]> {\n const urls: string[] =\n this.urls ??\n payloads\n .filter((p): p is UrlPayload => p.schema === UrlSchema)\n .map((p) => {\n return p.url\n })\n\n const matches = await checkUrlSafety(urls, { key: this.key })\n\n return urls.map((url) => {\n const payload = matches.reduce<UrlSafetyPayload>(\n (prev, match) => {\n if (match.threat.url === url) {\n prev.threatTypes = prev.threatTypes ?? []\n if (!prev.threatTypes.includes(match.threatEntryType as UrlSafetyThreatType)) {\n prev.threatTypes.push(match.threatEntryType as UrlSafetyThreatType)\n }\n }\n return prev\n },\n { schema: UrlSafetySchema, url },\n )\n payload.threatTypes = payload.threatTypes?.sort()\n return payload\n })\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA,uCAAgC;AAGzB,IAAM,+BAA+B,GAAG,gDAAe;;;ACH9D,mBAA0B;AAE1B,gCAAsC;AACtC,IAAAA,oCAAuE;AACvE,qBAAgC;AAMzB,IAAM,gCAA+D;AAkB5E,IAAM,iBAAiB,OACrB,MACA,WAI8C;AAlChD;AAmCE,QAAM,QAAQ,IAAI,uBAAU;AAC5B,QAAM,YAAW,iCAAQ,aAAY;AACrC,QAAM,MAAM,iCAAQ;AACpB,QAAM,cAAc,KAAK,IAAI,CAAC,QAAQ,IAAI,QAAQ,WAAW,8BAA8B,CAAC;AAC5F,MAAI,YAAY,WAAW,GAAG;AAC5B,WAAO,CAAC;AAAA,EACV;AACA,QAAM,WAAW;AAAA,IACf,QAAQ;AAAA,MACN,UAAU;AAAA,MACV,eAAe;AAAA,IACjB;AAAA,IACA,YAAY;AAAA,MACV,eAAe,CAAC,WAAW,SAAS,KAAK;AAAA,MACzC,eAAe,YAAY,IAAI,CAAC,SAAS,EAAE,IAAI,EAAE;AAAA,MACjD,kBAAkB,CAAC,KAAK;AAAA,MACxB,aAAa,CAAC,sBAAsB,mCAAmC,qBAAqB,yBAAyB;AAAA,IACvH;AAAA,EACF;AACA,UAAQ,IAAI,qBAAqB,KAAK,UAAU,UAAU,MAAM,CAAC,CAAC,EAAE;AACpE,QAAM,UAAU,MAAM,MAAM,KAA+B,GAAG,QAAQ,QAAQ,GAAG,IAAI,UAAU,EAAE,SAAS,EAAE,SAAS,wBAAwB,EAAE,CAAC,GAC7I;AACH,UAAQ,IAAI,sBAAsB,KAAK,UAAU,QAAQ,MAAM,CAAC,CAAC,EAAE;AACnE,WAAO,YAAO,YAAP,mBAAgB,IAAoC,CAAC,WAAW,EAAE,GAAG,OAAO,QAAQ,8BAA8B,QAAO,CAAC;AACnI;AAEO,IAAM,mBAAN,cAAgG,+BAAyB;AAAA,EAC9H,OAAgB,gBAAgB,CAAC,4BAA4B;AAAA,EAE7D,IAAI,MAAM;AAhEZ;AAiEI,YAAO,gBAAK,OAAO,WAAZ,mBAAoB,iBAApB,mBAAkC;AAAA,EAC3C;AAAA,EAEA,IAAI,OAAO;AApEb;AAqEI,YAAO,UAAK,WAAL,mBAAa;AAAA,EACtB;AAAA,EAEA,MAAyB,eAAe,WAAyB,CAAC,GAAgC;AAChG,UAAM,OACJ,KAAK,QACL,SACG,OAAO,CAAC,MAAuB,EAAE,WAAW,mCAAS,EACrD,IAAI,CAAC,MAAM;AACV,aAAO,EAAE;AAAA,IACX,CAAC;AAEL,UAAM,UAAU,MAAM,eAAe,MAAM,EAAE,KAAK,KAAK,IAAI,CAAC;AAE5D,WAAO,KAAK,IAAI,CAAC,QAAQ;AAnF7B;AAoFM,YAAM,UAAU,QAAQ;AAAA,QACtB,CAAC,MAAM,UAAU;AACf,cAAI,MAAM,OAAO,QAAQ,KAAK;AAC5B,iBAAK,cAAc,KAAK,eAAe,CAAC;AACxC,gBAAI,CAAC,KAAK,YAAY,SAAS,MAAM,eAAsC,GAAG;AAC5E,mBAAK,YAAY,KAAK,MAAM,eAAsC;AAAA,YACpE;AAAA,UACF;AACA,iBAAO;AAAA,QACT;AAAA,QACA,EAAE,QAAQ,mDAAiB,IAAI;AAAA,MACjC;AACA,cAAQ,eAAc,aAAQ,gBAAR,mBAAqB;AAC3C,aAAO;AAAA,IACT,CAAC;AAAA,EACH;AACF;","names":["import_url_safety_payload_plugin"]}
@@ -1,4 +1,76 @@
1
- export * from "./Config";
2
- export * from "./Params";
3
- export * from "./Witness";
1
+ // src/Witness/Config.ts
2
+ import { UrlSafetySchema } from "@xyo-network/url-safety-payload-plugin";
3
+ var UrlSafetyWitnessConfigSchema = `${UrlSafetySchema}.witness.config`;
4
+
5
+ // src/Witness/Witness.ts
6
+ import { AxiosJson } from "@xyo-network/axios";
7
+ import { UrlSchema } from "@xyo-network/url-payload-plugin";
8
+ import { UrlSafetySchema as UrlSafetySchema2 } from "@xyo-network/url-safety-payload-plugin";
9
+ import { AbstractWitness } from "@xyo-network/witness";
10
+ var GoogleSafeBrowsingMatchSchema = "com.google.safebrowsing.match";
11
+ var checkUrlSafety = async (urls, config) => {
12
+ var _a;
13
+ const axios = new AxiosJson();
14
+ const endPoint = (config == null ? void 0 : config.endPoint) ?? "https://safebrowsing.googleapis.com/v4/threatMatches:find";
15
+ const key = config == null ? void 0 : config.key;
16
+ const mutatedUrls = urls.map((url) => url.replace("ipfs://", "https://cloudflare-ipfs.com/"));
17
+ if (mutatedUrls.length === 0) {
18
+ return [];
19
+ }
20
+ const postData = {
21
+ client: {
22
+ clientId: "foreventory",
23
+ clientVersion: "1.0"
24
+ },
25
+ threatInfo: {
26
+ platformTypes: ["WINDOWS", "LINUX", "OSX"],
27
+ threatEntries: mutatedUrls.map((url) => ({ url })),
28
+ threatEntryTypes: ["URL"],
29
+ threatTypes: ["SOCIAL_ENGINEERING", "POTENTIALLY_HARMFUL_APPLICATION", "UNWANTED_SOFTWARE", "THREAT_TYPE_UNSPECIFIED"]
30
+ }
31
+ };
32
+ console.log(`checkUrlSafetyIn: ${JSON.stringify(postData, null, 2)}`);
33
+ const result = (await axios.post(`${endPoint}?key=${key}`, postData, { headers: { referer: "http://localhost:3000" } })).data;
34
+ console.log(`checkUrlSafetyOut: ${JSON.stringify(result, null, 2)}`);
35
+ return ((_a = result.matches) == null ? void 0 : _a.map((match) => ({ ...match, schema: GoogleSafeBrowsingMatchSchema }))) ?? [];
36
+ };
37
+ var UrlSafetyWitness = class extends AbstractWitness {
38
+ static configSchemas = [UrlSafetyWitnessConfigSchema];
39
+ get key() {
40
+ var _a, _b;
41
+ return (_b = (_a = this.params.google) == null ? void 0 : _a.safeBrowsing) == null ? void 0 : _b.key;
42
+ }
43
+ get urls() {
44
+ var _a;
45
+ return (_a = this.config) == null ? void 0 : _a.urls;
46
+ }
47
+ async observeHandler(payloads = []) {
48
+ const urls = this.urls ?? payloads.filter((p) => p.schema === UrlSchema).map((p) => {
49
+ return p.url;
50
+ });
51
+ const matches = await checkUrlSafety(urls, { key: this.key });
52
+ return urls.map((url) => {
53
+ var _a;
54
+ const payload = matches.reduce(
55
+ (prev, match) => {
56
+ if (match.threat.url === url) {
57
+ prev.threatTypes = prev.threatTypes ?? [];
58
+ if (!prev.threatTypes.includes(match.threatEntryType)) {
59
+ prev.threatTypes.push(match.threatEntryType);
60
+ }
61
+ }
62
+ return prev;
63
+ },
64
+ { schema: UrlSafetySchema2, url }
65
+ );
66
+ payload.threatTypes = (_a = payload.threatTypes) == null ? void 0 : _a.sort();
67
+ return payload;
68
+ });
69
+ }
70
+ };
71
+ export {
72
+ GoogleSafeBrowsingMatchSchema,
73
+ UrlSafetyWitness,
74
+ UrlSafetyWitnessConfigSchema
75
+ };
4
76
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/Witness/index.ts"],"sourcesContent":["export * from './Config'\nexport * from './Params'\nexport * from './Witness'\n"],"mappings":"AAAA,cAAc;AACd,cAAc;AACd,cAAc;","names":[]}
1
+ {"version":3,"sources":["../../../src/Witness/Config.ts","../../../src/Witness/Witness.ts"],"sourcesContent":["import { UrlSafetySchema } from '@xyo-network/url-safety-payload-plugin'\nimport { WitnessConfig } from '@xyo-network/witness'\n\nexport const UrlSafetyWitnessConfigSchema = `${UrlSafetySchema}.witness.config` as const\nexport type UrlSafetyWitnessConfigSchema = typeof UrlSafetyWitnessConfigSchema\n\nexport type UrlSafetyWitnessConfig = WitnessConfig<{\n google?: {\n safeBrowsing?: {\n endPoint?: string\n }\n }\n schema: UrlSafetyWitnessConfigSchema\n urls?: string[]\n}>\n","import { AxiosJson } from '@xyo-network/axios'\nimport { Payload } from '@xyo-network/payload-model'\nimport { UrlPayload, UrlSchema } from '@xyo-network/url-payload-plugin'\nimport { UrlSafetyPayload, UrlSafetySchema, UrlSafetyThreatType } from '@xyo-network/url-safety-payload-plugin'\nimport { AbstractWitness } from '@xyo-network/witness'\n\nimport { UrlSafetyWitnessConfigSchema } from './Config'\nimport { UrlSafetyWitnessParams } from './Params'\n\nexport type GoogleSafeBrowsingMatchSchema = 'com.google.safebrowsing.match'\nexport const GoogleSafeBrowsingMatchSchema: GoogleSafeBrowsingMatchSchema = 'com.google.safebrowsing.match'\n\nexport interface GoogleSafeBrowsingMatch {\n cacheDuration: string\n platformType: string\n threat: {\n url: string\n }\n threatEntryType: string\n threatType: string\n}\n\nexport type GoogleSafeBrowsingMatchPayload = Payload<GoogleSafeBrowsingMatch, GoogleSafeBrowsingMatchSchema>\n\ninterface GoogleSafeBrowsingResult {\n matches?: GoogleSafeBrowsingMatch[]\n}\n\nconst checkUrlSafety = async (\n urls: string[],\n config?: {\n endPoint?: string\n key?: string\n },\n): Promise<GoogleSafeBrowsingMatchPayload[]> => {\n const axios = new AxiosJson()\n const endPoint = config?.endPoint ?? 'https://safebrowsing.googleapis.com/v4/threatMatches:find'\n const key = config?.key\n const mutatedUrls = urls.map((url) => url.replace('ipfs://', 'https://cloudflare-ipfs.com/'))\n if (mutatedUrls.length === 0) {\n return []\n }\n const postData = {\n client: {\n clientId: 'foreventory',\n clientVersion: '1.0',\n },\n threatInfo: {\n platformTypes: ['WINDOWS', 'LINUX', 'OSX'],\n threatEntries: mutatedUrls.map((url) => ({ url })),\n threatEntryTypes: ['URL'],\n threatTypes: ['SOCIAL_ENGINEERING', 'POTENTIALLY_HARMFUL_APPLICATION', 'UNWANTED_SOFTWARE', 'THREAT_TYPE_UNSPECIFIED'],\n },\n }\n console.log(`checkUrlSafetyIn: ${JSON.stringify(postData, null, 2)}`)\n const result = (await axios.post<GoogleSafeBrowsingResult>(`${endPoint}?key=${key}`, postData, { headers: { referer: 'http://localhost:3000' } }))\n .data\n console.log(`checkUrlSafetyOut: ${JSON.stringify(result, null, 2)}`)\n return result.matches?.map<GoogleSafeBrowsingMatchPayload>((match) => ({ ...match, schema: GoogleSafeBrowsingMatchSchema })) ?? []\n}\n\nexport class UrlSafetyWitness<TParams extends UrlSafetyWitnessParams = UrlSafetyWitnessParams> extends AbstractWitness<TParams> {\n static override configSchemas = [UrlSafetyWitnessConfigSchema]\n\n get key() {\n return this.params.google?.safeBrowsing?.key\n }\n\n get urls() {\n return this.config?.urls\n }\n\n protected override async observeHandler(payloads: UrlPayload[] = []): Promise<UrlSafetyPayload[]> {\n const urls: string[] =\n this.urls ??\n payloads\n .filter((p): p is UrlPayload => p.schema === UrlSchema)\n .map((p) => {\n return p.url\n })\n\n const matches = await checkUrlSafety(urls, { key: this.key })\n\n return urls.map((url) => {\n const payload = matches.reduce<UrlSafetyPayload>(\n (prev, match) => {\n if (match.threat.url === url) {\n prev.threatTypes = prev.threatTypes ?? []\n if (!prev.threatTypes.includes(match.threatEntryType as UrlSafetyThreatType)) {\n prev.threatTypes.push(match.threatEntryType as UrlSafetyThreatType)\n }\n }\n return prev\n },\n { schema: UrlSafetySchema, url },\n )\n payload.threatTypes = payload.threatTypes?.sort()\n return payload\n })\n }\n}\n"],"mappings":";AAAA,SAAS,uBAAuB;AAGzB,IAAM,+BAA+B,GAAG,eAAe;;;ACH9D,SAAS,iBAAiB;AAE1B,SAAqB,iBAAiB;AACtC,SAA2B,mBAAAA,wBAA4C;AACvE,SAAS,uBAAuB;AAMzB,IAAM,gCAA+D;AAkB5E,IAAM,iBAAiB,OACrB,MACA,WAI8C;AAlChD;AAmCE,QAAM,QAAQ,IAAI,UAAU;AAC5B,QAAM,YAAW,iCAAQ,aAAY;AACrC,QAAM,MAAM,iCAAQ;AACpB,QAAM,cAAc,KAAK,IAAI,CAAC,QAAQ,IAAI,QAAQ,WAAW,8BAA8B,CAAC;AAC5F,MAAI,YAAY,WAAW,GAAG;AAC5B,WAAO,CAAC;AAAA,EACV;AACA,QAAM,WAAW;AAAA,IACf,QAAQ;AAAA,MACN,UAAU;AAAA,MACV,eAAe;AAAA,IACjB;AAAA,IACA,YAAY;AAAA,MACV,eAAe,CAAC,WAAW,SAAS,KAAK;AAAA,MACzC,eAAe,YAAY,IAAI,CAAC,SAAS,EAAE,IAAI,EAAE;AAAA,MACjD,kBAAkB,CAAC,KAAK;AAAA,MACxB,aAAa,CAAC,sBAAsB,mCAAmC,qBAAqB,yBAAyB;AAAA,IACvH;AAAA,EACF;AACA,UAAQ,IAAI,qBAAqB,KAAK,UAAU,UAAU,MAAM,CAAC,CAAC,EAAE;AACpE,QAAM,UAAU,MAAM,MAAM,KAA+B,GAAG,QAAQ,QAAQ,GAAG,IAAI,UAAU,EAAE,SAAS,EAAE,SAAS,wBAAwB,EAAE,CAAC,GAC7I;AACH,UAAQ,IAAI,sBAAsB,KAAK,UAAU,QAAQ,MAAM,CAAC,CAAC,EAAE;AACnE,WAAO,YAAO,YAAP,mBAAgB,IAAoC,CAAC,WAAW,EAAE,GAAG,OAAO,QAAQ,8BAA8B,QAAO,CAAC;AACnI;AAEO,IAAM,mBAAN,cAAgG,gBAAyB;AAAA,EAC9H,OAAgB,gBAAgB,CAAC,4BAA4B;AAAA,EAE7D,IAAI,MAAM;AAhEZ;AAiEI,YAAO,gBAAK,OAAO,WAAZ,mBAAoB,iBAApB,mBAAkC;AAAA,EAC3C;AAAA,EAEA,IAAI,OAAO;AApEb;AAqEI,YAAO,UAAK,WAAL,mBAAa;AAAA,EACtB;AAAA,EAEA,MAAyB,eAAe,WAAyB,CAAC,GAAgC;AAChG,UAAM,OACJ,KAAK,QACL,SACG,OAAO,CAAC,MAAuB,EAAE,WAAW,SAAS,EACrD,IAAI,CAAC,MAAM;AACV,aAAO,EAAE;AAAA,IACX,CAAC;AAEL,UAAM,UAAU,MAAM,eAAe,MAAM,EAAE,KAAK,KAAK,IAAI,CAAC;AAE5D,WAAO,KAAK,IAAI,CAAC,QAAQ;AAnF7B;AAoFM,YAAM,UAAU,QAAQ;AAAA,QACtB,CAAC,MAAM,UAAU;AACf,cAAI,MAAM,OAAO,QAAQ,KAAK;AAC5B,iBAAK,cAAc,KAAK,eAAe,CAAC;AACxC,gBAAI,CAAC,KAAK,YAAY,SAAS,MAAM,eAAsC,GAAG;AAC5E,mBAAK,YAAY,KAAK,MAAM,eAAsC;AAAA,YACpE;AAAA,UACF;AACA,iBAAO;AAAA,QACT;AAAA,QACA,EAAE,QAAQC,kBAAiB,IAAI;AAAA,MACjC;AACA,cAAQ,eAAc,aAAQ,gBAAR,mBAAqB;AAC3C,aAAO;AAAA,IACT,CAAC;AAAA,EACH;AACF;","names":["UrlSafetySchema","UrlSafetySchema"]}
@@ -0,0 +1,5 @@
1
+ import { UrlSafetyPlugin } from './Plugin';
2
+ export * from './Witness';
3
+ export { UrlSafetyPlugin };
4
+ export default UrlSafetyPlugin;
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
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"}
@@ -15,20 +15,113 @@ var __copyProps = (to, from, except, desc) => {
15
15
  }
16
16
  return to;
17
17
  };
18
- var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
19
18
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/index.ts
20
21
  var src_exports = {};
21
22
  __export(src_exports, {
22
- UrlSafetyPlugin: () => import_Plugin.UrlSafetyPlugin,
23
+ GoogleSafeBrowsingMatchSchema: () => GoogleSafeBrowsingMatchSchema,
24
+ UrlSafetyPlugin: () => UrlSafetyPlugin,
25
+ UrlSafetyWitness: () => UrlSafetyWitness,
26
+ UrlSafetyWitnessConfigSchema: () => UrlSafetyWitnessConfigSchema,
23
27
  default: () => src_default
24
28
  });
25
29
  module.exports = __toCommonJS(src_exports);
26
- var import_Plugin = require("./Plugin");
27
- __reExport(src_exports, require("./Witness"), module.exports);
28
- var src_default = import_Plugin.UrlSafetyPlugin;
30
+
31
+ // src/Plugin.ts
32
+ var import_payload_model = require("@xyo-network/payload-model");
33
+ var import_payloadset_plugin = require("@xyo-network/payloadset-plugin");
34
+ var import_url_safety_payload_plugin3 = require("@xyo-network/url-safety-payload-plugin");
35
+
36
+ // src/Witness/Config.ts
37
+ var import_url_safety_payload_plugin = require("@xyo-network/url-safety-payload-plugin");
38
+ var UrlSafetyWitnessConfigSchema = `${import_url_safety_payload_plugin.UrlSafetySchema}.witness.config`;
39
+
40
+ // src/Witness/Witness.ts
41
+ var import_axios = require("@xyo-network/axios");
42
+ var import_url_payload_plugin = require("@xyo-network/url-payload-plugin");
43
+ var import_url_safety_payload_plugin2 = require("@xyo-network/url-safety-payload-plugin");
44
+ var import_witness = require("@xyo-network/witness");
45
+ var GoogleSafeBrowsingMatchSchema = "com.google.safebrowsing.match";
46
+ var checkUrlSafety = async (urls, config) => {
47
+ var _a;
48
+ const axios = new import_axios.AxiosJson();
49
+ const endPoint = (config == null ? void 0 : config.endPoint) ?? "https://safebrowsing.googleapis.com/v4/threatMatches:find";
50
+ const key = config == null ? void 0 : config.key;
51
+ const mutatedUrls = urls.map((url) => url.replace("ipfs://", "https://cloudflare-ipfs.com/"));
52
+ if (mutatedUrls.length === 0) {
53
+ return [];
54
+ }
55
+ const postData = {
56
+ client: {
57
+ clientId: "foreventory",
58
+ clientVersion: "1.0"
59
+ },
60
+ threatInfo: {
61
+ platformTypes: ["WINDOWS", "LINUX", "OSX"],
62
+ threatEntries: mutatedUrls.map((url) => ({ url })),
63
+ threatEntryTypes: ["URL"],
64
+ threatTypes: ["SOCIAL_ENGINEERING", "POTENTIALLY_HARMFUL_APPLICATION", "UNWANTED_SOFTWARE", "THREAT_TYPE_UNSPECIFIED"]
65
+ }
66
+ };
67
+ console.log(`checkUrlSafetyIn: ${JSON.stringify(postData, null, 2)}`);
68
+ const result = (await axios.post(`${endPoint}?key=${key}`, postData, { headers: { referer: "http://localhost:3000" } })).data;
69
+ console.log(`checkUrlSafetyOut: ${JSON.stringify(result, null, 2)}`);
70
+ return ((_a = result.matches) == null ? void 0 : _a.map((match) => ({ ...match, schema: GoogleSafeBrowsingMatchSchema }))) ?? [];
71
+ };
72
+ var UrlSafetyWitness = class extends import_witness.AbstractWitness {
73
+ static configSchemas = [UrlSafetyWitnessConfigSchema];
74
+ get key() {
75
+ var _a, _b;
76
+ return (_b = (_a = this.params.google) == null ? void 0 : _a.safeBrowsing) == null ? void 0 : _b.key;
77
+ }
78
+ get urls() {
79
+ var _a;
80
+ return (_a = this.config) == null ? void 0 : _a.urls;
81
+ }
82
+ async observeHandler(payloads = []) {
83
+ const urls = this.urls ?? payloads.filter((p) => p.schema === import_url_payload_plugin.UrlSchema).map((p) => {
84
+ return p.url;
85
+ });
86
+ const matches = await checkUrlSafety(urls, { key: this.key });
87
+ return urls.map((url) => {
88
+ var _a;
89
+ const payload = matches.reduce(
90
+ (prev, match) => {
91
+ if (match.threat.url === url) {
92
+ prev.threatTypes = prev.threatTypes ?? [];
93
+ if (!prev.threatTypes.includes(match.threatEntryType)) {
94
+ prev.threatTypes.push(match.threatEntryType);
95
+ }
96
+ }
97
+ return prev;
98
+ },
99
+ { schema: import_url_safety_payload_plugin2.UrlSafetySchema, url }
100
+ );
101
+ payload.threatTypes = (_a = payload.threatTypes) == null ? void 0 : _a.sort();
102
+ return payload;
103
+ });
104
+ }
105
+ };
106
+
107
+ // src/Plugin.ts
108
+ var UrlSafetyPlugin = () => (0, import_payloadset_plugin.createPayloadSetWitnessPlugin)(
109
+ { required: { [import_url_safety_payload_plugin3.UrlSafetySchema]: 1 }, schema: import_payload_model.PayloadSetSchema },
110
+ {
111
+ witness: async (params) => {
112
+ const result = await UrlSafetyWitness.create(params);
113
+ return result;
114
+ }
115
+ }
116
+ );
117
+
118
+ // src/index.ts
119
+ var src_default = UrlSafetyPlugin;
29
120
  // Annotate the CommonJS export names for ESM import in node:
30
121
  0 && (module.exports = {
122
+ GoogleSafeBrowsingMatchSchema,
31
123
  UrlSafetyPlugin,
32
- ...require("./Witness")
124
+ UrlSafetyWitness,
125
+ UrlSafetyWitnessConfigSchema
33
126
  });
34
127
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts"],"sourcesContent":["import { UrlSafetyPlugin } from './Plugin'\n\nexport * from './Witness'\n\nexport { UrlSafetyPlugin }\n\n// eslint-disable-next-line import/no-default-export\nexport default UrlSafetyPlugin\n"],"mappings":";;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAAgC;AAEhC,wBAAc,sBAFd;AAOA,IAAO,cAAQ;","names":[]}
1
+ {"version":3,"sources":["../../src/index.ts","../../src/Plugin.ts","../../src/Witness/Config.ts","../../src/Witness/Witness.ts"],"sourcesContent":["import { UrlSafetyPlugin } from './Plugin'\n\nexport * from './Witness'\n\nexport { UrlSafetyPlugin }\n\n// eslint-disable-next-line import/no-default-export\nexport default UrlSafetyPlugin\n","import { PayloadSetSchema } from '@xyo-network/payload-model'\nimport { createPayloadSetWitnessPlugin } from '@xyo-network/payloadset-plugin'\nimport { UrlSafetySchema } from '@xyo-network/url-safety-payload-plugin'\n\nimport { UrlSafetyWitness } from './Witness'\n\nexport const UrlSafetyPlugin = () =>\n createPayloadSetWitnessPlugin<UrlSafetyWitness>(\n { required: { [UrlSafetySchema]: 1 }, schema: PayloadSetSchema },\n {\n witness: async (params) => {\n const result = await UrlSafetyWitness.create(params)\n return result\n },\n },\n )\n","import { UrlSafetySchema } from '@xyo-network/url-safety-payload-plugin'\nimport { WitnessConfig } from '@xyo-network/witness'\n\nexport const UrlSafetyWitnessConfigSchema = `${UrlSafetySchema}.witness.config` as const\nexport type UrlSafetyWitnessConfigSchema = typeof UrlSafetyWitnessConfigSchema\n\nexport type UrlSafetyWitnessConfig = WitnessConfig<{\n google?: {\n safeBrowsing?: {\n endPoint?: string\n }\n }\n schema: UrlSafetyWitnessConfigSchema\n urls?: string[]\n}>\n","import { AxiosJson } from '@xyo-network/axios'\nimport { Payload } from '@xyo-network/payload-model'\nimport { UrlPayload, UrlSchema } from '@xyo-network/url-payload-plugin'\nimport { UrlSafetyPayload, UrlSafetySchema, UrlSafetyThreatType } from '@xyo-network/url-safety-payload-plugin'\nimport { AbstractWitness } from '@xyo-network/witness'\n\nimport { UrlSafetyWitnessConfigSchema } from './Config'\nimport { UrlSafetyWitnessParams } from './Params'\n\nexport type GoogleSafeBrowsingMatchSchema = 'com.google.safebrowsing.match'\nexport const GoogleSafeBrowsingMatchSchema: GoogleSafeBrowsingMatchSchema = 'com.google.safebrowsing.match'\n\nexport interface GoogleSafeBrowsingMatch {\n cacheDuration: string\n platformType: string\n threat: {\n url: string\n }\n threatEntryType: string\n threatType: string\n}\n\nexport type GoogleSafeBrowsingMatchPayload = Payload<GoogleSafeBrowsingMatch, GoogleSafeBrowsingMatchSchema>\n\ninterface GoogleSafeBrowsingResult {\n matches?: GoogleSafeBrowsingMatch[]\n}\n\nconst checkUrlSafety = async (\n urls: string[],\n config?: {\n endPoint?: string\n key?: string\n },\n): Promise<GoogleSafeBrowsingMatchPayload[]> => {\n const axios = new AxiosJson()\n const endPoint = config?.endPoint ?? 'https://safebrowsing.googleapis.com/v4/threatMatches:find'\n const key = config?.key\n const mutatedUrls = urls.map((url) => url.replace('ipfs://', 'https://cloudflare-ipfs.com/'))\n if (mutatedUrls.length === 0) {\n return []\n }\n const postData = {\n client: {\n clientId: 'foreventory',\n clientVersion: '1.0',\n },\n threatInfo: {\n platformTypes: ['WINDOWS', 'LINUX', 'OSX'],\n threatEntries: mutatedUrls.map((url) => ({ url })),\n threatEntryTypes: ['URL'],\n threatTypes: ['SOCIAL_ENGINEERING', 'POTENTIALLY_HARMFUL_APPLICATION', 'UNWANTED_SOFTWARE', 'THREAT_TYPE_UNSPECIFIED'],\n },\n }\n console.log(`checkUrlSafetyIn: ${JSON.stringify(postData, null, 2)}`)\n const result = (await axios.post<GoogleSafeBrowsingResult>(`${endPoint}?key=${key}`, postData, { headers: { referer: 'http://localhost:3000' } }))\n .data\n console.log(`checkUrlSafetyOut: ${JSON.stringify(result, null, 2)}`)\n return result.matches?.map<GoogleSafeBrowsingMatchPayload>((match) => ({ ...match, schema: GoogleSafeBrowsingMatchSchema })) ?? []\n}\n\nexport class UrlSafetyWitness<TParams extends UrlSafetyWitnessParams = UrlSafetyWitnessParams> extends AbstractWitness<TParams> {\n static override configSchemas = [UrlSafetyWitnessConfigSchema]\n\n get key() {\n return this.params.google?.safeBrowsing?.key\n }\n\n get urls() {\n return this.config?.urls\n }\n\n protected override async observeHandler(payloads: UrlPayload[] = []): Promise<UrlSafetyPayload[]> {\n const urls: string[] =\n this.urls ??\n payloads\n .filter((p): p is UrlPayload => p.schema === UrlSchema)\n .map((p) => {\n return p.url\n })\n\n const matches = await checkUrlSafety(urls, { key: this.key })\n\n return urls.map((url) => {\n const payload = matches.reduce<UrlSafetyPayload>(\n (prev, match) => {\n if (match.threat.url === url) {\n prev.threatTypes = prev.threatTypes ?? []\n if (!prev.threatTypes.includes(match.threatEntryType as UrlSafetyThreatType)) {\n prev.threatTypes.push(match.threatEntryType as UrlSafetyThreatType)\n }\n }\n return prev\n },\n { schema: UrlSafetySchema, url },\n )\n payload.threatTypes = payload.threatTypes?.sort()\n return payload\n })\n }\n}\n"],"mappings":"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","names":["import_url_safety_payload_plugin","import_url_safety_payload_plugin"]}
@@ -1,8 +1,97 @@
1
- import { UrlSafetyPlugin } from "./Plugin";
2
- export * from "./Witness";
1
+ // src/Plugin.ts
2
+ import { PayloadSetSchema } from "@xyo-network/payload-model";
3
+ import { createPayloadSetWitnessPlugin } from "@xyo-network/payloadset-plugin";
4
+ import { UrlSafetySchema as UrlSafetySchema3 } from "@xyo-network/url-safety-payload-plugin";
5
+
6
+ // src/Witness/Config.ts
7
+ import { UrlSafetySchema } from "@xyo-network/url-safety-payload-plugin";
8
+ var UrlSafetyWitnessConfigSchema = `${UrlSafetySchema}.witness.config`;
9
+
10
+ // src/Witness/Witness.ts
11
+ import { AxiosJson } from "@xyo-network/axios";
12
+ import { UrlSchema } from "@xyo-network/url-payload-plugin";
13
+ import { UrlSafetySchema as UrlSafetySchema2 } from "@xyo-network/url-safety-payload-plugin";
14
+ import { AbstractWitness } from "@xyo-network/witness";
15
+ var GoogleSafeBrowsingMatchSchema = "com.google.safebrowsing.match";
16
+ var checkUrlSafety = async (urls, config) => {
17
+ var _a;
18
+ const axios = new AxiosJson();
19
+ const endPoint = (config == null ? void 0 : config.endPoint) ?? "https://safebrowsing.googleapis.com/v4/threatMatches:find";
20
+ const key = config == null ? void 0 : config.key;
21
+ const mutatedUrls = urls.map((url) => url.replace("ipfs://", "https://cloudflare-ipfs.com/"));
22
+ if (mutatedUrls.length === 0) {
23
+ return [];
24
+ }
25
+ const postData = {
26
+ client: {
27
+ clientId: "foreventory",
28
+ clientVersion: "1.0"
29
+ },
30
+ threatInfo: {
31
+ platformTypes: ["WINDOWS", "LINUX", "OSX"],
32
+ threatEntries: mutatedUrls.map((url) => ({ url })),
33
+ threatEntryTypes: ["URL"],
34
+ threatTypes: ["SOCIAL_ENGINEERING", "POTENTIALLY_HARMFUL_APPLICATION", "UNWANTED_SOFTWARE", "THREAT_TYPE_UNSPECIFIED"]
35
+ }
36
+ };
37
+ console.log(`checkUrlSafetyIn: ${JSON.stringify(postData, null, 2)}`);
38
+ const result = (await axios.post(`${endPoint}?key=${key}`, postData, { headers: { referer: "http://localhost:3000" } })).data;
39
+ console.log(`checkUrlSafetyOut: ${JSON.stringify(result, null, 2)}`);
40
+ return ((_a = result.matches) == null ? void 0 : _a.map((match) => ({ ...match, schema: GoogleSafeBrowsingMatchSchema }))) ?? [];
41
+ };
42
+ var UrlSafetyWitness = class extends AbstractWitness {
43
+ static configSchemas = [UrlSafetyWitnessConfigSchema];
44
+ get key() {
45
+ var _a, _b;
46
+ return (_b = (_a = this.params.google) == null ? void 0 : _a.safeBrowsing) == null ? void 0 : _b.key;
47
+ }
48
+ get urls() {
49
+ var _a;
50
+ return (_a = this.config) == null ? void 0 : _a.urls;
51
+ }
52
+ async observeHandler(payloads = []) {
53
+ const urls = this.urls ?? payloads.filter((p) => p.schema === UrlSchema).map((p) => {
54
+ return p.url;
55
+ });
56
+ const matches = await checkUrlSafety(urls, { key: this.key });
57
+ return urls.map((url) => {
58
+ var _a;
59
+ const payload = matches.reduce(
60
+ (prev, match) => {
61
+ if (match.threat.url === url) {
62
+ prev.threatTypes = prev.threatTypes ?? [];
63
+ if (!prev.threatTypes.includes(match.threatEntryType)) {
64
+ prev.threatTypes.push(match.threatEntryType);
65
+ }
66
+ }
67
+ return prev;
68
+ },
69
+ { schema: UrlSafetySchema2, url }
70
+ );
71
+ payload.threatTypes = (_a = payload.threatTypes) == null ? void 0 : _a.sort();
72
+ return payload;
73
+ });
74
+ }
75
+ };
76
+
77
+ // src/Plugin.ts
78
+ var UrlSafetyPlugin = () => createPayloadSetWitnessPlugin(
79
+ { required: { [UrlSafetySchema3]: 1 }, schema: PayloadSetSchema },
80
+ {
81
+ witness: async (params) => {
82
+ const result = await UrlSafetyWitness.create(params);
83
+ return result;
84
+ }
85
+ }
86
+ );
87
+
88
+ // src/index.ts
3
89
  var src_default = UrlSafetyPlugin;
4
90
  export {
91
+ GoogleSafeBrowsingMatchSchema,
5
92
  UrlSafetyPlugin,
93
+ UrlSafetyWitness,
94
+ UrlSafetyWitnessConfigSchema,
6
95
  src_default as default
7
96
  };
8
97
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts"],"sourcesContent":["import { UrlSafetyPlugin } from './Plugin'\n\nexport * from './Witness'\n\nexport { UrlSafetyPlugin }\n\n// eslint-disable-next-line import/no-default-export\nexport default UrlSafetyPlugin\n"],"mappings":"AAAA,SAAS,uBAAuB;AAEhC,cAAc;AAKd,IAAO,cAAQ;","names":[]}
1
+ {"version":3,"sources":["../../src/Plugin.ts","../../src/Witness/Config.ts","../../src/Witness/Witness.ts","../../src/index.ts"],"sourcesContent":["import { PayloadSetSchema } from '@xyo-network/payload-model'\nimport { createPayloadSetWitnessPlugin } from '@xyo-network/payloadset-plugin'\nimport { UrlSafetySchema } from '@xyo-network/url-safety-payload-plugin'\n\nimport { UrlSafetyWitness } from './Witness'\n\nexport const UrlSafetyPlugin = () =>\n createPayloadSetWitnessPlugin<UrlSafetyWitness>(\n { required: { [UrlSafetySchema]: 1 }, schema: PayloadSetSchema },\n {\n witness: async (params) => {\n const result = await UrlSafetyWitness.create(params)\n return result\n },\n },\n )\n","import { UrlSafetySchema } from '@xyo-network/url-safety-payload-plugin'\nimport { WitnessConfig } from '@xyo-network/witness'\n\nexport const UrlSafetyWitnessConfigSchema = `${UrlSafetySchema}.witness.config` as const\nexport type UrlSafetyWitnessConfigSchema = typeof UrlSafetyWitnessConfigSchema\n\nexport type UrlSafetyWitnessConfig = WitnessConfig<{\n google?: {\n safeBrowsing?: {\n endPoint?: string\n }\n }\n schema: UrlSafetyWitnessConfigSchema\n urls?: string[]\n}>\n","import { AxiosJson } from '@xyo-network/axios'\nimport { Payload } from '@xyo-network/payload-model'\nimport { UrlPayload, UrlSchema } from '@xyo-network/url-payload-plugin'\nimport { UrlSafetyPayload, UrlSafetySchema, UrlSafetyThreatType } from '@xyo-network/url-safety-payload-plugin'\nimport { AbstractWitness } from '@xyo-network/witness'\n\nimport { UrlSafetyWitnessConfigSchema } from './Config'\nimport { UrlSafetyWitnessParams } from './Params'\n\nexport type GoogleSafeBrowsingMatchSchema = 'com.google.safebrowsing.match'\nexport const GoogleSafeBrowsingMatchSchema: GoogleSafeBrowsingMatchSchema = 'com.google.safebrowsing.match'\n\nexport interface GoogleSafeBrowsingMatch {\n cacheDuration: string\n platformType: string\n threat: {\n url: string\n }\n threatEntryType: string\n threatType: string\n}\n\nexport type GoogleSafeBrowsingMatchPayload = Payload<GoogleSafeBrowsingMatch, GoogleSafeBrowsingMatchSchema>\n\ninterface GoogleSafeBrowsingResult {\n matches?: GoogleSafeBrowsingMatch[]\n}\n\nconst checkUrlSafety = async (\n urls: string[],\n config?: {\n endPoint?: string\n key?: string\n },\n): Promise<GoogleSafeBrowsingMatchPayload[]> => {\n const axios = new AxiosJson()\n const endPoint = config?.endPoint ?? 'https://safebrowsing.googleapis.com/v4/threatMatches:find'\n const key = config?.key\n const mutatedUrls = urls.map((url) => url.replace('ipfs://', 'https://cloudflare-ipfs.com/'))\n if (mutatedUrls.length === 0) {\n return []\n }\n const postData = {\n client: {\n clientId: 'foreventory',\n clientVersion: '1.0',\n },\n threatInfo: {\n platformTypes: ['WINDOWS', 'LINUX', 'OSX'],\n threatEntries: mutatedUrls.map((url) => ({ url })),\n threatEntryTypes: ['URL'],\n threatTypes: ['SOCIAL_ENGINEERING', 'POTENTIALLY_HARMFUL_APPLICATION', 'UNWANTED_SOFTWARE', 'THREAT_TYPE_UNSPECIFIED'],\n },\n }\n console.log(`checkUrlSafetyIn: ${JSON.stringify(postData, null, 2)}`)\n const result = (await axios.post<GoogleSafeBrowsingResult>(`${endPoint}?key=${key}`, postData, { headers: { referer: 'http://localhost:3000' } }))\n .data\n console.log(`checkUrlSafetyOut: ${JSON.stringify(result, null, 2)}`)\n return result.matches?.map<GoogleSafeBrowsingMatchPayload>((match) => ({ ...match, schema: GoogleSafeBrowsingMatchSchema })) ?? []\n}\n\nexport class UrlSafetyWitness<TParams extends UrlSafetyWitnessParams = UrlSafetyWitnessParams> extends AbstractWitness<TParams> {\n static override configSchemas = [UrlSafetyWitnessConfigSchema]\n\n get key() {\n return this.params.google?.safeBrowsing?.key\n }\n\n get urls() {\n return this.config?.urls\n }\n\n protected override async observeHandler(payloads: UrlPayload[] = []): Promise<UrlSafetyPayload[]> {\n const urls: string[] =\n this.urls ??\n payloads\n .filter((p): p is UrlPayload => p.schema === UrlSchema)\n .map((p) => {\n return p.url\n })\n\n const matches = await checkUrlSafety(urls, { key: this.key })\n\n return urls.map((url) => {\n const payload = matches.reduce<UrlSafetyPayload>(\n (prev, match) => {\n if (match.threat.url === url) {\n prev.threatTypes = prev.threatTypes ?? []\n if (!prev.threatTypes.includes(match.threatEntryType as UrlSafetyThreatType)) {\n prev.threatTypes.push(match.threatEntryType as UrlSafetyThreatType)\n }\n }\n return prev\n },\n { schema: UrlSafetySchema, url },\n )\n payload.threatTypes = payload.threatTypes?.sort()\n return payload\n })\n }\n}\n","import { UrlSafetyPlugin } from './Plugin'\n\nexport * from './Witness'\n\nexport { UrlSafetyPlugin }\n\n// eslint-disable-next-line import/no-default-export\nexport default UrlSafetyPlugin\n"],"mappings":";AAAA,SAAS,wBAAwB;AACjC,SAAS,qCAAqC;AAC9C,SAAS,mBAAAA,wBAAuB;;;ACFhC,SAAS,uBAAuB;AAGzB,IAAM,+BAA+B,GAAG,eAAe;;;ACH9D,SAAS,iBAAiB;AAE1B,SAAqB,iBAAiB;AACtC,SAA2B,mBAAAC,wBAA4C;AACvE,SAAS,uBAAuB;AAMzB,IAAM,gCAA+D;AAkB5E,IAAM,iBAAiB,OACrB,MACA,WAI8C;AAlChD;AAmCE,QAAM,QAAQ,IAAI,UAAU;AAC5B,QAAM,YAAW,iCAAQ,aAAY;AACrC,QAAM,MAAM,iCAAQ;AACpB,QAAM,cAAc,KAAK,IAAI,CAAC,QAAQ,IAAI,QAAQ,WAAW,8BAA8B,CAAC;AAC5F,MAAI,YAAY,WAAW,GAAG;AAC5B,WAAO,CAAC;AAAA,EACV;AACA,QAAM,WAAW;AAAA,IACf,QAAQ;AAAA,MACN,UAAU;AAAA,MACV,eAAe;AAAA,IACjB;AAAA,IACA,YAAY;AAAA,MACV,eAAe,CAAC,WAAW,SAAS,KAAK;AAAA,MACzC,eAAe,YAAY,IAAI,CAAC,SAAS,EAAE,IAAI,EAAE;AAAA,MACjD,kBAAkB,CAAC,KAAK;AAAA,MACxB,aAAa,CAAC,sBAAsB,mCAAmC,qBAAqB,yBAAyB;AAAA,IACvH;AAAA,EACF;AACA,UAAQ,IAAI,qBAAqB,KAAK,UAAU,UAAU,MAAM,CAAC,CAAC,EAAE;AACpE,QAAM,UAAU,MAAM,MAAM,KAA+B,GAAG,QAAQ,QAAQ,GAAG,IAAI,UAAU,EAAE,SAAS,EAAE,SAAS,wBAAwB,EAAE,CAAC,GAC7I;AACH,UAAQ,IAAI,sBAAsB,KAAK,UAAU,QAAQ,MAAM,CAAC,CAAC,EAAE;AACnE,WAAO,YAAO,YAAP,mBAAgB,IAAoC,CAAC,WAAW,EAAE,GAAG,OAAO,QAAQ,8BAA8B,QAAO,CAAC;AACnI;AAEO,IAAM,mBAAN,cAAgG,gBAAyB;AAAA,EAC9H,OAAgB,gBAAgB,CAAC,4BAA4B;AAAA,EAE7D,IAAI,MAAM;AAhEZ;AAiEI,YAAO,gBAAK,OAAO,WAAZ,mBAAoB,iBAApB,mBAAkC;AAAA,EAC3C;AAAA,EAEA,IAAI,OAAO;AApEb;AAqEI,YAAO,UAAK,WAAL,mBAAa;AAAA,EACtB;AAAA,EAEA,MAAyB,eAAe,WAAyB,CAAC,GAAgC;AAChG,UAAM,OACJ,KAAK,QACL,SACG,OAAO,CAAC,MAAuB,EAAE,WAAW,SAAS,EACrD,IAAI,CAAC,MAAM;AACV,aAAO,EAAE;AAAA,IACX,CAAC;AAEL,UAAM,UAAU,MAAM,eAAe,MAAM,EAAE,KAAK,KAAK,IAAI,CAAC;AAE5D,WAAO,KAAK,IAAI,CAAC,QAAQ;AAnF7B;AAoFM,YAAM,UAAU,QAAQ;AAAA,QACtB,CAAC,MAAM,UAAU;AACf,cAAI,MAAM,OAAO,QAAQ,KAAK;AAC5B,iBAAK,cAAc,KAAK,eAAe,CAAC;AACxC,gBAAI,CAAC,KAAK,YAAY,SAAS,MAAM,eAAsC,GAAG;AAC5E,mBAAK,YAAY,KAAK,MAAM,eAAsC;AAAA,YACpE;AAAA,UACF;AACA,iBAAO;AAAA,QACT;AAAA,QACA,EAAE,QAAQC,kBAAiB,IAAI;AAAA,MACjC;AACA,cAAQ,eAAc,aAAQ,gBAAR,mBAAqB;AAC3C,aAAO;AAAA,IACT,CAAC;AAAA,EACH;AACF;;;AF9FO,IAAM,kBAAkB,MAC7B;AAAA,EACE,EAAE,UAAU,EAAE,CAACC,gBAAe,GAAG,EAAE,GAAG,QAAQ,iBAAiB;AAAA,EAC/D;AAAA,IACE,SAAS,OAAO,WAAW;AACzB,YAAM,SAAS,MAAM,iBAAiB,OAAO,MAAM;AACnD,aAAO;AAAA,IACT;AAAA,EACF;AACF;;;AGRF,IAAO,cAAQ;","names":["UrlSafetySchema","UrlSafetySchema","UrlSafetySchema","UrlSafetySchema"]}
package/package.json CHANGED
@@ -10,17 +10,17 @@
10
10
  "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js/issues"
11
11
  },
12
12
  "dependencies": {
13
- "@xyo-network/axios": "~2.75.0",
14
- "@xyo-network/module": "~2.75.0",
15
- "@xyo-network/payload-model": "~2.75.0",
16
- "@xyo-network/payloadset-plugin": "~2.75.0",
17
- "@xyo-network/url-payload-plugin": "~2.75.0",
18
- "@xyo-network/url-safety-payload-plugin": "~2.75.0",
19
- "@xyo-network/witness": "~2.75.0"
13
+ "@xyo-network/axios": "~2.75.3",
14
+ "@xyo-network/module": "~2.75.3",
15
+ "@xyo-network/payload-model": "~2.75.3",
16
+ "@xyo-network/payloadset-plugin": "~2.75.3",
17
+ "@xyo-network/url-payload-plugin": "~2.75.3",
18
+ "@xyo-network/url-safety-payload-plugin": "~2.75.3",
19
+ "@xyo-network/witness": "~2.75.3"
20
20
  },
21
21
  "devDependencies": {
22
- "@xylabs/ts-scripts-yarn3": "^3.0.70",
23
- "@xylabs/tsconfig": "^3.0.70",
22
+ "@xylabs/ts-scripts-yarn3": "^3.0.77",
23
+ "@xylabs/tsconfig": "^3.0.77",
24
24
  "typescript": "^5.2.2"
25
25
  },
26
26
  "description": "Primary SDK for using XYO Protocol 2.0",
@@ -30,7 +30,7 @@
30
30
  ".": {
31
31
  "browser": {
32
32
  "require": {
33
- "types": "./dist/browser/index.d.ts",
33
+ "types": "./dist/browser/index.d.cts",
34
34
  "default": "./dist/browser/index.cjs"
35
35
  },
36
36
  "import": {
@@ -66,5 +66,5 @@
66
66
  "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
67
67
  },
68
68
  "sideEffects": false,
69
- "version": "2.75.0"
69
+ "version": "2.75.3"
70
70
  }