@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
@@ -0,0 +1,67 @@
1
+ import { UrlSafetyWitness } from './Witness';
2
+ export declare const UrlSafetyPlugin: () => import("@xyo-network/payloadset-plugin").PayloadSetWitnessPlugin<UrlSafetyWitness<import("@xyo-network/core").BaseParamsFields & {
3
+ account?: import("@xyo-network/account-model").AccountInstance | "random" | undefined;
4
+ config: import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<{
5
+ accountDerivationPath?: string | undefined;
6
+ readonly archivist?: import("@xyo-network/module-model").ArchivistModuleConfig | undefined;
7
+ readonly labels?: import("@xyo-network/module-model").Labels | undefined;
8
+ readonly name?: string | undefined;
9
+ readonly paging?: Record<string, {
10
+ size?: number | undefined;
11
+ }> | undefined;
12
+ readonly security?: {
13
+ readonly allowAnonymous?: boolean | undefined;
14
+ readonly allowed?: Record<string, (string | import("@xyo-network/module-model").CosigningAddressSet)[]> | undefined;
15
+ readonly disallowed?: Record<string, string[]> | undefined;
16
+ } | undefined;
17
+ readonly sign?: boolean | undefined;
18
+ readonly storeQueries?: boolean | undefined;
19
+ readonly timestamp?: boolean | undefined;
20
+ } & Omit<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<{
21
+ accountDerivationPath?: string | undefined;
22
+ readonly archivist?: import("@xyo-network/module-model").ArchivistModuleConfig | undefined;
23
+ readonly labels?: import("@xyo-network/module-model").Labels | undefined;
24
+ readonly name?: string | undefined;
25
+ readonly paging?: Record<string, {
26
+ size?: number | undefined;
27
+ }> | undefined;
28
+ readonly security?: {
29
+ readonly allowAnonymous?: boolean | undefined;
30
+ readonly allowed?: Record<string, (string | import("@xyo-network/module-model").CosigningAddressSet)[]> | undefined;
31
+ readonly disallowed?: Record<string, string[]> | undefined;
32
+ } | undefined;
33
+ readonly sign?: boolean | undefined;
34
+ readonly storeQueries?: boolean | undefined;
35
+ readonly timestamp?: boolean | undefined;
36
+ } & {
37
+ archivist?: string | undefined;
38
+ schema: "network.xyo.url.safety.witness.config";
39
+ targetSet?: (import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & import("@xyo-network/payload-model").PayloadSet & {
40
+ schema: "network.xyo.payload.set";
41
+ }) | undefined;
42
+ } & {
43
+ google?: {
44
+ safeBrowsing?: {
45
+ endPoint?: string | undefined;
46
+ } | undefined;
47
+ } | undefined;
48
+ schema: "network.xyo.url.safety.witness.config";
49
+ urls?: string[] | undefined;
50
+ }, "schema"> & {
51
+ schema: "network.xyo.url.safety.witness.config";
52
+ }, "schema"> & {
53
+ schema: string;
54
+ }, "schema"> & {
55
+ schema: string;
56
+ };
57
+ ephemeralQueryAccountEnabled?: boolean | undefined;
58
+ wallet?: import("@xyo-network/wallet-model").WalletInstance | undefined;
59
+ } & {
60
+ google?: {
61
+ safeBrowsing?: {
62
+ endPoint?: string | undefined;
63
+ key?: string | undefined;
64
+ } | undefined;
65
+ } | undefined;
66
+ }>>;
67
+ //# sourceMappingURL=Plugin.d.ts.map
@@ -0,0 +1 @@
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"}
@@ -16,6 +16,8 @@ var __copyProps = (to, from, except, desc) => {
16
16
  return to;
17
17
  };
18
18
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/Plugin.ts
19
21
  var Plugin_exports = {};
20
22
  __export(Plugin_exports, {
21
23
  UrlSafetyPlugin: () => UrlSafetyPlugin
@@ -23,13 +25,85 @@ __export(Plugin_exports, {
23
25
  module.exports = __toCommonJS(Plugin_exports);
24
26
  var import_payload_model = require("@xyo-network/payload-model");
25
27
  var import_payloadset_plugin = require("@xyo-network/payloadset-plugin");
28
+ var import_url_safety_payload_plugin3 = require("@xyo-network/url-safety-payload-plugin");
29
+
30
+ // src/Witness/Config.ts
26
31
  var import_url_safety_payload_plugin = require("@xyo-network/url-safety-payload-plugin");
27
- var import_Witness = require("./Witness");
28
- const UrlSafetyPlugin = () => (0, import_payloadset_plugin.createPayloadSetWitnessPlugin)(
29
- { required: { [import_url_safety_payload_plugin.UrlSafetySchema]: 1 }, schema: import_payload_model.PayloadSetSchema },
32
+ var UrlSafetyWitnessConfigSchema = `${import_url_safety_payload_plugin.UrlSafetySchema}.witness.config`;
33
+
34
+ // src/Witness/Witness.ts
35
+ var import_axios = require("@xyo-network/axios");
36
+ var import_url_payload_plugin = require("@xyo-network/url-payload-plugin");
37
+ var import_url_safety_payload_plugin2 = require("@xyo-network/url-safety-payload-plugin");
38
+ var import_witness = require("@xyo-network/witness");
39
+ var GoogleSafeBrowsingMatchSchema = "com.google.safebrowsing.match";
40
+ var checkUrlSafety = async (urls, config) => {
41
+ var _a;
42
+ const axios = new import_axios.AxiosJson();
43
+ const endPoint = (config == null ? void 0 : config.endPoint) ?? "https://safebrowsing.googleapis.com/v4/threatMatches:find";
44
+ const key = config == null ? void 0 : config.key;
45
+ const mutatedUrls = urls.map((url) => url.replace("ipfs://", "https://cloudflare-ipfs.com/"));
46
+ if (mutatedUrls.length === 0) {
47
+ return [];
48
+ }
49
+ const postData = {
50
+ client: {
51
+ clientId: "foreventory",
52
+ clientVersion: "1.0"
53
+ },
54
+ threatInfo: {
55
+ platformTypes: ["WINDOWS", "LINUX", "OSX"],
56
+ threatEntries: mutatedUrls.map((url) => ({ url })),
57
+ threatEntryTypes: ["URL"],
58
+ threatTypes: ["SOCIAL_ENGINEERING", "POTENTIALLY_HARMFUL_APPLICATION", "UNWANTED_SOFTWARE", "THREAT_TYPE_UNSPECIFIED"]
59
+ }
60
+ };
61
+ console.log(`checkUrlSafetyIn: ${JSON.stringify(postData, null, 2)}`);
62
+ const result = (await axios.post(`${endPoint}?key=${key}`, postData, { headers: { referer: "http://localhost:3000" } })).data;
63
+ console.log(`checkUrlSafetyOut: ${JSON.stringify(result, null, 2)}`);
64
+ return ((_a = result.matches) == null ? void 0 : _a.map((match) => ({ ...match, schema: GoogleSafeBrowsingMatchSchema }))) ?? [];
65
+ };
66
+ var UrlSafetyWitness = class extends import_witness.AbstractWitness {
67
+ static configSchemas = [UrlSafetyWitnessConfigSchema];
68
+ get key() {
69
+ var _a, _b;
70
+ return (_b = (_a = this.params.google) == null ? void 0 : _a.safeBrowsing) == null ? void 0 : _b.key;
71
+ }
72
+ get urls() {
73
+ var _a;
74
+ return (_a = this.config) == null ? void 0 : _a.urls;
75
+ }
76
+ async observeHandler(payloads = []) {
77
+ const urls = this.urls ?? payloads.filter((p) => p.schema === import_url_payload_plugin.UrlSchema).map((p) => {
78
+ return p.url;
79
+ });
80
+ const matches = await checkUrlSafety(urls, { key: this.key });
81
+ return urls.map((url) => {
82
+ var _a;
83
+ const payload = matches.reduce(
84
+ (prev, match) => {
85
+ if (match.threat.url === url) {
86
+ prev.threatTypes = prev.threatTypes ?? [];
87
+ if (!prev.threatTypes.includes(match.threatEntryType)) {
88
+ prev.threatTypes.push(match.threatEntryType);
89
+ }
90
+ }
91
+ return prev;
92
+ },
93
+ { schema: import_url_safety_payload_plugin2.UrlSafetySchema, url }
94
+ );
95
+ payload.threatTypes = (_a = payload.threatTypes) == null ? void 0 : _a.sort();
96
+ return payload;
97
+ });
98
+ }
99
+ };
100
+
101
+ // src/Plugin.ts
102
+ var UrlSafetyPlugin = () => (0, import_payloadset_plugin.createPayloadSetWitnessPlugin)(
103
+ { required: { [import_url_safety_payload_plugin3.UrlSafetySchema]: 1 }, schema: import_payload_model.PayloadSetSchema },
30
104
  {
31
105
  witness: async (params) => {
32
- const result = await import_Witness.UrlSafetyWitness.create(params);
106
+ const result = await UrlSafetyWitness.create(params);
33
107
  return result;
34
108
  }
35
109
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/Plugin.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"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,2BAAiC;AACjC,+BAA8C;AAC9C,uCAAgC;AAEhC,qBAAiC;AAE1B,MAAM,kBAAkB,UAC7B;AAAA,EACE,EAAE,UAAU,EAAE,CAAC,gDAAe,GAAG,EAAE,GAAG,QAAQ,sCAAiB;AAAA,EAC/D;AAAA,IACE,SAAS,OAAO,WAAW;AACzB,YAAM,SAAS,MAAM,gCAAiB,OAAO,MAAM;AACnD,aAAO;AAAA,IACT;AAAA,EACF;AACF;","names":[]}
1
+ {"version":3,"sources":["../../src/Plugin.ts","../../src/Witness/Config.ts","../../src/Witness/Witness.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"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,2BAAiC;AACjC,+BAA8C;AAC9C,IAAAA,oCAAgC;;;ACFhC,uCAAgC;AAGzB,IAAM,+BAA+B,GAAG,gDAAe;;;ACH9D,mBAA0B;AAE1B,gCAAsC;AACtC,IAAAC,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;;;AF9FO,IAAM,kBAAkB,UAC7B;AAAA,EACE,EAAE,UAAU,EAAE,CAAC,iDAAe,GAAG,EAAE,GAAG,QAAQ,sCAAiB;AAAA,EAC/D;AAAA,IACE,SAAS,OAAO,WAAW;AACzB,YAAM,SAAS,MAAM,iBAAiB,OAAO,MAAM;AACnD,aAAO;AAAA,IACT;AAAA,EACF;AACF;","names":["import_url_safety_payload_plugin","import_url_safety_payload_plugin"]}
@@ -1,9 +1,82 @@
1
+ // src/Plugin.ts
1
2
  import { PayloadSetSchema } from "@xyo-network/payload-model";
2
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
3
7
  import { UrlSafetySchema } from "@xyo-network/url-safety-payload-plugin";
4
- import { UrlSafetyWitness } from "./Witness";
5
- const UrlSafetyPlugin = () => createPayloadSetWitnessPlugin(
6
- { required: { [UrlSafetySchema]: 1 }, schema: PayloadSetSchema },
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 },
7
80
  {
8
81
  witness: async (params) => {
9
82
  const result = await UrlSafetyWitness.create(params);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/Plugin.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"],"mappings":"AAAA,SAAS,wBAAwB;AACjC,SAAS,qCAAqC;AAC9C,SAAS,uBAAuB;AAEhC,SAAS,wBAAwB;AAE1B,MAAM,kBAAkB,MAC7B;AAAA,EACE,EAAE,UAAU,EAAE,CAAC,eAAe,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;","names":[]}
1
+ {"version":3,"sources":["../../src/Plugin.ts","../../src/Witness/Config.ts","../../src/Witness/Witness.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"],"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;","names":["UrlSafetySchema","UrlSafetySchema","UrlSafetySchema","UrlSafetySchema"]}
@@ -0,0 +1,13 @@
1
+ import { WitnessConfig } from '@xyo-network/witness';
2
+ export declare const UrlSafetyWitnessConfigSchema: "network.xyo.url.safety.witness.config";
3
+ export type UrlSafetyWitnessConfigSchema = typeof UrlSafetyWitnessConfigSchema;
4
+ export type UrlSafetyWitnessConfig = WitnessConfig<{
5
+ google?: {
6
+ safeBrowsing?: {
7
+ endPoint?: string;
8
+ };
9
+ };
10
+ schema: UrlSafetyWitnessConfigSchema;
11
+ urls?: string[];
12
+ }>;
13
+ //# sourceMappingURL=Config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Config.d.ts","sourceRoot":"","sources":["../../../src/Witness/Config.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AAEpD,eAAO,MAAM,4BAA4B,yCAA+C,CAAA;AACxF,MAAM,MAAM,4BAA4B,GAAG,OAAO,4BAA4B,CAAA;AAE9E,MAAM,MAAM,sBAAsB,GAAG,aAAa,CAAC;IACjD,MAAM,CAAC,EAAE;QACP,YAAY,CAAC,EAAE;YACb,QAAQ,CAAC,EAAE,MAAM,CAAA;SAClB,CAAA;KACF,CAAA;IACD,MAAM,EAAE,4BAA4B,CAAA;IACpC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAA;CAChB,CAAC,CAAA"}
@@ -16,13 +16,15 @@ var __copyProps = (to, from, except, desc) => {
16
16
  return to;
17
17
  };
18
18
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/Witness/Config.ts
19
21
  var Config_exports = {};
20
22
  __export(Config_exports, {
21
23
  UrlSafetyWitnessConfigSchema: () => UrlSafetyWitnessConfigSchema
22
24
  });
23
25
  module.exports = __toCommonJS(Config_exports);
24
26
  var import_url_safety_payload_plugin = require("@xyo-network/url-safety-payload-plugin");
25
- const UrlSafetyWitnessConfigSchema = `${import_url_safety_payload_plugin.UrlSafetySchema}.witness.config`;
27
+ var UrlSafetyWitnessConfigSchema = `${import_url_safety_payload_plugin.UrlSafetySchema}.witness.config`;
26
28
  // Annotate the CommonJS export names for ESM import in node:
27
29
  0 && (module.exports = {
28
30
  UrlSafetyWitnessConfigSchema
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/Witness/Config.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"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,uCAAgC;AAGzB,MAAM,+BAA+B,GAAG,gDAAe;","names":[]}
1
+ {"version":3,"sources":["../../../src/Witness/Config.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"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,uCAAgC;AAGzB,IAAM,+BAA+B,GAAG,gDAAe;","names":[]}
@@ -1,5 +1,6 @@
1
+ // src/Witness/Config.ts
1
2
  import { UrlSafetySchema } from "@xyo-network/url-safety-payload-plugin";
2
- const UrlSafetyWitnessConfigSchema = `${UrlSafetySchema}.witness.config`;
3
+ var UrlSafetyWitnessConfigSchema = `${UrlSafetySchema}.witness.config`;
3
4
  export {
4
5
  UrlSafetyWitnessConfigSchema
5
6
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/Witness/Config.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"],"mappings":"AAAA,SAAS,uBAAuB;AAGzB,MAAM,+BAA+B,GAAG,eAAe;","names":[]}
1
+ {"version":3,"sources":["../../../src/Witness/Config.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"],"mappings":";AAAA,SAAS,uBAAuB;AAGzB,IAAM,+BAA+B,GAAG,eAAe;","names":[]}
@@ -0,0 +1,12 @@
1
+ import { AnyConfigSchema } from '@xyo-network/module';
2
+ import { WitnessParams } from '@xyo-network/witness';
3
+ import { UrlSafetyWitnessConfig } from './Config';
4
+ export type UrlSafetyWitnessParams = WitnessParams<AnyConfigSchema<UrlSafetyWitnessConfig>, {
5
+ google?: {
6
+ safeBrowsing?: {
7
+ endPoint?: string;
8
+ key?: string;
9
+ };
10
+ };
11
+ }>;
12
+ //# sourceMappingURL=Params.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Params.d.ts","sourceRoot":"","sources":["../../../src/Witness/Params.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AAEpD,OAAO,EAAE,sBAAsB,EAAE,MAAM,UAAU,CAAA;AAEjD,MAAM,MAAM,sBAAsB,GAAG,aAAa,CAChD,eAAe,CAAC,sBAAsB,CAAC,EACvC;IACE,MAAM,CAAC,EAAE;QACP,YAAY,CAAC,EAAE;YACb,QAAQ,CAAC,EAAE,MAAM,CAAA;YACjB,GAAG,CAAC,EAAE,MAAM,CAAA;SACb,CAAA;KACF,CAAA;CACF,CACF,CAAA"}
@@ -12,6 +12,8 @@ var __copyProps = (to, from, except, desc) => {
12
12
  return to;
13
13
  };
14
14
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
15
+
16
+ // src/Witness/Params.ts
15
17
  var Params_exports = {};
16
18
  module.exports = __toCommonJS(Params_exports);
17
19
  //# sourceMappingURL=Params.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/Witness/Params.ts"],"sourcesContent":["import { AnyConfigSchema } from '@xyo-network/module'\nimport { WitnessParams } from '@xyo-network/witness'\n\nimport { UrlSafetyWitnessConfig } from './Config'\n\nexport type UrlSafetyWitnessParams = WitnessParams<\n AnyConfigSchema<UrlSafetyWitnessConfig>,\n {\n google?: {\n safeBrowsing?: {\n endPoint?: string\n key?: string\n }\n }\n }\n>\n"],"mappings":";;;;;;;;;;;;;;AAAA;AAAA;","names":[]}
1
+ {"version":3,"sources":["../../../src/Witness/Params.ts"],"sourcesContent":["import { AnyConfigSchema } from '@xyo-network/module'\nimport { WitnessParams } from '@xyo-network/witness'\n\nimport { UrlSafetyWitnessConfig } from './Config'\n\nexport type UrlSafetyWitnessParams = WitnessParams<\n AnyConfigSchema<UrlSafetyWitnessConfig>,\n {\n google?: {\n safeBrowsing?: {\n endPoint?: string\n key?: string\n }\n }\n }\n>\n"],"mappings":";;;;;;;;;;;;;;;;AAAA;AAAA;","names":[]}
@@ -0,0 +1,24 @@
1
+ import { Payload } from '@xyo-network/payload-model';
2
+ import { UrlPayload } from '@xyo-network/url-payload-plugin';
3
+ import { UrlSafetyPayload } from '@xyo-network/url-safety-payload-plugin';
4
+ import { AbstractWitness } from '@xyo-network/witness';
5
+ import { UrlSafetyWitnessParams } from './Params';
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> {
19
+ static configSchemas: "network.xyo.url.safety.witness.config"[];
20
+ get key(): string | undefined;
21
+ get urls(): string[] | undefined;
22
+ protected observeHandler(payloads?: UrlPayload[]): Promise<UrlSafetyPayload[]>;
23
+ }
24
+ //# sourceMappingURL=Witness.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Witness.d.ts","sourceRoot":"","sources":["../../../src/Witness/Witness.ts"],"names":[],"mappings":"AACA,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"}
@@ -16,6 +16,8 @@ var __copyProps = (to, from, except, desc) => {
16
16
  return to;
17
17
  };
18
18
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/Witness/Witness.ts
19
21
  var Witness_exports = {};
20
22
  __export(Witness_exports, {
21
23
  GoogleSafeBrowsingMatchSchema: () => GoogleSafeBrowsingMatchSchema,
@@ -24,14 +26,20 @@ __export(Witness_exports, {
24
26
  module.exports = __toCommonJS(Witness_exports);
25
27
  var import_axios = require("@xyo-network/axios");
26
28
  var import_url_payload_plugin = require("@xyo-network/url-payload-plugin");
27
- var import_url_safety_payload_plugin = require("@xyo-network/url-safety-payload-plugin");
29
+ var import_url_safety_payload_plugin2 = require("@xyo-network/url-safety-payload-plugin");
28
30
  var import_witness = require("@xyo-network/witness");
29
- var import_Config = require("./Config");
30
- const GoogleSafeBrowsingMatchSchema = "com.google.safebrowsing.match";
31
- const checkUrlSafety = async (urls, config) => {
31
+
32
+ // src/Witness/Config.ts
33
+ var import_url_safety_payload_plugin = require("@xyo-network/url-safety-payload-plugin");
34
+ var UrlSafetyWitnessConfigSchema = `${import_url_safety_payload_plugin.UrlSafetySchema}.witness.config`;
35
+
36
+ // src/Witness/Witness.ts
37
+ var GoogleSafeBrowsingMatchSchema = "com.google.safebrowsing.match";
38
+ var checkUrlSafety = async (urls, config) => {
39
+ var _a;
32
40
  const axios = new import_axios.AxiosJson();
33
- const endPoint = config?.endPoint ?? "https://safebrowsing.googleapis.com/v4/threatMatches:find";
34
- const key = config?.key;
41
+ const endPoint = (config == null ? void 0 : config.endPoint) ?? "https://safebrowsing.googleapis.com/v4/threatMatches:find";
42
+ const key = config == null ? void 0 : config.key;
35
43
  const mutatedUrls = urls.map((url) => url.replace("ipfs://", "https://cloudflare-ipfs.com/"));
36
44
  if (mutatedUrls.length === 0) {
37
45
  return [];
@@ -51,15 +59,17 @@ const checkUrlSafety = async (urls, config) => {
51
59
  console.log(`checkUrlSafetyIn: ${JSON.stringify(postData, null, 2)}`);
52
60
  const result = (await axios.post(`${endPoint}?key=${key}`, postData, { headers: { referer: "http://localhost:3000" } })).data;
53
61
  console.log(`checkUrlSafetyOut: ${JSON.stringify(result, null, 2)}`);
54
- return result.matches?.map((match) => ({ ...match, schema: GoogleSafeBrowsingMatchSchema })) ?? [];
62
+ return ((_a = result.matches) == null ? void 0 : _a.map((match) => ({ ...match, schema: GoogleSafeBrowsingMatchSchema }))) ?? [];
55
63
  };
56
- class UrlSafetyWitness extends import_witness.AbstractWitness {
57
- static configSchemas = [import_Config.UrlSafetyWitnessConfigSchema];
64
+ var UrlSafetyWitness = class extends import_witness.AbstractWitness {
65
+ static configSchemas = [UrlSafetyWitnessConfigSchema];
58
66
  get key() {
59
- return this.params.google?.safeBrowsing?.key;
67
+ var _a, _b;
68
+ return (_b = (_a = this.params.google) == null ? void 0 : _a.safeBrowsing) == null ? void 0 : _b.key;
60
69
  }
61
70
  get urls() {
62
- return this.config?.urls;
71
+ var _a;
72
+ return (_a = this.config) == null ? void 0 : _a.urls;
63
73
  }
64
74
  async observeHandler(payloads = []) {
65
75
  const urls = this.urls ?? payloads.filter((p) => p.schema === import_url_payload_plugin.UrlSchema).map((p) => {
@@ -67,6 +77,7 @@ class UrlSafetyWitness extends import_witness.AbstractWitness {
67
77
  });
68
78
  const matches = await checkUrlSafety(urls, { key: this.key });
69
79
  return urls.map((url) => {
80
+ var _a;
70
81
  const payload = matches.reduce(
71
82
  (prev, match) => {
72
83
  if (match.threat.url === url) {
@@ -77,13 +88,13 @@ class UrlSafetyWitness extends import_witness.AbstractWitness {
77
88
  }
78
89
  return prev;
79
90
  },
80
- { schema: import_url_safety_payload_plugin.UrlSafetySchema, url }
91
+ { schema: import_url_safety_payload_plugin2.UrlSafetySchema, url }
81
92
  );
82
- payload.threatTypes = payload.threatTypes?.sort();
93
+ payload.threatTypes = (_a = payload.threatTypes) == null ? void 0 : _a.sort();
83
94
  return payload;
84
95
  });
85
96
  }
86
- }
97
+ };
87
98
  // Annotate the CommonJS export names for ESM import in node:
88
99
  0 && (module.exports = {
89
100
  GoogleSafeBrowsingMatchSchema,
@@ -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;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAA0B;AAE1B,gCAAsC;AACtC,uCAAuE;AACvE,qBAAgC;AAEhC,oBAA6C;AAItC,MAAM,gCAA+D;AAkB5E,MAAM,iBAAiB,OACrB,MACA,WAI8C;AAC9C,QAAM,QAAQ,IAAI,uBAAU;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,+BAAyB;AAAA,EAC9H,OAAgB,gBAAgB,CAAC,0CAA4B;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,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;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,kDAAiB,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;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAA0B;AAE1B,gCAAsC;AACtC,IAAAA,oCAAuE;AACvE,qBAAgC;;;ACJhC,uCAAgC;AAGzB,IAAM,+BAA+B,GAAG,gDAAe;;;ADOvD,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,13 +1,20 @@
1
+ // src/Witness/Witness.ts
1
2
  import { AxiosJson } from "@xyo-network/axios";
2
3
  import { UrlSchema } from "@xyo-network/url-payload-plugin";
3
- import { UrlSafetySchema } from "@xyo-network/url-safety-payload-plugin";
4
+ import { UrlSafetySchema as UrlSafetySchema2 } from "@xyo-network/url-safety-payload-plugin";
4
5
  import { AbstractWitness } from "@xyo-network/witness";
5
- import { UrlSafetyWitnessConfigSchema } from "./Config";
6
- const GoogleSafeBrowsingMatchSchema = "com.google.safebrowsing.match";
7
- const checkUrlSafety = async (urls, config) => {
6
+
7
+ // src/Witness/Config.ts
8
+ import { UrlSafetySchema } from "@xyo-network/url-safety-payload-plugin";
9
+ var UrlSafetyWitnessConfigSchema = `${UrlSafetySchema}.witness.config`;
10
+
11
+ // src/Witness/Witness.ts
12
+ var GoogleSafeBrowsingMatchSchema = "com.google.safebrowsing.match";
13
+ var checkUrlSafety = async (urls, config) => {
14
+ var _a;
8
15
  const axios = new AxiosJson();
9
- const endPoint = config?.endPoint ?? "https://safebrowsing.googleapis.com/v4/threatMatches:find";
10
- const key = config?.key;
16
+ const endPoint = (config == null ? void 0 : config.endPoint) ?? "https://safebrowsing.googleapis.com/v4/threatMatches:find";
17
+ const key = config == null ? void 0 : config.key;
11
18
  const mutatedUrls = urls.map((url) => url.replace("ipfs://", "https://cloudflare-ipfs.com/"));
12
19
  if (mutatedUrls.length === 0) {
13
20
  return [];
@@ -27,15 +34,17 @@ const checkUrlSafety = async (urls, config) => {
27
34
  console.log(`checkUrlSafetyIn: ${JSON.stringify(postData, null, 2)}`);
28
35
  const result = (await axios.post(`${endPoint}?key=${key}`, postData, { headers: { referer: "http://localhost:3000" } })).data;
29
36
  console.log(`checkUrlSafetyOut: ${JSON.stringify(result, null, 2)}`);
30
- return result.matches?.map((match) => ({ ...match, schema: GoogleSafeBrowsingMatchSchema })) ?? [];
37
+ return ((_a = result.matches) == null ? void 0 : _a.map((match) => ({ ...match, schema: GoogleSafeBrowsingMatchSchema }))) ?? [];
31
38
  };
32
- class UrlSafetyWitness extends AbstractWitness {
39
+ var UrlSafetyWitness = class extends AbstractWitness {
33
40
  static configSchemas = [UrlSafetyWitnessConfigSchema];
34
41
  get key() {
35
- return this.params.google?.safeBrowsing?.key;
42
+ var _a, _b;
43
+ return (_b = (_a = this.params.google) == null ? void 0 : _a.safeBrowsing) == null ? void 0 : _b.key;
36
44
  }
37
45
  get urls() {
38
- return this.config?.urls;
46
+ var _a;
47
+ return (_a = this.config) == null ? void 0 : _a.urls;
39
48
  }
40
49
  async observeHandler(payloads = []) {
41
50
  const urls = this.urls ?? payloads.filter((p) => p.schema === UrlSchema).map((p) => {
@@ -43,6 +52,7 @@ class UrlSafetyWitness extends AbstractWitness {
43
52
  });
44
53
  const matches = await checkUrlSafety(urls, { key: this.key });
45
54
  return urls.map((url) => {
55
+ var _a;
46
56
  const payload = matches.reduce(
47
57
  (prev, match) => {
48
58
  if (match.threat.url === url) {
@@ -53,13 +63,13 @@ class UrlSafetyWitness extends AbstractWitness {
53
63
  }
54
64
  return prev;
55
65
  },
56
- { schema: UrlSafetySchema, url }
66
+ { schema: UrlSafetySchema2, url }
57
67
  );
58
- payload.threatTypes = payload.threatTypes?.sort();
68
+ payload.threatTypes = (_a = payload.threatTypes) == null ? void 0 : _a.sort();
59
69
  return payload;
60
70
  });
61
71
  }
62
- }
72
+ };
63
73
  export {
64
74
  GoogleSafeBrowsingMatchSchema,
65
75
  UrlSafetyWitness