@xyo-network/url-safety-plugin 2.99.4 → 2.99.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/browser/Plugin.d.cts +2 -2
- package/dist/browser/Plugin.d.mts +2 -2
- package/dist/browser/Plugin.d.ts +2 -2
- package/dist/browser/Witness/Params.d.cts +1 -1
- package/dist/browser/Witness/Params.d.mts +1 -1
- package/dist/browser/Witness/Params.d.ts +1 -1
- package/dist/browser/Witness/Witness.d.cts +1 -1
- package/dist/browser/Witness/Witness.d.mts +1 -1
- package/dist/browser/Witness/Witness.d.ts +1 -1
- package/dist/browser/Witness/index.d.cts +3 -3
- package/dist/browser/Witness/index.d.mts +3 -3
- package/dist/browser/Witness/index.d.ts +3 -3
- package/dist/browser/index.cjs +61 -30
- package/dist/browser/index.cjs.map +1 -1
- package/dist/browser/index.d.cts +2 -2
- package/dist/browser/index.d.mts +2 -2
- package/dist/browser/index.d.ts +2 -2
- package/dist/browser/{index.js → index.mjs} +64 -31
- package/dist/browser/index.mjs.map +1 -0
- package/dist/neutral/Plugin.d.cts +2 -2
- package/dist/neutral/Plugin.d.mts +2 -2
- package/dist/neutral/Plugin.d.ts +2 -2
- package/dist/neutral/Witness/Params.d.cts +1 -1
- package/dist/neutral/Witness/Params.d.mts +1 -1
- package/dist/neutral/Witness/Params.d.ts +1 -1
- package/dist/neutral/Witness/Witness.d.cts +1 -1
- package/dist/neutral/Witness/Witness.d.mts +1 -1
- package/dist/neutral/Witness/Witness.d.ts +1 -1
- package/dist/neutral/Witness/index.d.cts +3 -3
- package/dist/neutral/Witness/index.d.mts +3 -3
- package/dist/neutral/Witness/index.d.ts +3 -3
- package/dist/neutral/index.cjs +61 -30
- package/dist/neutral/index.cjs.map +1 -1
- package/dist/neutral/index.d.cts +2 -2
- package/dist/neutral/index.d.mts +2 -2
- package/dist/neutral/index.d.ts +2 -2
- package/dist/neutral/{index.js → index.mjs} +64 -31
- package/dist/neutral/index.mjs.map +1 -0
- package/dist/node/Plugin.d.cts +2 -2
- package/dist/node/Plugin.d.mts +2 -2
- package/dist/node/Plugin.d.ts +2 -2
- package/dist/node/Witness/Params.d.cts +1 -1
- package/dist/node/Witness/Params.d.mts +1 -1
- package/dist/node/Witness/Params.d.ts +1 -1
- package/dist/node/Witness/Witness.d.cts +1 -1
- package/dist/node/Witness/Witness.d.mts +1 -1
- package/dist/node/Witness/Witness.d.ts +1 -1
- package/dist/node/Witness/index.d.cts +3 -3
- package/dist/node/Witness/index.d.mts +3 -3
- package/dist/node/Witness/index.d.ts +3 -3
- package/dist/node/index.cjs +67 -32
- package/dist/node/index.cjs.map +1 -1
- package/dist/node/index.d.cts +2 -2
- package/dist/node/index.d.mts +2 -2
- package/dist/node/index.d.ts +2 -2
- package/dist/node/index.mjs +130 -0
- package/dist/node/index.mjs.map +1 -0
- package/package.json +16 -16
- package/src/Plugin.ts +1 -1
- package/src/Witness/Params.ts +1 -1
- package/src/Witness/Witness.ts +8 -8
- package/src/Witness/index.ts +3 -3
- package/src/index.ts +2 -2
- package/dist/browser/index.js.map +0 -1
- package/dist/neutral/index.js.map +0 -1
- package/dist/node/index.js +0 -93
- package/dist/node/index.js.map +0 -1
package/dist/node/index.cjs
CHANGED
|
@@ -2,7 +2,11 @@
|
|
|
2
2
|
var __defProp = Object.defineProperty;
|
|
3
3
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
4
|
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
5
6
|
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 });
|
|
6
10
|
var __export = (target, all) => {
|
|
7
11
|
for (var name in all)
|
|
8
12
|
__defProp(target, name, { get: all[name], enumerable: true });
|
|
@@ -16,6 +20,8 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
16
20
|
return to;
|
|
17
21
|
};
|
|
18
22
|
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);
|
|
19
25
|
|
|
20
26
|
// src/index.ts
|
|
21
27
|
var src_exports = {};
|
|
@@ -43,7 +49,7 @@ var import_abstract_witness = require("@xyo-network/abstract-witness");
|
|
|
43
49
|
var import_url_payload_plugin = require("@xyo-network/url-payload-plugin");
|
|
44
50
|
var import_url_safety_payload_plugin2 = require("@xyo-network/url-safety-payload-plugin");
|
|
45
51
|
var GoogleSafeBrowsingMatchSchema = "com.google.safebrowsing.match";
|
|
46
|
-
var checkUrlSafety = async (urls, config) => {
|
|
52
|
+
var checkUrlSafety = /* @__PURE__ */ __name(async (urls, config) => {
|
|
47
53
|
var _a;
|
|
48
54
|
const axios = new import_axios.AxiosJson();
|
|
49
55
|
const endPoint = (config == null ? void 0 : config.endPoint) ?? "https://safebrowsing.googleapis.com/v4/threatMatches:find";
|
|
@@ -58,18 +64,36 @@ var checkUrlSafety = async (urls, config) => {
|
|
|
58
64
|
clientVersion: "1.0"
|
|
59
65
|
},
|
|
60
66
|
threatInfo: {
|
|
61
|
-
platformTypes: [
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
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
|
+
]
|
|
65
84
|
}
|
|
66
85
|
};
|
|
67
|
-
const result = (await axios.post(`${endPoint}?key=${key}`, postData, {
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
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 {
|
|
73
97
|
get key() {
|
|
74
98
|
var _a, _b;
|
|
75
99
|
return (_b = (_a = this.params.google) == null ? void 0 : _a.safeBrowsing) == null ? void 0 : _b.key;
|
|
@@ -82,37 +106,48 @@ var UrlSafetyWitness = class extends import_abstract_witness.AbstractWitness {
|
|
|
82
106
|
const urls = this.urls ?? payloads.filter((p) => p.schema === import_url_payload_plugin.UrlSchema).map((p) => {
|
|
83
107
|
return p.url;
|
|
84
108
|
});
|
|
85
|
-
const matches = await checkUrlSafety(urls, {
|
|
109
|
+
const matches = await checkUrlSafety(urls, {
|
|
110
|
+
key: this.key
|
|
111
|
+
});
|
|
86
112
|
return urls.map((url) => {
|
|
87
113
|
var _a;
|
|
88
|
-
const payload = matches.reduce(
|
|
89
|
-
(
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
prev.threatTypes.push(match.threatEntryType);
|
|
94
|
-
}
|
|
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);
|
|
95
119
|
}
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
120
|
+
}
|
|
121
|
+
return prev;
|
|
122
|
+
}, {
|
|
123
|
+
schema: import_url_safety_payload_plugin2.UrlSafetySchema,
|
|
124
|
+
url
|
|
125
|
+
});
|
|
100
126
|
payload.threatTypes = (_a = payload.threatTypes) == null ? void 0 : _a.sort();
|
|
101
127
|
return payload;
|
|
102
128
|
});
|
|
103
129
|
}
|
|
104
130
|
};
|
|
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;
|
|
105
138
|
|
|
106
139
|
// src/Plugin.ts
|
|
107
|
-
var UrlSafetyPlugin = () => (0, import_payloadset_plugin.createPayloadSetWitnessPlugin)(
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
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");
|
|
116
151
|
// Annotate the CommonJS export names for ESM import in node:
|
|
117
152
|
0 && (module.exports = {
|
|
118
153
|
GoogleSafeBrowsingMatchSchema,
|
package/dist/node/index.cjs.map
CHANGED
|
@@ -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.
|
|
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":"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","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"]}
|
package/dist/node/index.d.cts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export { UrlSafetyPlugin as default, UrlSafetyPlugin } from './Plugin.
|
|
2
|
-
export * from './Witness/index.
|
|
1
|
+
export { UrlSafetyPlugin as default, UrlSafetyPlugin } from './Plugin.ts';
|
|
2
|
+
export * from './Witness/index.ts';
|
|
3
3
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/node/index.d.mts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export { UrlSafetyPlugin as default, UrlSafetyPlugin } from './Plugin.
|
|
2
|
-
export * from './Witness/index.
|
|
1
|
+
export { UrlSafetyPlugin as default, UrlSafetyPlugin } from './Plugin.ts';
|
|
2
|
+
export * from './Witness/index.ts';
|
|
3
3
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/node/index.d.ts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export { UrlSafetyPlugin as default, UrlSafetyPlugin } from './Plugin.
|
|
2
|
-
export * from './Witness/index.
|
|
1
|
+
export { UrlSafetyPlugin as default, UrlSafetyPlugin } from './Plugin.ts';
|
|
2
|
+
export * from './Witness/index.ts';
|
|
3
3
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1,130 @@
|
|
|
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
|
+
// src/Plugin.ts
|
|
10
|
+
import { PayloadSetSchema } from "@xyo-network/payload-model";
|
|
11
|
+
import { createPayloadSetWitnessPlugin } from "@xyo-network/payloadset-plugin";
|
|
12
|
+
import { UrlSafetySchema as UrlSafetySchema3 } from "@xyo-network/url-safety-payload-plugin";
|
|
13
|
+
|
|
14
|
+
// src/Witness/Config.ts
|
|
15
|
+
import { UrlSafetySchema } from "@xyo-network/url-safety-payload-plugin";
|
|
16
|
+
var UrlSafetyWitnessConfigSchema = `${UrlSafetySchema}.witness.config`;
|
|
17
|
+
|
|
18
|
+
// src/Witness/Witness.ts
|
|
19
|
+
import { AxiosJson } from "@xylabs/axios";
|
|
20
|
+
import { AbstractWitness } from "@xyo-network/abstract-witness";
|
|
21
|
+
import { UrlSchema } from "@xyo-network/url-payload-plugin";
|
|
22
|
+
import { UrlSafetySchema as UrlSafetySchema2 } from "@xyo-network/url-safety-payload-plugin";
|
|
23
|
+
var GoogleSafeBrowsingMatchSchema = "com.google.safebrowsing.match";
|
|
24
|
+
var checkUrlSafety = /* @__PURE__ */ __name(async (urls, config) => {
|
|
25
|
+
var _a;
|
|
26
|
+
const axios = new AxiosJson();
|
|
27
|
+
const endPoint = (config == null ? void 0 : config.endPoint) ?? "https://safebrowsing.googleapis.com/v4/threatMatches:find";
|
|
28
|
+
const key = config == null ? void 0 : config.key;
|
|
29
|
+
const mutatedUrls = urls.map((url) => url.replace("ipfs://", "https://cloudflare-ipfs.com/"));
|
|
30
|
+
if (mutatedUrls.length === 0) {
|
|
31
|
+
return [];
|
|
32
|
+
}
|
|
33
|
+
const postData = {
|
|
34
|
+
client: {
|
|
35
|
+
clientId: "foreventory",
|
|
36
|
+
clientVersion: "1.0"
|
|
37
|
+
},
|
|
38
|
+
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
|
+
]
|
|
56
|
+
}
|
|
57
|
+
};
|
|
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 {
|
|
69
|
+
get key() {
|
|
70
|
+
var _a, _b;
|
|
71
|
+
return (_b = (_a = this.params.google) == null ? void 0 : _a.safeBrowsing) == null ? void 0 : _b.key;
|
|
72
|
+
}
|
|
73
|
+
get urls() {
|
|
74
|
+
var _a;
|
|
75
|
+
return (_a = this.config) == null ? void 0 : _a.urls;
|
|
76
|
+
}
|
|
77
|
+
async observeHandler(payloads = []) {
|
|
78
|
+
const urls = this.urls ?? payloads.filter((p) => p.schema === UrlSchema).map((p) => {
|
|
79
|
+
return p.url;
|
|
80
|
+
});
|
|
81
|
+
const matches = await checkUrlSafety(urls, {
|
|
82
|
+
key: this.key
|
|
83
|
+
});
|
|
84
|
+
return urls.map((url) => {
|
|
85
|
+
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);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
return prev;
|
|
94
|
+
}, {
|
|
95
|
+
schema: UrlSafetySchema2,
|
|
96
|
+
url
|
|
97
|
+
});
|
|
98
|
+
payload.threatTypes = (_a = payload.threatTypes) == null ? void 0 : _a.sort();
|
|
99
|
+
return payload;
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
};
|
|
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
|
+
|
|
111
|
+
// 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");
|
|
123
|
+
export {
|
|
124
|
+
GoogleSafeBrowsingMatchSchema,
|
|
125
|
+
UrlSafetyPlugin,
|
|
126
|
+
UrlSafetyWitness,
|
|
127
|
+
UrlSafetyWitnessConfigSchema,
|
|
128
|
+
UrlSafetyPlugin as default
|
|
129
|
+
};
|
|
130
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +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":"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","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","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"]}
|
package/package.json
CHANGED
|
@@ -10,21 +10,21 @@
|
|
|
10
10
|
"url": "https://github.com/XYOracleNetwork/plugins/issues"
|
|
11
11
|
},
|
|
12
12
|
"dependencies": {
|
|
13
|
-
"@xylabs/axios": "^3.6.
|
|
14
|
-
"@xyo-network/abstract-witness": "^2.
|
|
15
|
-
"@xyo-network/module-model": "^2.
|
|
16
|
-
"@xyo-network/payload-model": "^2.
|
|
17
|
-
"@xyo-network/payloadset-plugin": "^2.
|
|
18
|
-
"@xyo-network/url-payload-plugin": "^2.99.
|
|
19
|
-
"@xyo-network/url-safety-payload-plugin": "^2.99.
|
|
20
|
-
"@xyo-network/witness-model": "^2.
|
|
13
|
+
"@xylabs/axios": "^3.6.8",
|
|
14
|
+
"@xyo-network/abstract-witness": "^2.111.2",
|
|
15
|
+
"@xyo-network/module-model": "^2.111.2",
|
|
16
|
+
"@xyo-network/payload-model": "^2.111.2",
|
|
17
|
+
"@xyo-network/payloadset-plugin": "^2.111.2",
|
|
18
|
+
"@xyo-network/url-payload-plugin": "^2.99.5",
|
|
19
|
+
"@xyo-network/url-safety-payload-plugin": "^2.99.5",
|
|
20
|
+
"@xyo-network/witness-model": "^2.111.2"
|
|
21
21
|
},
|
|
22
22
|
"devDependencies": {
|
|
23
|
-
"@xylabs/jest-helpers": "^3.6.
|
|
24
|
-
"@xylabs/ts-scripts-yarn3": "^3.
|
|
25
|
-
"@xylabs/tsconfig": "^3.
|
|
23
|
+
"@xylabs/jest-helpers": "^3.6.8",
|
|
24
|
+
"@xylabs/ts-scripts-yarn3": "^3.15.13",
|
|
25
|
+
"@xylabs/tsconfig": "^3.15.13",
|
|
26
26
|
"jest": "^29.7.0",
|
|
27
|
-
"typescript": "^5.5.
|
|
27
|
+
"typescript": "^5.5.4"
|
|
28
28
|
},
|
|
29
29
|
"description": "Typescript/Javascript Plugins for XYO Platform",
|
|
30
30
|
"types": "dist/node/index.d.ts",
|
|
@@ -37,7 +37,7 @@
|
|
|
37
37
|
},
|
|
38
38
|
"import": {
|
|
39
39
|
"types": "./dist/browser/index.d.mts",
|
|
40
|
-
"default": "./dist/browser/index.
|
|
40
|
+
"default": "./dist/browser/index.mjs"
|
|
41
41
|
}
|
|
42
42
|
},
|
|
43
43
|
"node": {
|
|
@@ -47,14 +47,14 @@
|
|
|
47
47
|
},
|
|
48
48
|
"import": {
|
|
49
49
|
"types": "./dist/node/index.d.mts",
|
|
50
|
-
"default": "./dist/node/index.
|
|
50
|
+
"default": "./dist/node/index.mjs"
|
|
51
51
|
}
|
|
52
52
|
}
|
|
53
53
|
},
|
|
54
54
|
"./package.json": "./package.json"
|
|
55
55
|
},
|
|
56
56
|
"main": "dist/node/index.cjs",
|
|
57
|
-
"module": "dist/node/index.
|
|
57
|
+
"module": "dist/node/index.mjs",
|
|
58
58
|
"homepage": "https://xyo.network",
|
|
59
59
|
"license": "LGPL-3.0-only",
|
|
60
60
|
"publishConfig": {
|
|
@@ -65,6 +65,6 @@
|
|
|
65
65
|
"url": "https://github.com/XYOracleNetwork/plugins.git"
|
|
66
66
|
},
|
|
67
67
|
"sideEffects": false,
|
|
68
|
-
"version": "2.99.
|
|
68
|
+
"version": "2.99.5",
|
|
69
69
|
"type": "module"
|
|
70
70
|
}
|
package/src/Plugin.ts
CHANGED
|
@@ -2,7 +2,7 @@ import { PayloadSetSchema } from '@xyo-network/payload-model'
|
|
|
2
2
|
import { createPayloadSetWitnessPlugin } from '@xyo-network/payloadset-plugin'
|
|
3
3
|
import { UrlSafetySchema } from '@xyo-network/url-safety-payload-plugin'
|
|
4
4
|
|
|
5
|
-
import { UrlSafetyWitness } from './Witness/index.
|
|
5
|
+
import { UrlSafetyWitness } from './Witness/index.ts'
|
|
6
6
|
|
|
7
7
|
export const UrlSafetyPlugin = () =>
|
|
8
8
|
createPayloadSetWitnessPlugin<UrlSafetyWitness>(
|
package/src/Witness/Params.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { AnyConfigSchema } from '@xyo-network/module-model'
|
|
2
2
|
import { WitnessParams } from '@xyo-network/witness-model'
|
|
3
3
|
|
|
4
|
-
import { UrlSafetyWitnessConfig } from './Config.
|
|
4
|
+
import { UrlSafetyWitnessConfig } from './Config.ts'
|
|
5
5
|
|
|
6
6
|
export type UrlSafetyWitnessParams = WitnessParams<
|
|
7
7
|
AnyConfigSchema<UrlSafetyWitnessConfig>,
|
package/src/Witness/Witness.ts
CHANGED
|
@@ -4,8 +4,8 @@ import { Payload, Schema } from '@xyo-network/payload-model'
|
|
|
4
4
|
import { UrlPayload, UrlSchema } from '@xyo-network/url-payload-plugin'
|
|
5
5
|
import { UrlSafetyPayload, UrlSafetySchema, UrlSafetyThreatType } from '@xyo-network/url-safety-payload-plugin'
|
|
6
6
|
|
|
7
|
-
import { UrlSafetyWitnessConfigSchema } from './Config.
|
|
8
|
-
import { UrlSafetyWitnessParams } from './Params.
|
|
7
|
+
import { UrlSafetyWitnessConfigSchema } from './Config.ts'
|
|
8
|
+
import { UrlSafetyWitnessParams } from './Params.ts'
|
|
9
9
|
|
|
10
10
|
export type GoogleSafeBrowsingMatchSchema = 'com.google.safebrowsing.match'
|
|
11
11
|
export const GoogleSafeBrowsingMatchSchema: GoogleSafeBrowsingMatchSchema = 'com.google.safebrowsing.match'
|
|
@@ -36,7 +36,7 @@ const checkUrlSafety = async (
|
|
|
36
36
|
const axios = new AxiosJson()
|
|
37
37
|
const endPoint = config?.endPoint ?? 'https://safebrowsing.googleapis.com/v4/threatMatches:find'
|
|
38
38
|
const key = config?.key
|
|
39
|
-
const mutatedUrls = urls.map(
|
|
39
|
+
const mutatedUrls = urls.map(url => url.replace('ipfs://', 'https://cloudflare-ipfs.com/'))
|
|
40
40
|
if (mutatedUrls.length === 0) {
|
|
41
41
|
return []
|
|
42
42
|
}
|
|
@@ -47,14 +47,14 @@ const checkUrlSafety = async (
|
|
|
47
47
|
},
|
|
48
48
|
threatInfo: {
|
|
49
49
|
platformTypes: ['WINDOWS', 'LINUX', 'OSX'],
|
|
50
|
-
threatEntries: mutatedUrls.map(
|
|
50
|
+
threatEntries: mutatedUrls.map(url => ({ url })),
|
|
51
51
|
threatEntryTypes: ['URL'],
|
|
52
52
|
threatTypes: ['SOCIAL_ENGINEERING', 'POTENTIALLY_HARMFUL_APPLICATION', 'UNWANTED_SOFTWARE', 'THREAT_TYPE_UNSPECIFIED'],
|
|
53
53
|
},
|
|
54
54
|
}
|
|
55
55
|
const result = (await axios.post<GoogleSafeBrowsingResult>(`${endPoint}?key=${key}`, postData, { headers: { referer: 'http://localhost:3000' } }))
|
|
56
56
|
.data
|
|
57
|
-
return result.matches?.map<GoogleSafeBrowsingMatchPayload>(
|
|
57
|
+
return result.matches?.map<GoogleSafeBrowsingMatchPayload>(match => ({ ...match, schema: GoogleSafeBrowsingMatchSchema })) ?? []
|
|
58
58
|
}
|
|
59
59
|
|
|
60
60
|
export class UrlSafetyWitness<TParams extends UrlSafetyWitnessParams = UrlSafetyWitnessParams> extends AbstractWitness<TParams> {
|
|
@@ -70,9 +70,9 @@ export class UrlSafetyWitness<TParams extends UrlSafetyWitnessParams = UrlSafety
|
|
|
70
70
|
}
|
|
71
71
|
|
|
72
72
|
protected override async observeHandler(payloads: UrlPayload[] = []): Promise<UrlSafetyPayload[]> {
|
|
73
|
-
const urls: string[]
|
|
74
|
-
this.urls
|
|
75
|
-
payloads
|
|
73
|
+
const urls: string[]
|
|
74
|
+
= this.urls
|
|
75
|
+
?? payloads
|
|
76
76
|
.filter((p): p is UrlPayload => p.schema === UrlSchema)
|
|
77
77
|
.map((p) => {
|
|
78
78
|
return p.url
|
package/src/Witness/index.ts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export * from './Config.
|
|
2
|
-
export * from './Params.
|
|
3
|
-
export * from './Witness.
|
|
1
|
+
export * from './Config.ts'
|
|
2
|
+
export * from './Params.ts'
|
|
3
|
+
export * from './Witness.ts'
|
package/src/index.ts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
// eslint-disable-next-line import/no-default-export
|
|
2
|
-
export { UrlSafetyPlugin as default, UrlSafetyPlugin } from './Plugin.
|
|
3
|
-
export * from './Witness/index.
|
|
2
|
+
export { UrlSafetyPlugin as default, UrlSafetyPlugin } from './Plugin.ts'
|
|
3
|
+
export * from './Witness/index.ts'
|
|
@@ -1 +0,0 @@
|
|
|
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.js'\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.js'\nimport { UrlSafetyWitnessParams } from './Params.js'\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,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,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,CAAC,WAAW,EAAE,GAAG,OAAO,QAAQ,8BAA8B,EAAE,KAAK,CAAC;AACnI;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,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;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 +0,0 @@
|
|
|
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.js'\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.js'\nimport { UrlSafetyWitnessParams } from './Params.js'\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,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,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,CAAC,WAAW,EAAE,GAAG,OAAO,QAAQ,8BAA8B,EAAE,KAAK,CAAC;AACnI;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,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;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"]}
|