@xyo-network/url-safety-plugin 2.99.5 → 2.99.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/Plugin.ts","../../src/Witness/Config.ts","../../src/Witness/Witness.ts"],"sourcesContent":["// eslint-disable-next-line import/no-default-export\nexport { UrlSafetyPlugin as default, UrlSafetyPlugin } from './Plugin.ts'\nexport * from './Witness/index.ts'\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/index.ts'\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-model'\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 '@xylabs/axios'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport { Payload, Schema } 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'\n\nimport { UrlSafetyWitnessConfigSchema } from './Config.ts'\nimport { UrlSafetyWitnessParams } from './Params.ts'\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 const result = (await axios.post<GoogleSafeBrowsingResult>(`${endPoint}?key=${key}`, postData, { headers: { referer: 'http://localhost:3000' } }))\n .data\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 readonly configSchemas: Schema[] = [...super.configSchemas, UrlSafetyWitnessConfigSchema]\n static override readonly defaultConfigSchema: Schema = 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 // eslint-disable-next-line unicorn/no-array-reduce\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;;;;;;;;;;;ACAA,2BAAiC;AACjC,+BAA8C;AAC9C,IAAAA,oCAAgC;;;ACFhC,uCAAgC;AAGzB,IAAMC,+BAA+B,GAAGC,gDAAAA;;;ACH/C,mBAA0B;AAC1B,8BAAgC;AAEhC,gCAAsC;AACtC,IAAAC,oCAAuE;AAMhE,IAAMC,gCAA+D;AAkB5E,IAAMC,iBAAiB,8BACrBC,MACAC,WAAAA;AAKA,QAAMC,QAAQ,IAAIC,uBAAAA;AAClB,QAAMC,WAAWH,QAAQG,YAAY;AACrC,QAAMC,MAAMJ,QAAQI;AACpB,QAAMC,cAAcN,KAAKO,IAAIC,CAAAA,QAAOA,IAAIC,QAAQ,WAAW,8BAAA,CAAA;AAC3D,MAAIH,YAAYI,WAAW,GAAG;AAC5B,WAAO,CAAA;EACT;AACA,QAAMC,WAAW;IACfC,QAAQ;MACNC,UAAU;MACVC,eAAe;IACjB;IACAC,YAAY;MACVC,eAAe;QAAC;QAAW;QAAS;;MACpCC,eAAeX,YAAYC,IAAIC,CAAAA,SAAQ;QAAEA;MAAI,EAAA;MAC7CU,kBAAkB;QAAC;;MACnBC,aAAa;QAAC;QAAsB;QAAmC;QAAqB;;IAC9F;EACF;AACA,QAAMC,UAAU,MAAMlB,MAAMmB,KAA+B,GAAGjB,QAAAA,QAAgBC,GAAAA,IAAOM,UAAU;IAAEW,SAAS;MAAEC,SAAS;IAAwB;EAAE,CAAA,GAC5IC;AACH,SAAOJ,OAAOK,SAASlB,IAAoCmB,CAAAA,WAAU;IAAE,GAAGA;IAAOC,QAAQ7B;EAA8B,EAAA,KAAO,CAAA;AAChI,GA7BuB;AA+BhB,IAAM8B,mBAAN,cAAgGC,wCAAAA;EA3DvG,OA2DuGA;;;EACrG,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAEvD,IAAI1B,MAAM;AACR,WAAO,KAAK4B,OAAOC,QAAQC,cAAc9B;EAC3C;EAEA,IAAIL,OAAO;AACT,WAAO,KAAKC,QAAQD;EACtB;EAEA,MAAyBoC,eAAeC,WAAyB,CAAA,GAAiC;AAChG,UAAMrC,OACF,KAAKA,QACJqC,SACAC,OAAO,CAACC,MAAuBA,EAAEZ,WAAWa,mCAAAA,EAC5CjC,IAAI,CAACgC,MAAAA;AACJ,aAAOA,EAAE/B;IACX,CAAA;AAEJ,UAAMiB,UAAU,MAAM1B,eAAeC,MAAM;MAAEK,KAAK,KAAKA;IAAI,CAAA;AAE3D,WAAOL,KAAKO,IAAI,CAACC,QAAAA;AAEf,YAAMiC,UAAUhB,QAAQiB,OACtB,CAACC,MAAMjB,UAAAA;AACL,YAAIA,MAAMkB,OAAOpC,QAAQA,KAAK;AAC5BmC,eAAKxB,cAAcwB,KAAKxB,eAAe,CAAA;AACvC,cAAI,CAACwB,KAAKxB,YAAY0B,SAASnB,MAAMoB,eAAe,GAA0B;AAC5EH,iBAAKxB,YAAY4B,KAAKrB,MAAMoB,eAAe;UAC7C;QACF;AACA,eAAOH;MACT,GACA;QAAEhB,QAAQqB;QAAiBxC;MAAI,CAAA;AAEjCiC,cAAQtB,cAAcsB,QAAQtB,aAAa8B,KAAAA;AAC3C,aAAOR;IACT,CAAA;EACF;AACF;;;AF9FO,IAAMS,kBAAkB,iCAC7BC,wDACE;EAAEC,UAAU;IAAE,CAACC,iDAAAA,GAAkB;EAAE;EAAGC,QAAQC;AAAiB,GAC/D;EACEC,SAAS,8BAAOC,WAAAA;AACd,UAAMC,SAAS,MAAMC,iBAAiBC,OAAOH,MAAAA;AAC7C,WAAOC;EACT,GAHS;AAIX,CAAA,GAR2B;","names":["import_url_safety_payload_plugin","UrlSafetyWitnessConfigSchema","UrlSafetySchema","import_url_safety_payload_plugin","GoogleSafeBrowsingMatchSchema","checkUrlSafety","urls","config","axios","AxiosJson","endPoint","key","mutatedUrls","map","url","replace","length","postData","client","clientId","clientVersion","threatInfo","platformTypes","threatEntries","threatEntryTypes","threatTypes","result","post","headers","referer","data","matches","match","schema","UrlSafetyWitness","AbstractWitness","configSchemas","UrlSafetyWitnessConfigSchema","defaultConfigSchema","params","google","safeBrowsing","observeHandler","payloads","filter","p","UrlSchema","payload","reduce","prev","threat","includes","threatEntryType","push","UrlSafetySchema","sort","UrlSafetyPlugin","createPayloadSetWitnessPlugin","required","UrlSafetySchema","schema","PayloadSetSchema","witness","params","result","UrlSafetyWitness","create"]}
1
+ {"version":3,"sources":["../../src/index.ts","../../src/Plugin.ts","../../src/Witness/Config.ts","../../src/Witness/Witness.ts"],"sourcesContent":["// eslint-disable-next-line import/no-default-export\nexport { UrlSafetyPlugin as default, UrlSafetyPlugin } from './Plugin.ts'\nexport * from './Witness/index.ts'\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/index.ts'\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-model'\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 '@xylabs/axios'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport { Payload, Schema } 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'\n\nimport { UrlSafetyWitnessConfigSchema } from './Config.ts'\nimport { UrlSafetyWitnessParams } from './Params.ts'\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 const result = (await axios.post<GoogleSafeBrowsingResult>(`${endPoint}?key=${key}`, postData, { headers: { referer: 'http://localhost:3000' } }))\n .data\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 readonly configSchemas: Schema[] = [...super.configSchemas, UrlSafetyWitnessConfigSchema]\n static override readonly defaultConfigSchema: Schema = 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 // eslint-disable-next-line unicorn/no-array-reduce\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;AAAA;AAAA;;;ACAA,2BAAiC;AACjC,+BAA8C;AAC9C,IAAAA,oCAAgC;;;ACFhC,uCAAgC;AAGzB,IAAM,+BAA+B,GAAG,gDAAe;;;ACH9D,mBAA0B;AAC1B,8BAAgC;AAEhC,gCAAsC;AACtC,IAAAC,oCAAuE;AAMhE,IAAM,gCAA+D;AAkB5E,IAAM,iBAAiB,OACrB,MACA,WAI8C;AAC9C,QAAM,QAAQ,IAAI,uBAAU;AAC5B,QAAM,WAAW,QAAQ,YAAY;AACrC,QAAM,MAAM,QAAQ;AACpB,QAAM,cAAc,KAAK,IAAI,SAAO,IAAI,QAAQ,WAAW,8BAA8B,CAAC;AAC1F,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,UAAQ,EAAE,IAAI,EAAE;AAAA,MAC/C,kBAAkB,CAAC,KAAK;AAAA,MACxB,aAAa,CAAC,sBAAsB,mCAAmC,qBAAqB,yBAAyB;AAAA,IACvH;AAAA,EACF;AACA,QAAM,UAAU,MAAM,MAAM,KAA+B,GAAG,QAAQ,QAAQ,GAAG,IAAI,UAAU,EAAE,SAAS,EAAE,SAAS,wBAAwB,EAAE,CAAC,GAC7I;AACH,SAAO,OAAO,SAAS,IAAoC,YAAU,EAAE,GAAG,OAAO,QAAQ,8BAA8B,EAAE,KAAK,CAAC;AACjI;AAEO,IAAM,mBAAN,cAAgG,wCAAyB;AAAA,EAC9H,OAAyB,gBAA0B,CAAC,GAAG,MAAM,eAAe,4BAA4B;AAAA,EACxG,OAAyB,sBAA8B;AAAA,EAEvD,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,OACF,KAAK,QACJ,SACA,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;AAEvB,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,cAAc,QAAQ,aAAa,KAAK;AAChD,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,6 +1,3 @@
1
- var __defProp = Object.defineProperty;
2
- var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
-
4
1
  // src/Plugin.ts
5
2
  import { PayloadSetSchema } from "@xyo-network/payload-model";
6
3
  import { createPayloadSetWitnessPlugin } from "@xyo-network/payloadset-plugin";
@@ -16,7 +13,7 @@ import { AbstractWitness } from "@xyo-network/abstract-witness";
16
13
  import { UrlSchema } from "@xyo-network/url-payload-plugin";
17
14
  import { UrlSafetySchema as UrlSafetySchema2 } from "@xyo-network/url-safety-payload-plugin";
18
15
  var GoogleSafeBrowsingMatchSchema = "com.google.safebrowsing.match";
19
- var checkUrlSafety = /* @__PURE__ */ __name(async (urls, config) => {
16
+ var checkUrlSafety = async (urls, config) => {
20
17
  const axios = new AxiosJson();
21
18
  const endPoint = config?.endPoint ?? "https://safebrowsing.googleapis.com/v4/threatMatches:find";
22
19
  const key = config?.key;
@@ -30,43 +27,17 @@ var checkUrlSafety = /* @__PURE__ */ __name(async (urls, config) => {
30
27
  clientVersion: "1.0"
31
28
  },
32
29
  threatInfo: {
33
- platformTypes: [
34
- "WINDOWS",
35
- "LINUX",
36
- "OSX"
37
- ],
38
- threatEntries: mutatedUrls.map((url) => ({
39
- url
40
- })),
41
- threatEntryTypes: [
42
- "URL"
43
- ],
44
- threatTypes: [
45
- "SOCIAL_ENGINEERING",
46
- "POTENTIALLY_HARMFUL_APPLICATION",
47
- "UNWANTED_SOFTWARE",
48
- "THREAT_TYPE_UNSPECIFIED"
49
- ]
30
+ platformTypes: ["WINDOWS", "LINUX", "OSX"],
31
+ threatEntries: mutatedUrls.map((url) => ({ url })),
32
+ threatEntryTypes: ["URL"],
33
+ threatTypes: ["SOCIAL_ENGINEERING", "POTENTIALLY_HARMFUL_APPLICATION", "UNWANTED_SOFTWARE", "THREAT_TYPE_UNSPECIFIED"]
50
34
  }
51
35
  };
52
- const result = (await axios.post(`${endPoint}?key=${key}`, postData, {
53
- headers: {
54
- referer: "http://localhost:3000"
55
- }
56
- })).data;
57
- return result.matches?.map((match) => ({
58
- ...match,
59
- schema: GoogleSafeBrowsingMatchSchema
60
- })) ?? [];
61
- }, "checkUrlSafety");
36
+ const result = (await axios.post(`${endPoint}?key=${key}`, postData, { headers: { referer: "http://localhost:3000" } })).data;
37
+ return result.matches?.map((match) => ({ ...match, schema: GoogleSafeBrowsingMatchSchema })) ?? [];
38
+ };
62
39
  var UrlSafetyWitness = class extends AbstractWitness {
63
- static {
64
- __name(this, "UrlSafetyWitness");
65
- }
66
- static configSchemas = [
67
- ...super.configSchemas,
68
- UrlSafetyWitnessConfigSchema
69
- ];
40
+ static configSchemas = [...super.configSchemas, UrlSafetyWitnessConfigSchema];
70
41
  static defaultConfigSchema = UrlSafetyWitnessConfigSchema;
71
42
  get key() {
72
43
  return this.params.google?.safeBrowsing?.key;
@@ -78,22 +49,20 @@ var UrlSafetyWitness = class extends AbstractWitness {
78
49
  const urls = this.urls ?? payloads.filter((p) => p.schema === UrlSchema).map((p) => {
79
50
  return p.url;
80
51
  });
81
- const matches = await checkUrlSafety(urls, {
82
- key: this.key
83
- });
52
+ const matches = await checkUrlSafety(urls, { key: this.key });
84
53
  return urls.map((url) => {
85
- const payload = matches.reduce((prev, match) => {
86
- if (match.threat.url === url) {
87
- prev.threatTypes = prev.threatTypes ?? [];
88
- if (!prev.threatTypes.includes(match.threatEntryType)) {
89
- prev.threatTypes.push(match.threatEntryType);
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
+ }
90
61
  }
91
- }
92
- return prev;
93
- }, {
94
- schema: UrlSafetySchema2,
95
- url
96
- });
62
+ return prev;
63
+ },
64
+ { schema: UrlSafetySchema2, url }
65
+ );
97
66
  payload.threatTypes = payload.threatTypes?.sort();
98
67
  return payload;
99
68
  });
@@ -101,17 +70,15 @@ var UrlSafetyWitness = class extends AbstractWitness {
101
70
  };
102
71
 
103
72
  // src/Plugin.ts
104
- var UrlSafetyPlugin = /* @__PURE__ */ __name(() => createPayloadSetWitnessPlugin({
105
- required: {
106
- [UrlSafetySchema3]: 1
107
- },
108
- schema: PayloadSetSchema
109
- }, {
110
- witness: /* @__PURE__ */ __name(async (params) => {
111
- const result = await UrlSafetyWitness.create(params);
112
- return result;
113
- }, "witness")
114
- }), "UrlSafetyPlugin");
73
+ var UrlSafetyPlugin = () => createPayloadSetWitnessPlugin(
74
+ { required: { [UrlSafetySchema3]: 1 }, schema: PayloadSetSchema },
75
+ {
76
+ witness: async (params) => {
77
+ const result = await UrlSafetyWitness.create(params);
78
+ return result;
79
+ }
80
+ }
81
+ );
115
82
  export {
116
83
  GoogleSafeBrowsingMatchSchema,
117
84
  UrlSafetyPlugin,
@@ -1 +1 @@
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/index.ts'\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-model'\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 '@xylabs/axios'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport { Payload, Schema } 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'\n\nimport { UrlSafetyWitnessConfigSchema } from './Config.ts'\nimport { UrlSafetyWitnessParams } from './Params.ts'\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 const result = (await axios.post<GoogleSafeBrowsingResult>(`${endPoint}?key=${key}`, postData, { headers: { referer: 'http://localhost:3000' } }))\n .data\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 readonly configSchemas: Schema[] = [...super.configSchemas, UrlSafetyWitnessConfigSchema]\n static override readonly defaultConfigSchema: Schema = 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 // eslint-disable-next-line unicorn/no-array-reduce\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,SAASA,wBAAwB;AACjC,SAASC,qCAAqC;AAC9C,SAASC,mBAAAA,wBAAuB;;;ACFhC,SAASC,uBAAuB;AAGzB,IAAMC,+BAA+B,GAAGD,eAAAA;;;ACH/C,SAASE,iBAAiB;AAC1B,SAASC,uBAAuB;AAEhC,SAAqBC,iBAAiB;AACtC,SAA2BC,mBAAAA,wBAA4C;AAMhE,IAAMC,gCAA+D;AAkB5E,IAAMC,iBAAiB,8BACrBC,MACAC,WAAAA;AAKA,QAAMC,QAAQ,IAAIC,UAAAA;AAClB,QAAMC,WAAWH,QAAQG,YAAY;AACrC,QAAMC,MAAMJ,QAAQI;AACpB,QAAMC,cAAcN,KAAKO,IAAIC,CAAAA,QAAOA,IAAIC,QAAQ,WAAW,8BAAA,CAAA;AAC3D,MAAIH,YAAYI,WAAW,GAAG;AAC5B,WAAO,CAAA;EACT;AACA,QAAMC,WAAW;IACfC,QAAQ;MACNC,UAAU;MACVC,eAAe;IACjB;IACAC,YAAY;MACVC,eAAe;QAAC;QAAW;QAAS;;MACpCC,eAAeX,YAAYC,IAAIC,CAAAA,SAAQ;QAAEA;MAAI,EAAA;MAC7CU,kBAAkB;QAAC;;MACnBC,aAAa;QAAC;QAAsB;QAAmC;QAAqB;;IAC9F;EACF;AACA,QAAMC,UAAU,MAAMlB,MAAMmB,KAA+B,GAAGjB,QAAAA,QAAgBC,GAAAA,IAAOM,UAAU;IAAEW,SAAS;MAAEC,SAAS;IAAwB;EAAE,CAAA,GAC5IC;AACH,SAAOJ,OAAOK,SAASlB,IAAoCmB,CAAAA,WAAU;IAAE,GAAGA;IAAOC,QAAQ7B;EAA8B,EAAA,KAAO,CAAA;AAChI,GA7BuB;AA+BhB,IAAM8B,mBAAN,cAAgGC,gBAAAA;EA3DvG,OA2DuGA;;;EACrG,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAEvD,IAAI1B,MAAM;AACR,WAAO,KAAK4B,OAAOC,QAAQC,cAAc9B;EAC3C;EAEA,IAAIL,OAAO;AACT,WAAO,KAAKC,QAAQD;EACtB;EAEA,MAAyBoC,eAAeC,WAAyB,CAAA,GAAiC;AAChG,UAAMrC,OACF,KAAKA,QACJqC,SACAC,OAAO,CAACC,MAAuBA,EAAEZ,WAAWa,SAAAA,EAC5CjC,IAAI,CAACgC,MAAAA;AACJ,aAAOA,EAAE/B;IACX,CAAA;AAEJ,UAAMiB,UAAU,MAAM1B,eAAeC,MAAM;MAAEK,KAAK,KAAKA;IAAI,CAAA;AAE3D,WAAOL,KAAKO,IAAI,CAACC,QAAAA;AAEf,YAAMiC,UAAUhB,QAAQiB,OACtB,CAACC,MAAMjB,UAAAA;AACL,YAAIA,MAAMkB,OAAOpC,QAAQA,KAAK;AAC5BmC,eAAKxB,cAAcwB,KAAKxB,eAAe,CAAA;AACvC,cAAI,CAACwB,KAAKxB,YAAY0B,SAASnB,MAAMoB,eAAe,GAA0B;AAC5EH,iBAAKxB,YAAY4B,KAAKrB,MAAMoB,eAAe;UAC7C;QACF;AACA,eAAOH;MACT,GACA;QAAEhB,QAAQqB;QAAiBxC;MAAI,CAAA;AAEjCiC,cAAQtB,cAAcsB,QAAQtB,aAAa8B,KAAAA;AAC3C,aAAOR;IACT,CAAA;EACF;AACF;;;AF9FO,IAAMS,kBAAkB,6BAC7BC,8BACE;EAAEC,UAAU;IAAE,CAACC,gBAAAA,GAAkB;EAAE;EAAGC,QAAQC;AAAiB,GAC/D;EACEC,SAAS,8BAAOC,WAAAA;AACd,UAAMC,SAAS,MAAMC,iBAAiBC,OAAOH,MAAAA;AAC7C,WAAOC;EACT,GAHS;AAIX,CAAA,GAR2B;","names":["PayloadSetSchema","createPayloadSetWitnessPlugin","UrlSafetySchema","UrlSafetySchema","UrlSafetyWitnessConfigSchema","AxiosJson","AbstractWitness","UrlSchema","UrlSafetySchema","GoogleSafeBrowsingMatchSchema","checkUrlSafety","urls","config","axios","AxiosJson","endPoint","key","mutatedUrls","map","url","replace","length","postData","client","clientId","clientVersion","threatInfo","platformTypes","threatEntries","threatEntryTypes","threatTypes","result","post","headers","referer","data","matches","match","schema","UrlSafetyWitness","AbstractWitness","configSchemas","UrlSafetyWitnessConfigSchema","defaultConfigSchema","params","google","safeBrowsing","observeHandler","payloads","filter","p","UrlSchema","payload","reduce","prev","threat","includes","threatEntryType","push","UrlSafetySchema","sort","UrlSafetyPlugin","createPayloadSetWitnessPlugin","required","UrlSafetySchema","schema","PayloadSetSchema","witness","params","result","UrlSafetyWitness","create"]}
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/index.ts'\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-model'\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 '@xylabs/axios'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport { Payload, Schema } 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'\n\nimport { UrlSafetyWitnessConfigSchema } from './Config.ts'\nimport { UrlSafetyWitnessParams } from './Params.ts'\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 const result = (await axios.post<GoogleSafeBrowsingResult>(`${endPoint}?key=${key}`, postData, { headers: { referer: 'http://localhost:3000' } }))\n .data\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 readonly configSchemas: Schema[] = [...super.configSchemas, UrlSafetyWitnessConfigSchema]\n static override readonly defaultConfigSchema: Schema = 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 // eslint-disable-next-line unicorn/no-array-reduce\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;AAC1B,SAAS,uBAAuB;AAEhC,SAAqB,iBAAiB;AACtC,SAA2B,mBAAAC,wBAA4C;AAMhE,IAAM,gCAA+D;AAkB5E,IAAM,iBAAiB,OACrB,MACA,WAI8C;AAC9C,QAAM,QAAQ,IAAI,UAAU;AAC5B,QAAM,WAAW,QAAQ,YAAY;AACrC,QAAM,MAAM,QAAQ;AACpB,QAAM,cAAc,KAAK,IAAI,SAAO,IAAI,QAAQ,WAAW,8BAA8B,CAAC;AAC1F,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,UAAQ,EAAE,IAAI,EAAE;AAAA,MAC/C,kBAAkB,CAAC,KAAK;AAAA,MACxB,aAAa,CAAC,sBAAsB,mCAAmC,qBAAqB,yBAAyB;AAAA,IACvH;AAAA,EACF;AACA,QAAM,UAAU,MAAM,MAAM,KAA+B,GAAG,QAAQ,QAAQ,GAAG,IAAI,UAAU,EAAE,SAAS,EAAE,SAAS,wBAAwB,EAAE,CAAC,GAC7I;AACH,SAAO,OAAO,SAAS,IAAoC,YAAU,EAAE,GAAG,OAAO,QAAQ,8BAA8B,EAAE,KAAK,CAAC;AACjI;AAEO,IAAM,mBAAN,cAAgG,gBAAyB;AAAA,EAC9H,OAAyB,gBAA0B,CAAC,GAAG,MAAM,eAAe,4BAA4B;AAAA,EACxG,OAAyB,sBAA8B;AAAA,EAEvD,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,OACF,KAAK,QACJ,SACA,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;AAEvB,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,cAAc,QAAQ,aAAa,KAAK;AAChD,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"]}
@@ -1,8 +1,8 @@
1
1
  import { UrlSafetyWitness } from './Witness/index.ts';
2
- export declare const UrlSafetyPlugin: () => import("@xyo-network/payloadset-plugin").PayloadSetWitnessPlugin<UrlSafetyWitness<import("@xylabs/object").BaseParamsFields & {
3
- account?: import("@xyo-network/account-model").AccountInstance | "random";
2
+ export declare const UrlSafetyPlugin: () => import("@xyo-network/payloadset-plugin").PayloadSetWitnessPlugin<UrlSafetyWitness<import(".store/@xylabs-object-npm-3.6.12-443b813787/package").BaseParamsFields & {
3
+ account?: import(".store/@xyo-network-account-model-virtual-c593258ccf/package").AccountInstance | "random";
4
4
  addToResolvers?: boolean;
5
- additionalSigners?: import("@xyo-network/account-model").AccountInstance[];
5
+ additionalSigners?: import(".store/@xyo-network-account-model-virtual-c593258ccf/package").AccountInstance[];
6
6
  allowNameResolution?: boolean;
7
7
  config: import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
8
8
  schema: "network.xyo.url.safety.witness.config";
@@ -1,8 +1,8 @@
1
1
  import { UrlSafetyWitness } from './Witness/index.ts';
2
- export declare const UrlSafetyPlugin: () => import("@xyo-network/payloadset-plugin").PayloadSetWitnessPlugin<UrlSafetyWitness<import("@xylabs/object").BaseParamsFields & {
3
- account?: import("@xyo-network/account-model").AccountInstance | "random";
2
+ export declare const UrlSafetyPlugin: () => import("@xyo-network/payloadset-plugin").PayloadSetWitnessPlugin<UrlSafetyWitness<import(".store/@xylabs-object-npm-3.6.12-443b813787/package").BaseParamsFields & {
3
+ account?: import(".store/@xyo-network-account-model-virtual-c593258ccf/package").AccountInstance | "random";
4
4
  addToResolvers?: boolean;
5
- additionalSigners?: import("@xyo-network/account-model").AccountInstance[];
5
+ additionalSigners?: import(".store/@xyo-network-account-model-virtual-c593258ccf/package").AccountInstance[];
6
6
  allowNameResolution?: boolean;
7
7
  config: import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
8
8
  schema: "network.xyo.url.safety.witness.config";
@@ -1,8 +1,8 @@
1
1
  import { UrlSafetyWitness } from './Witness/index.ts';
2
- export declare const UrlSafetyPlugin: () => import("@xyo-network/payloadset-plugin").PayloadSetWitnessPlugin<UrlSafetyWitness<import("@xylabs/object").BaseParamsFields & {
3
- account?: import("@xyo-network/account-model").AccountInstance | "random";
2
+ export declare const UrlSafetyPlugin: () => import("@xyo-network/payloadset-plugin").PayloadSetWitnessPlugin<UrlSafetyWitness<import(".store/@xylabs-object-npm-3.6.12-443b813787/package").BaseParamsFields & {
3
+ account?: import(".store/@xyo-network-account-model-virtual-c593258ccf/package").AccountInstance | "random";
4
4
  addToResolvers?: boolean;
5
- additionalSigners?: import("@xyo-network/account-model").AccountInstance[];
5
+ additionalSigners?: import(".store/@xyo-network-account-model-virtual-c593258ccf/package").AccountInstance[];
6
6
  allowNameResolution?: boolean;
7
7
  config: import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
8
8
  schema: "network.xyo.url.safety.witness.config";
@@ -2,11 +2,7 @@
2
2
  var __defProp = Object.defineProperty;
3
3
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
4
  var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __getProtoOf = Object.getPrototypeOf;
6
5
  var __hasOwnProp = Object.prototype.hasOwnProperty;
7
- var __reflectGet = Reflect.get;
8
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
9
- var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
10
6
  var __export = (target, all) => {
11
7
  for (var name in all)
12
8
  __defProp(target, name, { get: all[name], enumerable: true });
@@ -20,8 +16,6 @@ var __copyProps = (to, from, except, desc) => {
20
16
  return to;
21
17
  };
22
18
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
23
- var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
24
- var __superGet = (cls, obj, key) => __reflectGet(__getProtoOf(cls), key, obj);
25
19
 
26
20
  // src/index.ts
27
21
  var src_exports = {};
@@ -49,7 +43,7 @@ var import_abstract_witness = require("@xyo-network/abstract-witness");
49
43
  var import_url_payload_plugin = require("@xyo-network/url-payload-plugin");
50
44
  var import_url_safety_payload_plugin2 = require("@xyo-network/url-safety-payload-plugin");
51
45
  var GoogleSafeBrowsingMatchSchema = "com.google.safebrowsing.match";
52
- var checkUrlSafety = /* @__PURE__ */ __name(async (urls, config) => {
46
+ var checkUrlSafety = async (urls, config) => {
53
47
  var _a;
54
48
  const axios = new import_axios.AxiosJson();
55
49
  const endPoint = (config == null ? void 0 : config.endPoint) ?? "https://safebrowsing.googleapis.com/v4/threatMatches:find";
@@ -64,36 +58,18 @@ var checkUrlSafety = /* @__PURE__ */ __name(async (urls, config) => {
64
58
  clientVersion: "1.0"
65
59
  },
66
60
  threatInfo: {
67
- platformTypes: [
68
- "WINDOWS",
69
- "LINUX",
70
- "OSX"
71
- ],
72
- threatEntries: mutatedUrls.map((url) => ({
73
- url
74
- })),
75
- threatEntryTypes: [
76
- "URL"
77
- ],
78
- threatTypes: [
79
- "SOCIAL_ENGINEERING",
80
- "POTENTIALLY_HARMFUL_APPLICATION",
81
- "UNWANTED_SOFTWARE",
82
- "THREAT_TYPE_UNSPECIFIED"
83
- ]
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"]
84
65
  }
85
66
  };
86
- const result = (await axios.post(`${endPoint}?key=${key}`, postData, {
87
- headers: {
88
- referer: "http://localhost:3000"
89
- }
90
- })).data;
91
- return ((_a = result.matches) == null ? void 0 : _a.map((match) => ({
92
- ...match,
93
- schema: GoogleSafeBrowsingMatchSchema
94
- }))) ?? [];
95
- }, "checkUrlSafety");
96
- var _UrlSafetyWitness = class _UrlSafetyWitness extends import_abstract_witness.AbstractWitness {
67
+ const result = (await axios.post(`${endPoint}?key=${key}`, postData, { headers: { referer: "http://localhost:3000" } })).data;
68
+ return ((_a = result.matches) == null ? void 0 : _a.map((match) => ({ ...match, schema: GoogleSafeBrowsingMatchSchema }))) ?? [];
69
+ };
70
+ var UrlSafetyWitness = class extends import_abstract_witness.AbstractWitness {
71
+ static configSchemas = [...super.configSchemas, UrlSafetyWitnessConfigSchema];
72
+ static defaultConfigSchema = UrlSafetyWitnessConfigSchema;
97
73
  get key() {
98
74
  var _a, _b;
99
75
  return (_b = (_a = this.params.google) == null ? void 0 : _a.safeBrowsing) == null ? void 0 : _b.key;
@@ -106,48 +82,37 @@ var _UrlSafetyWitness = class _UrlSafetyWitness extends import_abstract_witness.
106
82
  const urls = this.urls ?? payloads.filter((p) => p.schema === import_url_payload_plugin.UrlSchema).map((p) => {
107
83
  return p.url;
108
84
  });
109
- const matches = await checkUrlSafety(urls, {
110
- key: this.key
111
- });
85
+ const matches = await checkUrlSafety(urls, { key: this.key });
112
86
  return urls.map((url) => {
113
87
  var _a;
114
- const payload = matches.reduce((prev, match) => {
115
- if (match.threat.url === url) {
116
- prev.threatTypes = prev.threatTypes ?? [];
117
- if (!prev.threatTypes.includes(match.threatEntryType)) {
118
- prev.threatTypes.push(match.threatEntryType);
88
+ const payload = matches.reduce(
89
+ (prev, match) => {
90
+ if (match.threat.url === url) {
91
+ prev.threatTypes = prev.threatTypes ?? [];
92
+ if (!prev.threatTypes.includes(match.threatEntryType)) {
93
+ prev.threatTypes.push(match.threatEntryType);
94
+ }
119
95
  }
120
- }
121
- return prev;
122
- }, {
123
- schema: import_url_safety_payload_plugin2.UrlSafetySchema,
124
- url
125
- });
96
+ return prev;
97
+ },
98
+ { schema: import_url_safety_payload_plugin2.UrlSafetySchema, url }
99
+ );
126
100
  payload.threatTypes = (_a = payload.threatTypes) == null ? void 0 : _a.sort();
127
101
  return payload;
128
102
  });
129
103
  }
130
104
  };
131
- __name(_UrlSafetyWitness, "UrlSafetyWitness");
132
- __publicField(_UrlSafetyWitness, "configSchemas", [
133
- ...__superGet(_UrlSafetyWitness, _UrlSafetyWitness, "configSchemas"),
134
- UrlSafetyWitnessConfigSchema
135
- ]);
136
- __publicField(_UrlSafetyWitness, "defaultConfigSchema", UrlSafetyWitnessConfigSchema);
137
- var UrlSafetyWitness = _UrlSafetyWitness;
138
105
 
139
106
  // src/Plugin.ts
140
- var UrlSafetyPlugin = /* @__PURE__ */ __name(() => (0, import_payloadset_plugin.createPayloadSetWitnessPlugin)({
141
- required: {
142
- [import_url_safety_payload_plugin3.UrlSafetySchema]: 1
143
- },
144
- schema: import_payload_model.PayloadSetSchema
145
- }, {
146
- witness: /* @__PURE__ */ __name(async (params) => {
147
- const result = await UrlSafetyWitness.create(params);
148
- return result;
149
- }, "witness")
150
- }), "UrlSafetyPlugin");
107
+ var UrlSafetyPlugin = () => (0, import_payloadset_plugin.createPayloadSetWitnessPlugin)(
108
+ { required: { [import_url_safety_payload_plugin3.UrlSafetySchema]: 1 }, schema: import_payload_model.PayloadSetSchema },
109
+ {
110
+ witness: async (params) => {
111
+ const result = await UrlSafetyWitness.create(params);
112
+ return result;
113
+ }
114
+ }
115
+ );
151
116
  // Annotate the CommonJS export names for ESM import in node:
152
117
  0 && (module.exports = {
153
118
  GoogleSafeBrowsingMatchSchema,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/Plugin.ts","../../src/Witness/Config.ts","../../src/Witness/Witness.ts"],"sourcesContent":["// eslint-disable-next-line import/no-default-export\nexport { UrlSafetyPlugin as default, UrlSafetyPlugin } from './Plugin.ts'\nexport * from './Witness/index.ts'\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/index.ts'\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-model'\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 '@xylabs/axios'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport { Payload, Schema } 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'\n\nimport { UrlSafetyWitnessConfigSchema } from './Config.ts'\nimport { UrlSafetyWitnessParams } from './Params.ts'\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 const result = (await axios.post<GoogleSafeBrowsingResult>(`${endPoint}?key=${key}`, postData, { headers: { referer: 'http://localhost:3000' } }))\n .data\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 readonly configSchemas: Schema[] = [...super.configSchemas, UrlSafetyWitnessConfigSchema]\n static override readonly defaultConfigSchema: Schema = 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 // eslint-disable-next-line unicorn/no-array-reduce\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;;;;;;;;;;;ACAA,2BAAiC;AACjC,+BAA8C;AAC9C,IAAAA,oCAAgC;;;ACFhC,uCAAgC;AAGzB,IAAMC,+BAA+B,GAAGC,gDAAAA;;;ACH/C,mBAA0B;AAC1B,8BAAgC;AAEhC,gCAAsC;AACtC,IAAAC,oCAAuE;AAMhE,IAAMC,gCAA+D;AAkB5E,IAAMC,iBAAiB,8BACrBC,MACAC,WAAAA;AA9BF;AAmCE,QAAMC,QAAQ,IAAIC,uBAAAA;AAClB,QAAMC,YAAWH,iCAAQG,aAAY;AACrC,QAAMC,MAAMJ,iCAAQI;AACpB,QAAMC,cAAcN,KAAKO,IAAIC,CAAAA,QAAOA,IAAIC,QAAQ,WAAW,8BAAA,CAAA;AAC3D,MAAIH,YAAYI,WAAW,GAAG;AAC5B,WAAO,CAAA;EACT;AACA,QAAMC,WAAW;IACfC,QAAQ;MACNC,UAAU;MACVC,eAAe;IACjB;IACAC,YAAY;MACVC,eAAe;QAAC;QAAW;QAAS;;MACpCC,eAAeX,YAAYC,IAAIC,CAAAA,SAAQ;QAAEA;MAAI,EAAA;MAC7CU,kBAAkB;QAAC;;MACnBC,aAAa;QAAC;QAAsB;QAAmC;QAAqB;;IAC9F;EACF;AACA,QAAMC,UAAU,MAAMlB,MAAMmB,KAA+B,GAAGjB,QAAAA,QAAgBC,GAAAA,IAAOM,UAAU;IAAEW,SAAS;MAAEC,SAAS;IAAwB;EAAE,CAAA,GAC5IC;AACH,WAAOJ,YAAOK,YAAPL,mBAAgBb,IAAoCmB,CAAAA,WAAU;IAAE,GAAGA;IAAOC,QAAQ7B;EAA8B,QAAO,CAAA;AAChI,GA7BuB;AA+BhB,IAAM8B,oBAAN,MAAMA,0BAA0FC,wCAAAA;EAIrG,IAAIxB,MAAM;AA/DZ;AAgEI,YAAO,gBAAKyB,OAAOC,WAAZ,mBAAoBC,iBAApB,mBAAkC3B;EAC3C;EAEA,IAAIL,OAAO;AAnEb;AAoEI,YAAO,UAAKC,WAAL,mBAAaD;EACtB;EAEA,MAAyBiC,eAAeC,WAAyB,CAAA,GAAiC;AAChG,UAAMlC,OACF,KAAKA,QACJkC,SACAC,OAAO,CAACC,MAAuBA,EAAET,WAAWU,mCAAAA,EAC5C9B,IAAI,CAAC6B,MAAAA;AACJ,aAAOA,EAAE5B;IACX,CAAA;AAEJ,UAAMiB,UAAU,MAAM1B,eAAeC,MAAM;MAAEK,KAAK,KAAKA;IAAI,CAAA;AAE3D,WAAOL,KAAKO,IAAI,CAACC,QAAAA;AAlFrB;AAoFM,YAAM8B,UAAUb,QAAQc,OACtB,CAACC,MAAMd,UAAAA;AACL,YAAIA,MAAMe,OAAOjC,QAAQA,KAAK;AAC5BgC,eAAKrB,cAAcqB,KAAKrB,eAAe,CAAA;AACvC,cAAI,CAACqB,KAAKrB,YAAYuB,SAAShB,MAAMiB,eAAe,GAA0B;AAC5EH,iBAAKrB,YAAYyB,KAAKlB,MAAMiB,eAAe;UAC7C;QACF;AACA,eAAOH;MACT,GACA;QAAEb,QAAQkB;QAAiBrC;MAAI,CAAA;AAEjC8B,cAAQnB,eAAcmB,aAAQnB,gBAARmB,mBAAqBQ;AAC3C,aAAOR;IACT,CAAA;EACF;AACF;AAzCuGT;AACrG,cADWD,mBACcmB,iBAA0B;KAAI,iDAAMA;EAAeC;;AAC5E,cAFWpB,mBAEcqB,uBAA8BD;AAFlD,IAAMpB,mBAAN;;;AFrDA,IAAMsB,kBAAkB,iCAC7BC,wDACE;EAAEC,UAAU;IAAE,CAACC,iDAAAA,GAAkB;EAAE;EAAGC,QAAQC;AAAiB,GAC/D;EACEC,SAAS,8BAAOC,WAAAA;AACd,UAAMC,SAAS,MAAMC,iBAAiBC,OAAOH,MAAAA;AAC7C,WAAOC;EACT,GAHS;AAIX,CAAA,GAR2B;","names":["import_url_safety_payload_plugin","UrlSafetyWitnessConfigSchema","UrlSafetySchema","import_url_safety_payload_plugin","GoogleSafeBrowsingMatchSchema","checkUrlSafety","urls","config","axios","AxiosJson","endPoint","key","mutatedUrls","map","url","replace","length","postData","client","clientId","clientVersion","threatInfo","platformTypes","threatEntries","threatEntryTypes","threatTypes","result","post","headers","referer","data","matches","match","schema","UrlSafetyWitness","AbstractWitness","params","google","safeBrowsing","observeHandler","payloads","filter","p","UrlSchema","payload","reduce","prev","threat","includes","threatEntryType","push","UrlSafetySchema","sort","configSchemas","UrlSafetyWitnessConfigSchema","defaultConfigSchema","UrlSafetyPlugin","createPayloadSetWitnessPlugin","required","UrlSafetySchema","schema","PayloadSetSchema","witness","params","result","UrlSafetyWitness","create"]}
1
+ {"version":3,"sources":["../../src/index.ts","../../src/Plugin.ts","../../src/Witness/Config.ts","../../src/Witness/Witness.ts"],"sourcesContent":["// eslint-disable-next-line import/no-default-export\nexport { UrlSafetyPlugin as default, UrlSafetyPlugin } from './Plugin.ts'\nexport * from './Witness/index.ts'\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/index.ts'\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-model'\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 '@xylabs/axios'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport { Payload, Schema } 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'\n\nimport { UrlSafetyWitnessConfigSchema } from './Config.ts'\nimport { UrlSafetyWitnessParams } from './Params.ts'\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 const result = (await axios.post<GoogleSafeBrowsingResult>(`${endPoint}?key=${key}`, postData, { headers: { referer: 'http://localhost:3000' } }))\n .data\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 readonly configSchemas: Schema[] = [...super.configSchemas, UrlSafetyWitnessConfigSchema]\n static override readonly defaultConfigSchema: Schema = 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 // eslint-disable-next-line unicorn/no-array-reduce\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;AAAA;AAAA;;;ACAA,2BAAiC;AACjC,+BAA8C;AAC9C,IAAAA,oCAAgC;;;ACFhC,uCAAgC;AAGzB,IAAM,+BAA+B,GAAG,gDAAe;;;ACH9D,mBAA0B;AAC1B,8BAAgC;AAEhC,gCAAsC;AACtC,IAAAC,oCAAuE;AAMhE,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,SAAO,IAAI,QAAQ,WAAW,8BAA8B,CAAC;AAC1F,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,UAAQ,EAAE,IAAI,EAAE;AAAA,MAC/C,kBAAkB,CAAC,KAAK;AAAA,MACxB,aAAa,CAAC,sBAAsB,mCAAmC,qBAAqB,yBAAyB;AAAA,IACvH;AAAA,EACF;AACA,QAAM,UAAU,MAAM,MAAM,KAA+B,GAAG,QAAQ,QAAQ,GAAG,IAAI,UAAU,EAAE,SAAS,EAAE,SAAS,wBAAwB,EAAE,CAAC,GAC7I;AACH,WAAO,YAAO,YAAP,mBAAgB,IAAoC,YAAU,EAAE,GAAG,OAAO,QAAQ,8BAA8B,QAAO,CAAC;AACjI;AAEO,IAAM,mBAAN,cAAgG,wCAAyB;AAAA,EAC9H,OAAyB,gBAA0B,CAAC,GAAG,MAAM,eAAe,4BAA4B;AAAA,EACxG,OAAyB,sBAA8B;AAAA,EAEvD,IAAI,MAAM;AA/DZ;AAgEI,YAAO,gBAAK,OAAO,WAAZ,mBAAoB,iBAApB,mBAAkC;AAAA,EAC3C;AAAA,EAEA,IAAI,OAAO;AAnEb;AAoEI,YAAO,UAAK,WAAL,mBAAa;AAAA,EACtB;AAAA,EAEA,MAAyB,eAAe,WAAyB,CAAC,GAAgC;AAChG,UAAM,OACF,KAAK,QACJ,SACA,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;AAlF7B;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,11 +1,3 @@
1
- var __defProp = Object.defineProperty;
2
- var __getProtoOf = Object.getPrototypeOf;
3
- var __reflectGet = Reflect.get;
4
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
5
- var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
6
- var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
7
- var __superGet = (cls, obj, key) => __reflectGet(__getProtoOf(cls), key, obj);
8
-
9
1
  // src/Plugin.ts
10
2
  import { PayloadSetSchema } from "@xyo-network/payload-model";
11
3
  import { createPayloadSetWitnessPlugin } from "@xyo-network/payloadset-plugin";
@@ -21,7 +13,7 @@ import { AbstractWitness } from "@xyo-network/abstract-witness";
21
13
  import { UrlSchema } from "@xyo-network/url-payload-plugin";
22
14
  import { UrlSafetySchema as UrlSafetySchema2 } from "@xyo-network/url-safety-payload-plugin";
23
15
  var GoogleSafeBrowsingMatchSchema = "com.google.safebrowsing.match";
24
- var checkUrlSafety = /* @__PURE__ */ __name(async (urls, config) => {
16
+ var checkUrlSafety = async (urls, config) => {
25
17
  var _a;
26
18
  const axios = new AxiosJson();
27
19
  const endPoint = (config == null ? void 0 : config.endPoint) ?? "https://safebrowsing.googleapis.com/v4/threatMatches:find";
@@ -36,36 +28,18 @@ var checkUrlSafety = /* @__PURE__ */ __name(async (urls, config) => {
36
28
  clientVersion: "1.0"
37
29
  },
38
30
  threatInfo: {
39
- platformTypes: [
40
- "WINDOWS",
41
- "LINUX",
42
- "OSX"
43
- ],
44
- threatEntries: mutatedUrls.map((url) => ({
45
- url
46
- })),
47
- threatEntryTypes: [
48
- "URL"
49
- ],
50
- threatTypes: [
51
- "SOCIAL_ENGINEERING",
52
- "POTENTIALLY_HARMFUL_APPLICATION",
53
- "UNWANTED_SOFTWARE",
54
- "THREAT_TYPE_UNSPECIFIED"
55
- ]
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"]
56
35
  }
57
36
  };
58
- const result = (await axios.post(`${endPoint}?key=${key}`, postData, {
59
- headers: {
60
- referer: "http://localhost:3000"
61
- }
62
- })).data;
63
- return ((_a = result.matches) == null ? void 0 : _a.map((match) => ({
64
- ...match,
65
- schema: GoogleSafeBrowsingMatchSchema
66
- }))) ?? [];
67
- }, "checkUrlSafety");
68
- var _UrlSafetyWitness = class _UrlSafetyWitness extends AbstractWitness {
37
+ const result = (await axios.post(`${endPoint}?key=${key}`, postData, { headers: { referer: "http://localhost:3000" } })).data;
38
+ return ((_a = result.matches) == null ? void 0 : _a.map((match) => ({ ...match, schema: GoogleSafeBrowsingMatchSchema }))) ?? [];
39
+ };
40
+ var UrlSafetyWitness = class extends AbstractWitness {
41
+ static configSchemas = [...super.configSchemas, UrlSafetyWitnessConfigSchema];
42
+ static defaultConfigSchema = UrlSafetyWitnessConfigSchema;
69
43
  get key() {
70
44
  var _a, _b;
71
45
  return (_b = (_a = this.params.google) == null ? void 0 : _a.safeBrowsing) == null ? void 0 : _b.key;
@@ -78,48 +52,37 @@ var _UrlSafetyWitness = class _UrlSafetyWitness extends AbstractWitness {
78
52
  const urls = this.urls ?? payloads.filter((p) => p.schema === UrlSchema).map((p) => {
79
53
  return p.url;
80
54
  });
81
- const matches = await checkUrlSafety(urls, {
82
- key: this.key
83
- });
55
+ const matches = await checkUrlSafety(urls, { key: this.key });
84
56
  return urls.map((url) => {
85
57
  var _a;
86
- const payload = matches.reduce((prev, match) => {
87
- if (match.threat.url === url) {
88
- prev.threatTypes = prev.threatTypes ?? [];
89
- if (!prev.threatTypes.includes(match.threatEntryType)) {
90
- prev.threatTypes.push(match.threatEntryType);
58
+ const payload = matches.reduce(
59
+ (prev, match) => {
60
+ if (match.threat.url === url) {
61
+ prev.threatTypes = prev.threatTypes ?? [];
62
+ if (!prev.threatTypes.includes(match.threatEntryType)) {
63
+ prev.threatTypes.push(match.threatEntryType);
64
+ }
91
65
  }
92
- }
93
- return prev;
94
- }, {
95
- schema: UrlSafetySchema2,
96
- url
97
- });
66
+ return prev;
67
+ },
68
+ { schema: UrlSafetySchema2, url }
69
+ );
98
70
  payload.threatTypes = (_a = payload.threatTypes) == null ? void 0 : _a.sort();
99
71
  return payload;
100
72
  });
101
73
  }
102
74
  };
103
- __name(_UrlSafetyWitness, "UrlSafetyWitness");
104
- __publicField(_UrlSafetyWitness, "configSchemas", [
105
- ...__superGet(_UrlSafetyWitness, _UrlSafetyWitness, "configSchemas"),
106
- UrlSafetyWitnessConfigSchema
107
- ]);
108
- __publicField(_UrlSafetyWitness, "defaultConfigSchema", UrlSafetyWitnessConfigSchema);
109
- var UrlSafetyWitness = _UrlSafetyWitness;
110
75
 
111
76
  // src/Plugin.ts
112
- var UrlSafetyPlugin = /* @__PURE__ */ __name(() => createPayloadSetWitnessPlugin({
113
- required: {
114
- [UrlSafetySchema3]: 1
115
- },
116
- schema: PayloadSetSchema
117
- }, {
118
- witness: /* @__PURE__ */ __name(async (params) => {
119
- const result = await UrlSafetyWitness.create(params);
120
- return result;
121
- }, "witness")
122
- }), "UrlSafetyPlugin");
77
+ var UrlSafetyPlugin = () => createPayloadSetWitnessPlugin(
78
+ { required: { [UrlSafetySchema3]: 1 }, schema: PayloadSetSchema },
79
+ {
80
+ witness: async (params) => {
81
+ const result = await UrlSafetyWitness.create(params);
82
+ return result;
83
+ }
84
+ }
85
+ );
123
86
  export {
124
87
  GoogleSafeBrowsingMatchSchema,
125
88
  UrlSafetyPlugin,