@xyo-network/url-safety-plugin 3.4.2 → 3.4.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/neutral/Plugin.d.ts +20 -0
- package/dist/neutral/Plugin.d.ts.map +1 -0
- package/dist/neutral/Witness/Config.d.ts +13 -0
- package/dist/neutral/Witness/Config.d.ts.map +1 -0
- package/dist/neutral/Witness/Params.d.ts +12 -0
- package/dist/neutral/Witness/Params.d.ts.map +1 -0
- package/dist/neutral/Witness/Witness.d.ts +25 -0
- package/dist/neutral/Witness/Witness.d.ts.map +1 -0
- package/dist/neutral/Witness/index.d.ts +4 -0
- package/dist/neutral/Witness/index.d.ts.map +1 -0
- package/dist/neutral/index.d.ts +3 -72
- package/dist/neutral/index.d.ts.map +1 -0
- package/dist/neutral/index.mjs +3 -1
- package/dist/neutral/index.mjs.map +1 -1
- package/package.json +12 -12
- package/src/Witness/Config.ts +1 -1
- package/src/Witness/Params.ts +3 -3
- package/src/Witness/Witness.ts +6 -6
- package/xy.config.ts +1 -1
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { UrlSafetyWitness } from './Witness/index.ts';
|
|
2
|
+
export declare const UrlSafetyPlugin: () => import("@xyo-network/payloadset-plugin").PayloadSetWitnessPlugin<UrlSafetyWitness<import(".store/@xylabs-object-npm-4.5.1-e31c389195/package").BaseParamsFields & {
|
|
3
|
+
account?: import(".store/@xyo-network-account-model-virtual-26592e0d6e/package").AccountInstance | "random";
|
|
4
|
+
addToResolvers?: boolean;
|
|
5
|
+
additionalSigners?: import(".store/@xyo-network-account-model-virtual-26592e0d6e/package").AccountInstance[];
|
|
6
|
+
allowNameResolution?: boolean;
|
|
7
|
+
config: import("@xyo-network/module-model").AnyConfigSchema<import("./Witness/Config.ts").UrlSafetyWitnessConfig>;
|
|
8
|
+
ephemeralQueryAccountEnabled?: boolean;
|
|
9
|
+
moduleIdentifierTransformers?: import("@xyo-network/module-model").ModuleIdentifierTransformer[];
|
|
10
|
+
privateChildren?: import("@xyo-network/module-model").ModuleInstance[];
|
|
11
|
+
publicChildren?: import("@xyo-network/module-model").ModuleInstance[];
|
|
12
|
+
} & {
|
|
13
|
+
google?: {
|
|
14
|
+
safeBrowsing?: {
|
|
15
|
+
endPoint?: string;
|
|
16
|
+
key?: string;
|
|
17
|
+
};
|
|
18
|
+
};
|
|
19
|
+
}>>;
|
|
20
|
+
//# sourceMappingURL=Plugin.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Plugin.d.ts","sourceRoot":"","sources":["../../src/Plugin.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAA;AAErD,eAAO,MAAM,eAAe;;;;;;;;;;;;oBAC1B,CAAF;oBAAoB,CAAC;eAAoB,CAAC;;;GAQvC,CAAA"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { WitnessConfig } from '@xyo-network/witness-model';
|
|
2
|
+
export declare const UrlSafetyWitnessConfigSchema: "network.xyo.url.safety.witness.config";
|
|
3
|
+
export type UrlSafetyWitnessConfigSchema = typeof UrlSafetyWitnessConfigSchema;
|
|
4
|
+
export type UrlSafetyWitnessConfig = WitnessConfig<{
|
|
5
|
+
google?: {
|
|
6
|
+
safeBrowsing?: {
|
|
7
|
+
endPoint?: string;
|
|
8
|
+
};
|
|
9
|
+
};
|
|
10
|
+
schema: UrlSafetyWitnessConfigSchema;
|
|
11
|
+
urls?: string[];
|
|
12
|
+
}>;
|
|
13
|
+
//# sourceMappingURL=Config.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Config.d.ts","sourceRoot":"","sources":["../../../src/Witness/Config.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AAE1D,eAAO,MAAM,4BAA4B,yCAA+C,CAAA;AACxF,MAAM,MAAM,4BAA4B,GAAG,OAAO,4BAA4B,CAAA;AAE9E,MAAM,MAAM,sBAAsB,GAAG,aAAa,CAAC;IACjD,MAAM,CAAC,EAAE;QACP,YAAY,CAAC,EAAE;YACb,QAAQ,CAAC,EAAE,MAAM,CAAA;SAClB,CAAA;KACF,CAAA;IACD,MAAM,EAAE,4BAA4B,CAAA;IACpC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAA;CAChB,CAAC,CAAA"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { AnyConfigSchema } from '@xyo-network/module-model';
|
|
2
|
+
import { WitnessParams } from '@xyo-network/witness-model';
|
|
3
|
+
import { UrlSafetyWitnessConfig } from './Config.ts';
|
|
4
|
+
export type UrlSafetyWitnessParams = WitnessParams<AnyConfigSchema<UrlSafetyWitnessConfig>, {
|
|
5
|
+
google?: {
|
|
6
|
+
safeBrowsing?: {
|
|
7
|
+
endPoint?: string;
|
|
8
|
+
key?: string;
|
|
9
|
+
};
|
|
10
|
+
};
|
|
11
|
+
}>;
|
|
12
|
+
//# sourceMappingURL=Params.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Params.d.ts","sourceRoot":"","sources":["../../../src/Witness/Params.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAC3D,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AAE1D,OAAO,EAAE,sBAAsB,EAAE,MAAM,aAAa,CAAA;AAEpD,MAAM,MAAM,sBAAsB,GAAG,aAAa,CAChD,eAAe,CAAC,sBAAsB,CAAC,EACvC;IACE,MAAM,CAAC,EAAE;QACP,YAAY,CAAC,EAAE;YACb,QAAQ,CAAC,EAAE,MAAM,CAAA;YACjB,GAAG,CAAC,EAAE,MAAM,CAAA;SACb,CAAA;KACF,CAAA;CACF,CACF,CAAA"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { AbstractWitness } from '@xyo-network/abstract-witness';
|
|
2
|
+
import { Payload, Schema } from '@xyo-network/payload-model';
|
|
3
|
+
import { UrlPayload } from '@xyo-network/url-payload-plugin';
|
|
4
|
+
import { UrlSafetyPayload } from '@xyo-network/url-safety-payload-plugin';
|
|
5
|
+
import { UrlSafetyWitnessParams } from './Params.ts';
|
|
6
|
+
export type GoogleSafeBrowsingMatchSchema = 'com.google.safebrowsing.match';
|
|
7
|
+
export declare const GoogleSafeBrowsingMatchSchema: GoogleSafeBrowsingMatchSchema;
|
|
8
|
+
export interface GoogleSafeBrowsingMatch {
|
|
9
|
+
cacheDuration: string;
|
|
10
|
+
platformType: string;
|
|
11
|
+
threat: {
|
|
12
|
+
url: string;
|
|
13
|
+
};
|
|
14
|
+
threatEntryType: string;
|
|
15
|
+
threatType: string;
|
|
16
|
+
}
|
|
17
|
+
export type GoogleSafeBrowsingMatchPayload = Payload<GoogleSafeBrowsingMatch, GoogleSafeBrowsingMatchSchema>;
|
|
18
|
+
export declare class UrlSafetyWitness<TParams extends UrlSafetyWitnessParams = UrlSafetyWitnessParams> extends AbstractWitness<TParams> {
|
|
19
|
+
static readonly configSchemas: Schema[];
|
|
20
|
+
static readonly defaultConfigSchema: Schema;
|
|
21
|
+
get key(): string | undefined;
|
|
22
|
+
get urls(): string[] | undefined;
|
|
23
|
+
protected observeHandler(payloads?: UrlPayload[]): Promise<UrlSafetyPayload[]>;
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=Witness.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Witness.d.ts","sourceRoot":"","sources":["../../../src/Witness/Witness.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAC/D,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAC5D,OAAO,EAAE,UAAU,EAAa,MAAM,iCAAiC,CAAA;AACvE,OAAO,EACL,gBAAgB,EACjB,MAAM,wCAAwC,CAAA;AAG/C,OAAO,EAAE,sBAAsB,EAAE,MAAM,aAAa,CAAA;AAEpD,MAAM,MAAM,6BAA6B,GAAG,+BAA+B,CAAA;AAC3E,eAAO,MAAM,6BAA6B,EAAE,6BAA+D,CAAA;AAE3G,MAAM,WAAW,uBAAuB;IACtC,aAAa,EAAE,MAAM,CAAA;IACrB,YAAY,EAAE,MAAM,CAAA;IACpB,MAAM,EAAE;QACN,GAAG,EAAE,MAAM,CAAA;KACZ,CAAA;IACD,eAAe,EAAE,MAAM,CAAA;IACvB,UAAU,EAAE,MAAM,CAAA;CACnB;AAED,MAAM,MAAM,8BAA8B,GAAG,OAAO,CAAC,uBAAuB,EAAE,6BAA6B,CAAC,CAAA;AAqC5G,qBAAa,gBAAgB,CAAC,OAAO,SAAS,sBAAsB,GAAG,sBAAsB,CAAE,SAAQ,eAAe,CAAC,OAAO,CAAC;IAC7H,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAyD;IACzG,gBAAyB,mBAAmB,EAAE,MAAM,CAA+B;IAEnF,IAAI,GAAG,uBAEN;IAED,IAAI,IAAI,yBAEP;cAEwB,cAAc,CAAC,QAAQ,GAAE,UAAU,EAAO,GAAG,OAAO,CAAC,gBAAgB,EAAE,CAAC;CA6BlG"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/Witness/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAA;AAC3B,cAAc,aAAa,CAAA;AAC3B,cAAc,cAAc,CAAA"}
|
package/dist/neutral/index.d.ts
CHANGED
|
@@ -1,72 +1,3 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
import { WitnessConfig, WitnessParams } from '@xyo-network/witness-model';
|
|
5
|
-
import * as _store__xyo_network_account_model_virtual_8ffda77307_package from '.store/@xyo-network-account-model-virtual-8ffda77307/package';
|
|
6
|
-
import * as _store__xylabs_object_npm_4_5_1_e31c389195_package from '.store/@xylabs-object-npm-4.5.1-e31c389195/package';
|
|
7
|
-
import { AbstractWitness } from '@xyo-network/abstract-witness';
|
|
8
|
-
import { Schema, Payload } from '@xyo-network/payload-model';
|
|
9
|
-
import { UrlPayload } from '@xyo-network/url-payload-plugin';
|
|
10
|
-
import { UrlSafetyPayload } from '@xyo-network/url-safety-payload-plugin';
|
|
11
|
-
|
|
12
|
-
declare const UrlSafetyWitnessConfigSchema: "network.xyo.url.safety.witness.config";
|
|
13
|
-
type UrlSafetyWitnessConfigSchema = typeof UrlSafetyWitnessConfigSchema;
|
|
14
|
-
type UrlSafetyWitnessConfig = WitnessConfig<{
|
|
15
|
-
google?: {
|
|
16
|
-
safeBrowsing?: {
|
|
17
|
-
endPoint?: string;
|
|
18
|
-
};
|
|
19
|
-
};
|
|
20
|
-
schema: UrlSafetyWitnessConfigSchema;
|
|
21
|
-
urls?: string[];
|
|
22
|
-
}>;
|
|
23
|
-
|
|
24
|
-
type UrlSafetyWitnessParams = WitnessParams<AnyConfigSchema<UrlSafetyWitnessConfig>, {
|
|
25
|
-
google?: {
|
|
26
|
-
safeBrowsing?: {
|
|
27
|
-
endPoint?: string;
|
|
28
|
-
key?: string;
|
|
29
|
-
};
|
|
30
|
-
};
|
|
31
|
-
}>;
|
|
32
|
-
|
|
33
|
-
type GoogleSafeBrowsingMatchSchema = 'com.google.safebrowsing.match';
|
|
34
|
-
declare const GoogleSafeBrowsingMatchSchema: GoogleSafeBrowsingMatchSchema;
|
|
35
|
-
interface GoogleSafeBrowsingMatch {
|
|
36
|
-
cacheDuration: string;
|
|
37
|
-
platformType: string;
|
|
38
|
-
threat: {
|
|
39
|
-
url: string;
|
|
40
|
-
};
|
|
41
|
-
threatEntryType: string;
|
|
42
|
-
threatType: string;
|
|
43
|
-
}
|
|
44
|
-
type GoogleSafeBrowsingMatchPayload = Payload<GoogleSafeBrowsingMatch, GoogleSafeBrowsingMatchSchema>;
|
|
45
|
-
declare class UrlSafetyWitness<TParams extends UrlSafetyWitnessParams = UrlSafetyWitnessParams> extends AbstractWitness<TParams> {
|
|
46
|
-
static readonly configSchemas: Schema[];
|
|
47
|
-
static readonly defaultConfigSchema: Schema;
|
|
48
|
-
get key(): string | undefined;
|
|
49
|
-
get urls(): string[] | undefined;
|
|
50
|
-
protected observeHandler(payloads?: UrlPayload[]): Promise<UrlSafetyPayload[]>;
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
declare const UrlSafetyPlugin: () => _xyo_network_payloadset_plugin.PayloadSetWitnessPlugin<UrlSafetyWitness<_store__xylabs_object_npm_4_5_1_e31c389195_package.BaseParamsFields & {
|
|
54
|
-
account?: _store__xyo_network_account_model_virtual_8ffda77307_package.AccountInstance | "random";
|
|
55
|
-
addToResolvers?: boolean;
|
|
56
|
-
additionalSigners?: _store__xyo_network_account_model_virtual_8ffda77307_package.AccountInstance[];
|
|
57
|
-
allowNameResolution?: boolean;
|
|
58
|
-
config: _xyo_network_module_model.AnyConfigSchema<UrlSafetyWitnessConfig>;
|
|
59
|
-
ephemeralQueryAccountEnabled?: boolean;
|
|
60
|
-
moduleIdentifierTransformers?: _xyo_network_module_model.ModuleIdentifierTransformer[];
|
|
61
|
-
privateChildren?: _xyo_network_module_model.ModuleInstance[];
|
|
62
|
-
publicChildren?: _xyo_network_module_model.ModuleInstance[];
|
|
63
|
-
} & {
|
|
64
|
-
google?: {
|
|
65
|
-
safeBrowsing?: {
|
|
66
|
-
endPoint?: string;
|
|
67
|
-
key?: string;
|
|
68
|
-
};
|
|
69
|
-
};
|
|
70
|
-
}>>;
|
|
71
|
-
|
|
72
|
-
export { type GoogleSafeBrowsingMatch, type GoogleSafeBrowsingMatchPayload, GoogleSafeBrowsingMatchSchema, UrlSafetyPlugin, UrlSafetyWitness, type UrlSafetyWitnessConfig, UrlSafetyWitnessConfigSchema, type UrlSafetyWitnessParams, UrlSafetyPlugin as default };
|
|
1
|
+
export { UrlSafetyPlugin as default, UrlSafetyPlugin } from './Plugin.ts';
|
|
2
|
+
export * from './Witness/index.ts';
|
|
3
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,IAAI,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAA;AACzE,cAAc,oBAAoB,CAAA"}
|
package/dist/neutral/index.mjs
CHANGED
|
@@ -11,7 +11,9 @@ var UrlSafetyWitnessConfigSchema = `${UrlSafetySchema}.witness.config`;
|
|
|
11
11
|
import { AxiosJson } from "@xylabs/axios";
|
|
12
12
|
import { AbstractWitness } from "@xyo-network/abstract-witness";
|
|
13
13
|
import { UrlSchema } from "@xyo-network/url-payload-plugin";
|
|
14
|
-
import {
|
|
14
|
+
import {
|
|
15
|
+
UrlSafetySchema as UrlSafetySchema2
|
|
16
|
+
} from "@xyo-network/url-safety-payload-plugin";
|
|
15
17
|
var GoogleSafeBrowsingMatchSchema = "com.google.safebrowsing.match";
|
|
16
18
|
var checkUrlSafety = async (urls, config) => {
|
|
17
19
|
const axios = new AxiosJson();
|
|
@@ -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
|
|
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 {\n UrlSafetyPayload, UrlSafetySchema, UrlSafetyThreatType,\n} 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;AAAA,EACoB,mBAAAC;AAAA,OACb;AAMA,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,QACF,SACA,OAAO,CAAC,MAAuB,EAAE,WAAW,SAAS,EACrD,IAAI,CAAC,MAAM;AACV,aAAO,EAAE;AAAA,IACX,CAAC;AAEP,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;;;AFhGO,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"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@xyo-network/url-safety-plugin",
|
|
3
|
-
"version": "3.4.
|
|
3
|
+
"version": "3.4.3",
|
|
4
4
|
"description": "Typescript/Javascript Plugins for XYO Platform",
|
|
5
5
|
"homepage": "https://xyo.network",
|
|
6
6
|
"bugs": {
|
|
@@ -30,19 +30,19 @@
|
|
|
30
30
|
"types": "dist/neutral/index.d.ts",
|
|
31
31
|
"dependencies": {
|
|
32
32
|
"@xylabs/axios": "^4.5.1",
|
|
33
|
-
"@xyo-network/abstract-witness": "^3.9.
|
|
34
|
-
"@xyo-network/module-model": "^3.9.
|
|
35
|
-
"@xyo-network/payload-model": "^3.9.
|
|
36
|
-
"@xyo-network/payloadset-plugin": "^3.9.
|
|
37
|
-
"@xyo-network/url-payload-plugin": "^3.4.
|
|
38
|
-
"@xyo-network/url-safety-payload-plugin": "^3.4.
|
|
39
|
-
"@xyo-network/witness-model": "^3.9.
|
|
33
|
+
"@xyo-network/abstract-witness": "^3.9.23",
|
|
34
|
+
"@xyo-network/module-model": "^3.9.23",
|
|
35
|
+
"@xyo-network/payload-model": "^3.9.23",
|
|
36
|
+
"@xyo-network/payloadset-plugin": "^3.9.23",
|
|
37
|
+
"@xyo-network/url-payload-plugin": "^3.4.3",
|
|
38
|
+
"@xyo-network/url-safety-payload-plugin": "^3.4.3",
|
|
39
|
+
"@xyo-network/witness-model": "^3.9.23"
|
|
40
40
|
},
|
|
41
41
|
"devDependencies": {
|
|
42
|
-
"@xylabs/ts-scripts-yarn3": "^5.0.
|
|
43
|
-
"@xylabs/tsconfig": "^5.0.
|
|
44
|
-
"typescript": "^5.
|
|
45
|
-
"vitest": "^3.0.
|
|
42
|
+
"@xylabs/ts-scripts-yarn3": "^5.0.39",
|
|
43
|
+
"@xylabs/tsconfig": "^5.0.39",
|
|
44
|
+
"typescript": "^5.8.2",
|
|
45
|
+
"vitest": "^3.0.7"
|
|
46
46
|
},
|
|
47
47
|
"publishConfig": {
|
|
48
48
|
"access": "public"
|
package/src/Witness/Config.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { UrlSafetySchema } from '@xyo-network/url-safety-payload-plugin'
|
|
2
|
-
import
|
|
2
|
+
import { WitnessConfig } from '@xyo-network/witness-model'
|
|
3
3
|
|
|
4
4
|
export const UrlSafetyWitnessConfigSchema = `${UrlSafetySchema}.witness.config` as const
|
|
5
5
|
export type UrlSafetyWitnessConfigSchema = typeof UrlSafetyWitnessConfigSchema
|
package/src/Witness/Params.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import
|
|
2
|
-
import
|
|
1
|
+
import { AnyConfigSchema } from '@xyo-network/module-model'
|
|
2
|
+
import { WitnessParams } from '@xyo-network/witness-model'
|
|
3
3
|
|
|
4
|
-
import
|
|
4
|
+
import { UrlSafetyWitnessConfig } from './Config.ts'
|
|
5
5
|
|
|
6
6
|
export type UrlSafetyWitnessParams = WitnessParams<
|
|
7
7
|
AnyConfigSchema<UrlSafetyWitnessConfig>,
|
package/src/Witness/Witness.ts
CHANGED
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
import { AxiosJson } from '@xylabs/axios'
|
|
2
2
|
import { AbstractWitness } from '@xyo-network/abstract-witness'
|
|
3
|
-
import
|
|
4
|
-
import
|
|
5
|
-
import {
|
|
6
|
-
|
|
7
|
-
|
|
3
|
+
import { Payload, Schema } from '@xyo-network/payload-model'
|
|
4
|
+
import { UrlPayload, UrlSchema } from '@xyo-network/url-payload-plugin'
|
|
5
|
+
import {
|
|
6
|
+
UrlSafetyPayload, UrlSafetySchema, UrlSafetyThreatType,
|
|
7
|
+
} from '@xyo-network/url-safety-payload-plugin'
|
|
8
8
|
|
|
9
9
|
import { UrlSafetyWitnessConfigSchema } from './Config.ts'
|
|
10
|
-
import
|
|
10
|
+
import { UrlSafetyWitnessParams } from './Params.ts'
|
|
11
11
|
|
|
12
12
|
export type GoogleSafeBrowsingMatchSchema = 'com.google.safebrowsing.match'
|
|
13
13
|
export const GoogleSafeBrowsingMatchSchema: GoogleSafeBrowsingMatchSchema = 'com.google.safebrowsing.match'
|
package/xy.config.ts
CHANGED