@xyo-network/domain-payload-plugin 2.75.0 → 2.75.2
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/Payload.d.cts +19 -0
- package/dist/browser/Payload.d.cts.map +1 -0
- package/dist/browser/Plugin.d.cts +21 -0
- package/dist/browser/Plugin.d.cts.map +1 -0
- package/dist/browser/Plugin.js +4 -112
- package/dist/browser/Plugin.js.map +1 -1
- package/dist/browser/Schema.d.cts +3 -0
- package/dist/browser/Schema.d.cts.map +1 -0
- package/dist/browser/Schema.js +1 -2
- package/dist/browser/Schema.js.map +1 -1
- package/dist/browser/Template.d.cts +3 -0
- package/dist/browser/Template.d.cts.map +1 -0
- package/dist/browser/Template.js +2 -5
- package/dist/browser/Template.js.map +1 -1
- package/dist/browser/Wrapper.d.cts +115 -0
- package/dist/browser/Wrapper.d.cts.map +1 -0
- package/dist/browser/Wrapper.js +5 -6
- package/dist/browser/Wrapper.js.map +1 -1
- package/dist/browser/index.d.cts +8 -0
- package/dist/browser/index.d.cts.map +1 -0
- package/dist/browser/index.js +6 -123
- package/dist/browser/index.js.map +1 -1
- package/dist/browser/schemadef.cjs +122 -0
- package/dist/browser/schemadef.cjs.map +1 -0
- package/dist/browser/schemadef.js +129 -0
- package/dist/browser/schemadef.js.map +1 -0
- package/dist/docs.json +11936 -0
- package/dist/node/Payload.d.cts +19 -0
- package/dist/node/Payload.d.cts.map +1 -0
- package/dist/node/Payload.js +2 -0
- package/dist/node/Payload.js.map +1 -1
- package/dist/node/Plugin.d.cts +21 -0
- package/dist/node/Plugin.d.cts.map +1 -0
- package/dist/node/Plugin.js +119 -7
- package/dist/node/Plugin.js.map +1 -1
- package/dist/node/Plugin.mjs +115 -4
- package/dist/node/Plugin.mjs.map +1 -1
- package/dist/node/Schema.d.cts +3 -0
- package/dist/node/Schema.d.cts.map +1 -0
- package/dist/node/Schema.js +3 -1
- package/dist/node/Schema.js.map +1 -1
- package/dist/node/Schema.mjs +2 -1
- package/dist/node/Schema.mjs.map +1 -1
- package/dist/node/Template.d.cts +3 -0
- package/dist/node/Template.d.cts.map +1 -0
- package/dist/node/Template.js +9 -3
- package/dist/node/Template.js.map +1 -1
- package/dist/node/Template.mjs +5 -2
- package/dist/node/Template.mjs.map +1 -1
- package/dist/node/Wrapper.d.cts +115 -0
- package/dist/node/Wrapper.d.cts.map +1 -0
- package/dist/node/Wrapper.js +13 -8
- package/dist/node/Wrapper.js.map +1 -1
- package/dist/node/Wrapper.mjs +12 -8
- package/dist/node/Wrapper.mjs.map +1 -1
- package/dist/node/index.d.cts +8 -0
- package/dist/node/index.d.cts.map +1 -0
- package/dist/node/index.js +134 -13
- package/dist/node/index.js.map +1 -1
- package/dist/node/index.mjs +126 -6
- package/dist/node/index.mjs.map +1 -1
- package/dist/node/schemadef.js +130 -0
- package/dist/node/schemadef.js.map +1 -0
- package/dist/node/schemadef.mjs +130 -0
- package/dist/node/schemadef.mjs.map +1 -0
- package/package.json +14 -14
- package/dist/node/schema.json +0 -115
- package/src/schema.json +0 -115
- /package/{dist/browser/schema.json → src/schemadef.json} +0 -0
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { NetworkPayload } from '@xyo-network/network';
|
|
2
|
+
import { Payload } from '@xyo-network/payload-model';
|
|
3
|
+
import { DomainSchema } from './Schema';
|
|
4
|
+
export interface Alias {
|
|
5
|
+
/** @field huri to the aliased payload */
|
|
6
|
+
huri: string;
|
|
7
|
+
/** @field canonical name (ex. network.xyo.example) */
|
|
8
|
+
name?: string;
|
|
9
|
+
}
|
|
10
|
+
export type DomainPayload = Payload<{
|
|
11
|
+
/** @field Additional config files [huri] [out] */
|
|
12
|
+
additional?: string[];
|
|
13
|
+
/** @field Values associated with this domain [out] */
|
|
14
|
+
aliases?: Record<string, Alias>;
|
|
15
|
+
/** @field Known networks [out] */
|
|
16
|
+
networks?: NetworkPayload[];
|
|
17
|
+
schema: DomainSchema;
|
|
18
|
+
}>;
|
|
19
|
+
//# sourceMappingURL=Payload.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Payload.d.ts","sourceRoot":"","sources":["../../src/Payload.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAA;AACrD,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAA;AAEvC,MAAM,WAAW,KAAK;IACpB,yCAAyC;IACzC,IAAI,EAAE,MAAM,CAAA;IACZ,sDAAsD;IACtD,IAAI,CAAC,EAAE,MAAM,CAAA;CACd;AAED,MAAM,MAAM,aAAa,GAAG,OAAO,CAAC;IAClC,kDAAkD;IAClD,UAAU,CAAC,EAAE,MAAM,EAAE,CAAA;IACrB,sDAAsD;IACtD,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAA;IAC/B,kCAAkC;IAClC,QAAQ,CAAC,EAAE,cAAc,EAAE,CAAA;IAC3B,MAAM,EAAE,YAAY,CAAA;CACrB,CAAC,CAAA"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export declare const DomainPayloadPlugin: () => import("@xyo-network/payload-plugin").PayloadPlugin<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
2
|
+
additional?: string[] | undefined;
|
|
3
|
+
aliases?: Record<string, import("./Payload").Alias> | undefined;
|
|
4
|
+
networks?: (import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
5
|
+
name?: string | undefined;
|
|
6
|
+
nodes?: (import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
7
|
+
docs?: string | undefined;
|
|
8
|
+
name?: string | undefined;
|
|
9
|
+
slug: string;
|
|
10
|
+
type: import("@xyo-network/network").NetworkNodeType;
|
|
11
|
+
uri: string;
|
|
12
|
+
web?: string | undefined;
|
|
13
|
+
} & {
|
|
14
|
+
schema: "network.xyo.network.node";
|
|
15
|
+
})[] | undefined;
|
|
16
|
+
schema: "network.xyo.network";
|
|
17
|
+
slug: string;
|
|
18
|
+
})[] | undefined;
|
|
19
|
+
schema: "network.xyo.domain";
|
|
20
|
+
}>;
|
|
21
|
+
//# sourceMappingURL=Plugin.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Plugin.d.ts","sourceRoot":"","sources":["../../src/Plugin.ts"],"names":[],"mappings":"AAQA,eAAO,MAAM,mBAAmB;;;;;;;;;;;;;;;;;;;EAK5B,CAAA"}
|
package/dist/browser/Plugin.js
CHANGED
|
@@ -1,116 +1,8 @@
|
|
|
1
|
-
// src/Plugin.ts
|
|
2
1
|
import { createPayloadPlugin } from "@xyo-network/payload-plugin";
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
// src/Template.ts
|
|
8
|
-
var domainConfigTemplate = () => ({
|
|
9
|
-
aliases: {
|
|
10
|
-
"com.example.id": {
|
|
11
|
-
huri: ""
|
|
12
|
-
}
|
|
13
|
-
},
|
|
14
|
-
networks: [
|
|
15
|
-
{
|
|
16
|
-
name: "",
|
|
17
|
-
nodes: [
|
|
18
|
-
{
|
|
19
|
-
name: "",
|
|
20
|
-
schema: "network.xyo.network.node",
|
|
21
|
-
slug: "",
|
|
22
|
-
type: "archivist",
|
|
23
|
-
uri: ""
|
|
24
|
-
}
|
|
25
|
-
],
|
|
26
|
-
schema: "network.xyo.network",
|
|
27
|
-
slug: ""
|
|
28
|
-
}
|
|
29
|
-
],
|
|
30
|
-
schema: DomainSchema
|
|
31
|
-
});
|
|
32
|
-
|
|
33
|
-
// src/Wrapper.ts
|
|
34
|
-
import { reverse } from "@xylabs/lodash";
|
|
35
|
-
import { axios } from "@xyo-network/axios";
|
|
36
|
-
import { isBrowser, PayloadHasher } from "@xyo-network/core";
|
|
37
|
-
import { DnsRecordType, domainResolve } from "@xyo-network/dns";
|
|
38
|
-
import { Huri } from "@xyo-network/huri";
|
|
39
|
-
import { PayloadWrapper } from "@xyo-network/payload-wrapper";
|
|
40
|
-
var DomainPayloadWrapper = class _DomainPayloadWrapper extends PayloadWrapper {
|
|
41
|
-
aliases;
|
|
42
|
-
static async discover(reverseDomainName, proxy) {
|
|
43
|
-
const parts = reverseDomainName.split(".");
|
|
44
|
-
for (let i = 2; i <= parts.length; i++) {
|
|
45
|
-
const domainToCheck = reverse(parts.filter((_, index) => index < i)).join(".");
|
|
46
|
-
return await this.discoverDNSEntry(domainToCheck) ?? await this.discoverRootFile(domainToCheck, proxy);
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
static async discoverDNSEntry(domain) {
|
|
50
|
-
try {
|
|
51
|
-
const hash = (await domainResolve(`_xyo.${domain}`, DnsRecordType.TXT))?.Answer?.[0]?.data;
|
|
52
|
-
if (hash) {
|
|
53
|
-
const huri = new Huri(hash);
|
|
54
|
-
const payload = await huri.fetch();
|
|
55
|
-
if (payload) {
|
|
56
|
-
return new _DomainPayloadWrapper(payload);
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
} catch (ex) {
|
|
60
|
-
console.log(`DomainConfig dns reading error entry not found [${domain}]`);
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
static async discoverRootFile(domain, proxy) {
|
|
64
|
-
return isBrowser() || proxy ? await this.discoverRootFileWithProxy(domain, proxy) : await this.discoverRootFileDirect(domain);
|
|
65
|
-
}
|
|
66
|
-
static async discoverRootFileDirect(domain) {
|
|
67
|
-
try {
|
|
68
|
-
const config = (await axios.get(`https://${domain}/xyo-config.json`)).data;
|
|
69
|
-
return new _DomainPayloadWrapper(config);
|
|
70
|
-
} catch (ex) {
|
|
71
|
-
console.log(`DomainConfig root file not found [${domain}]`);
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
static async discoverRootFileWithProxy(domain, proxy = "https://api.archivist.xyo.network/domain") {
|
|
75
|
-
try {
|
|
76
|
-
const requestUrl = `${proxy}/${domain.split(".").reverse().join(".")}`;
|
|
77
|
-
const config = (await axios.get(requestUrl)).data.data;
|
|
78
|
-
return new _DomainPayloadWrapper(config);
|
|
79
|
-
} catch (ex) {
|
|
80
|
-
const error = ex;
|
|
81
|
-
console.log(`DomainConfig root file not found using proxy [${domain}] [${error.code}]`);
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
async fetch(networkSlug) {
|
|
85
|
-
await this.fetchAliases(networkSlug);
|
|
86
|
-
}
|
|
87
|
-
async fetchAliases(networkSlug) {
|
|
88
|
-
this.aliases = null;
|
|
89
|
-
const archivistUri = await this.findArchivistUri(networkSlug);
|
|
90
|
-
if (this.payload().aliases) {
|
|
91
|
-
const fetchedAliases = await Promise.all(
|
|
92
|
-
Object.entries(this.payload().aliases ?? {}).map(([, alias]) => {
|
|
93
|
-
return this.fetchAlias(alias, { archivistUri });
|
|
94
|
-
})
|
|
95
|
-
);
|
|
96
|
-
this.aliases = fetchedAliases.filter((alias) => alias);
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
async fetchAlias(alias, huriOptions) {
|
|
100
|
-
const huri = new Huri(alias.huri, huriOptions);
|
|
101
|
-
const payload = await huri.fetch();
|
|
102
|
-
return payload ? { alias, huri, payload } : null;
|
|
103
|
-
}
|
|
104
|
-
async findArchivistUri(hash) {
|
|
105
|
-
return (await this.getNetwork(hash))?.nodes?.find((payload) => payload.type === "archivist" ? payload : void 0)?.uri;
|
|
106
|
-
}
|
|
107
|
-
async getNetwork(hash) {
|
|
108
|
-
return hash ? await PayloadHasher.find(this.payload().networks, hash) : this.payload().networks?.[0];
|
|
109
|
-
}
|
|
110
|
-
};
|
|
111
|
-
|
|
112
|
-
// src/Plugin.ts
|
|
113
|
-
var DomainPayloadPlugin = () => createPayloadPlugin({
|
|
2
|
+
import { DomainSchema } from "./Schema";
|
|
3
|
+
import { domainConfigTemplate } from "./Template";
|
|
4
|
+
import { DomainPayloadWrapper } from "./Wrapper";
|
|
5
|
+
const DomainPayloadPlugin = () => createPayloadPlugin({
|
|
114
6
|
schema: DomainSchema,
|
|
115
7
|
template: domainConfigTemplate,
|
|
116
8
|
wrap: (payload) => DomainPayloadWrapper.wrap(payload)
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/Plugin.ts"
|
|
1
|
+
{"version":3,"sources":["../../src/Plugin.ts"],"sourcesContent":["import { Payload } from '@xyo-network/payload-model'\nimport { createPayloadPlugin } from '@xyo-network/payload-plugin'\n\nimport { DomainPayload } from './Payload'\nimport { DomainSchema } from './Schema'\nimport { domainConfigTemplate } from './Template'\nimport { DomainPayloadWrapper } from './Wrapper'\n\nexport const DomainPayloadPlugin = () =>\n createPayloadPlugin<DomainPayload>({\n schema: DomainSchema,\n template: domainConfigTemplate,\n wrap: (payload: Payload) => DomainPayloadWrapper.wrap(payload as DomainPayload),\n })\n"],"mappings":"AACA,SAAS,2BAA2B;AAGpC,SAAS,oBAAoB;AAC7B,SAAS,4BAA4B;AACrC,SAAS,4BAA4B;AAE9B,MAAM,sBAAsB,MACjC,oBAAmC;AAAA,EACjC,QAAQ;AAAA,EACR,UAAU;AAAA,EACV,MAAM,CAAC,YAAqB,qBAAqB,KAAK,OAAwB;AAChF,CAAC;","names":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Schema.d.ts","sourceRoot":"","sources":["../../src/Schema.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,YAAY,GAAG,oBAAoB,CAAA;AAC/C,eAAO,MAAM,YAAY,EAAE,YAAmC,CAAA"}
|
package/dist/browser/Schema.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/Schema.ts"],"sourcesContent":["export type DomainSchema = 'network.xyo.domain'\nexport const DomainSchema: DomainSchema = 'network.xyo.domain'\n"],"mappings":"
|
|
1
|
+
{"version":3,"sources":["../../src/Schema.ts"],"sourcesContent":["export type DomainSchema = 'network.xyo.domain'\nexport const DomainSchema: DomainSchema = 'network.xyo.domain'\n"],"mappings":"AACO,MAAM,eAA6B;","names":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Template.d.ts","sourceRoot":"","sources":["../../src/Template.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAA;AAGzC,eAAO,MAAM,oBAAoB,QAAO,aAuBtC,CAAA"}
|
package/dist/browser/Template.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/
|
|
1
|
+
{"version":3,"sources":["../../src/Template.ts"],"sourcesContent":["import { DomainPayload } from './Payload'\nimport { DomainSchema } from './Schema'\n\nexport const domainConfigTemplate = (): DomainPayload => ({\n aliases: {\n 'com.example.id': {\n huri: '',\n },\n },\n networks: [\n {\n name: '',\n nodes: [\n {\n name: '',\n schema: 'network.xyo.network.node',\n slug: '',\n type: 'archivist',\n uri: '',\n },\n ],\n schema: 'network.xyo.network',\n slug: '',\n },\n ],\n schema: DomainSchema,\n})\n"],"mappings":"AACA,SAAS,oBAAoB;AAEtB,MAAM,uBAAuB,OAAsB;AAAA,EACxD,SAAS;AAAA,IACP,kBAAkB;AAAA,MAChB,MAAM;AAAA,IACR;AAAA,EACF;AAAA,EACA,UAAU;AAAA,IACR;AAAA,MACE,MAAM;AAAA,MACN,OAAO;AAAA,QACL;AAAA,UACE,MAAM;AAAA,UACN,QAAQ;AAAA,UACR,MAAM;AAAA,UACN,MAAM;AAAA,UACN,KAAK;AAAA,QACP;AAAA,MACF;AAAA,MACA,QAAQ;AAAA,MACR,MAAM;AAAA,IACR;AAAA,EACF;AAAA,EACA,QAAQ;AACV;","names":[]}
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
import { FetchedPayload } from '@xyo-network/huri';
|
|
2
|
+
import { PayloadWrapper } from '@xyo-network/payload-wrapper';
|
|
3
|
+
import { Alias, DomainPayload } from './Payload';
|
|
4
|
+
export interface FetchedAlias extends FetchedPayload {
|
|
5
|
+
alias: Alias;
|
|
6
|
+
}
|
|
7
|
+
export declare class DomainPayloadWrapper<T extends DomainPayload = DomainPayload> extends PayloadWrapper<T> {
|
|
8
|
+
aliases?: FetchedAlias[] | null;
|
|
9
|
+
static discover(reverseDomainName: string, proxy?: string): Promise<DomainPayloadWrapper<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
10
|
+
additional?: string[] | undefined;
|
|
11
|
+
aliases?: Record<string, Alias> | undefined;
|
|
12
|
+
networks?: (import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
13
|
+
name?: string | undefined;
|
|
14
|
+
nodes?: (import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
15
|
+
docs?: string | undefined;
|
|
16
|
+
name?: string | undefined;
|
|
17
|
+
slug: string;
|
|
18
|
+
type: import("@xyo-network/network").NetworkNodeType;
|
|
19
|
+
uri: string;
|
|
20
|
+
web?: string | undefined;
|
|
21
|
+
} & {
|
|
22
|
+
schema: "network.xyo.network.node";
|
|
23
|
+
})[] | undefined;
|
|
24
|
+
schema: "network.xyo.network";
|
|
25
|
+
slug: string;
|
|
26
|
+
})[] | undefined;
|
|
27
|
+
schema: "network.xyo.domain";
|
|
28
|
+
}> | undefined>;
|
|
29
|
+
static discoverDNSEntry(domain: string): Promise<DomainPayloadWrapper<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
30
|
+
additional?: string[] | undefined;
|
|
31
|
+
aliases?: Record<string, Alias> | undefined;
|
|
32
|
+
networks?: (import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
33
|
+
name?: string | undefined;
|
|
34
|
+
nodes?: (import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
35
|
+
docs?: string | undefined;
|
|
36
|
+
name?: string | undefined;
|
|
37
|
+
slug: string;
|
|
38
|
+
type: import("@xyo-network/network").NetworkNodeType;
|
|
39
|
+
uri: string;
|
|
40
|
+
web?: string | undefined;
|
|
41
|
+
} & {
|
|
42
|
+
schema: "network.xyo.network.node";
|
|
43
|
+
})[] | undefined;
|
|
44
|
+
schema: "network.xyo.network";
|
|
45
|
+
slug: string;
|
|
46
|
+
})[] | undefined;
|
|
47
|
+
schema: "network.xyo.domain";
|
|
48
|
+
}> | undefined>;
|
|
49
|
+
static discoverRootFile(domain: string, proxy?: string): Promise<DomainPayloadWrapper<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
50
|
+
additional?: string[] | undefined;
|
|
51
|
+
aliases?: Record<string, Alias> | undefined;
|
|
52
|
+
networks?: (import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
53
|
+
name?: string | undefined;
|
|
54
|
+
nodes?: (import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
55
|
+
docs?: string | undefined;
|
|
56
|
+
name?: string | undefined;
|
|
57
|
+
slug: string;
|
|
58
|
+
type: import("@xyo-network/network").NetworkNodeType;
|
|
59
|
+
uri: string;
|
|
60
|
+
web?: string | undefined;
|
|
61
|
+
} & {
|
|
62
|
+
schema: "network.xyo.network.node";
|
|
63
|
+
})[] | undefined;
|
|
64
|
+
schema: "network.xyo.network";
|
|
65
|
+
slug: string;
|
|
66
|
+
})[] | undefined;
|
|
67
|
+
schema: "network.xyo.domain";
|
|
68
|
+
}> | undefined>;
|
|
69
|
+
static discoverRootFileDirect(domain: string): Promise<DomainPayloadWrapper<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
70
|
+
additional?: string[] | undefined;
|
|
71
|
+
aliases?: Record<string, Alias> | undefined;
|
|
72
|
+
networks?: (import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
73
|
+
name?: string | undefined;
|
|
74
|
+
nodes?: (import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
75
|
+
docs?: string | undefined;
|
|
76
|
+
name?: string | undefined;
|
|
77
|
+
slug: string;
|
|
78
|
+
type: import("@xyo-network/network").NetworkNodeType;
|
|
79
|
+
uri: string;
|
|
80
|
+
web?: string | undefined;
|
|
81
|
+
} & {
|
|
82
|
+
schema: "network.xyo.network.node";
|
|
83
|
+
})[] | undefined;
|
|
84
|
+
schema: "network.xyo.network";
|
|
85
|
+
slug: string;
|
|
86
|
+
})[] | undefined;
|
|
87
|
+
schema: "network.xyo.domain";
|
|
88
|
+
}> | undefined>;
|
|
89
|
+
static discoverRootFileWithProxy(domain: string, proxy?: string): Promise<DomainPayloadWrapper<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
90
|
+
additional?: string[] | undefined;
|
|
91
|
+
aliases?: Record<string, Alias> | undefined;
|
|
92
|
+
networks?: (import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
93
|
+
name?: string | undefined;
|
|
94
|
+
nodes?: (import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
95
|
+
docs?: string | undefined;
|
|
96
|
+
name?: string | undefined;
|
|
97
|
+
slug: string;
|
|
98
|
+
type: import("@xyo-network/network").NetworkNodeType;
|
|
99
|
+
uri: string;
|
|
100
|
+
web?: string | undefined;
|
|
101
|
+
} & {
|
|
102
|
+
schema: "network.xyo.network.node";
|
|
103
|
+
})[] | undefined;
|
|
104
|
+
schema: "network.xyo.network";
|
|
105
|
+
slug: string;
|
|
106
|
+
})[] | undefined;
|
|
107
|
+
schema: "network.xyo.domain";
|
|
108
|
+
}> | undefined>;
|
|
109
|
+
fetch(networkSlug?: string): Promise<void>;
|
|
110
|
+
fetchAliases(networkSlug?: string): Promise<void>;
|
|
111
|
+
private fetchAlias;
|
|
112
|
+
private findArchivistUri;
|
|
113
|
+
private getNetwork;
|
|
114
|
+
}
|
|
115
|
+
//# sourceMappingURL=Wrapper.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Wrapper.d.ts","sourceRoot":"","sources":["../../src/Wrapper.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,cAAc,EAAqB,MAAM,mBAAmB,CAAA;AAErE,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAA;AAE7D,OAAO,EAAE,KAAK,EAAE,aAAa,EAAE,MAAM,WAAW,CAAA;AAEhD,MAAM,WAAW,YAAa,SAAQ,cAAc;IAClD,KAAK,EAAE,KAAK,CAAA;CACb;AAED,qBAAa,oBAAoB,CAAC,CAAC,SAAS,aAAa,GAAG,aAAa,CAAE,SAAQ,cAAc,CAAC,CAAC,CAAC;IAClG,OAAO,CAAC,EAAE,YAAY,EAAE,GAAG,IAAI,CAAA;WAElB,QAAQ,CAAC,iBAAiB,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM;;;;;;;;;;;;;;;;;;;;WAQlD,gBAAgB,CAAC,MAAM,EAAE,MAAM;;;;;;;;;;;;;;;;;;;;WAe/B,gBAAgB,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM;;;;;;;;;;;;;;;;;;;;WAI/C,sBAAsB,CAAC,MAAM,EAAE,MAAM;;;;;;;;;;;;;;;;;;;;WASrC,yBAAyB,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,SAA6C;;;;;;;;;;;;;;;;;;;;IAWnG,KAAK,CAAC,WAAW,CAAC,EAAE,MAAM;IAI1B,YAAY,CAAC,WAAW,CAAC,EAAE,MAAM;YAgBzB,UAAU;YAMV,gBAAgB;YAIhB,UAAU;CAGzB"}
|
package/dist/browser/Wrapper.js
CHANGED
|
@@ -1,11 +1,10 @@
|
|
|
1
|
-
// src/Wrapper.ts
|
|
2
1
|
import { reverse } from "@xylabs/lodash";
|
|
3
2
|
import { axios } from "@xyo-network/axios";
|
|
4
3
|
import { isBrowser, PayloadHasher } from "@xyo-network/core";
|
|
5
4
|
import { DnsRecordType, domainResolve } from "@xyo-network/dns";
|
|
6
5
|
import { Huri } from "@xyo-network/huri";
|
|
7
6
|
import { PayloadWrapper } from "@xyo-network/payload-wrapper";
|
|
8
|
-
|
|
7
|
+
class DomainPayloadWrapper extends PayloadWrapper {
|
|
9
8
|
aliases;
|
|
10
9
|
static async discover(reverseDomainName, proxy) {
|
|
11
10
|
const parts = reverseDomainName.split(".");
|
|
@@ -21,7 +20,7 @@ var DomainPayloadWrapper = class _DomainPayloadWrapper extends PayloadWrapper {
|
|
|
21
20
|
const huri = new Huri(hash);
|
|
22
21
|
const payload = await huri.fetch();
|
|
23
22
|
if (payload) {
|
|
24
|
-
return new
|
|
23
|
+
return new DomainPayloadWrapper(payload);
|
|
25
24
|
}
|
|
26
25
|
}
|
|
27
26
|
} catch (ex) {
|
|
@@ -34,7 +33,7 @@ var DomainPayloadWrapper = class _DomainPayloadWrapper extends PayloadWrapper {
|
|
|
34
33
|
static async discoverRootFileDirect(domain) {
|
|
35
34
|
try {
|
|
36
35
|
const config = (await axios.get(`https://${domain}/xyo-config.json`)).data;
|
|
37
|
-
return new
|
|
36
|
+
return new DomainPayloadWrapper(config);
|
|
38
37
|
} catch (ex) {
|
|
39
38
|
console.log(`DomainConfig root file not found [${domain}]`);
|
|
40
39
|
}
|
|
@@ -43,7 +42,7 @@ var DomainPayloadWrapper = class _DomainPayloadWrapper extends PayloadWrapper {
|
|
|
43
42
|
try {
|
|
44
43
|
const requestUrl = `${proxy}/${domain.split(".").reverse().join(".")}`;
|
|
45
44
|
const config = (await axios.get(requestUrl)).data.data;
|
|
46
|
-
return new
|
|
45
|
+
return new DomainPayloadWrapper(config);
|
|
47
46
|
} catch (ex) {
|
|
48
47
|
const error = ex;
|
|
49
48
|
console.log(`DomainConfig root file not found using proxy [${domain}] [${error.code}]`);
|
|
@@ -75,7 +74,7 @@ var DomainPayloadWrapper = class _DomainPayloadWrapper extends PayloadWrapper {
|
|
|
75
74
|
async getNetwork(hash) {
|
|
76
75
|
return hash ? await PayloadHasher.find(this.payload().networks, hash) : this.payload().networks?.[0];
|
|
77
76
|
}
|
|
78
|
-
}
|
|
77
|
+
}
|
|
79
78
|
export {
|
|
80
79
|
DomainPayloadWrapper
|
|
81
80
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/Wrapper.ts"],"sourcesContent":["import { reverse } from '@xylabs/lodash'\nimport { ApiEnvelope } from '@xyo-network/api-models'\nimport { axios, AxiosError } from '@xyo-network/axios'\nimport { isBrowser, PayloadHasher } from '@xyo-network/core'\nimport { DnsRecordType, domainResolve } from '@xyo-network/dns'\nimport { FetchedPayload, Huri, HuriOptions } from '@xyo-network/huri'\nimport { NetworkPayload } from '@xyo-network/network'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\nimport { Alias, DomainPayload } from './Payload'\n\nexport interface FetchedAlias extends FetchedPayload {\n alias: Alias\n}\n\nexport class DomainPayloadWrapper<T extends DomainPayload = DomainPayload> extends PayloadWrapper<T> {\n aliases?: FetchedAlias[] | null\n\n static async discover(reverseDomainName: string, proxy?: string) {\n const parts = reverseDomainName.split('.')\n for (let i = 2; i <= parts.length; i++) {\n const domainToCheck = reverse(parts.filter((_, index) => index < i)).join('.')\n return (await this.discoverDNSEntry(domainToCheck)) ?? (await this.discoverRootFile(domainToCheck, proxy))\n }\n }\n\n static async discoverDNSEntry(domain: string) {\n try {\n const hash = (await domainResolve(`_xyo.${domain}`, DnsRecordType.TXT))?.Answer?.[0]?.data\n if (hash) {\n const huri = new Huri(hash)\n const payload = (await huri.fetch()) as DomainPayload\n if (payload) {\n return new DomainPayloadWrapper(payload)\n }\n }\n } catch (ex) {\n console.log(`DomainConfig dns reading error entry not found [${domain}]`)\n }\n }\n\n static async discoverRootFile(domain: string, proxy?: string) {\n return isBrowser() || proxy ? await this.discoverRootFileWithProxy(domain, proxy) : await this.discoverRootFileDirect(domain)\n }\n\n static async discoverRootFileDirect(domain: string) {\n try {\n const config = (await axios.get<DomainPayload>(`https://${domain}/xyo-config.json`)).data\n return new DomainPayloadWrapper(config)\n } catch (ex) {\n console.log(`DomainConfig root file not found [${domain}]`)\n }\n }\n\n static async discoverRootFileWithProxy(domain: string, proxy = 'https://api.archivist.xyo.network/domain') {\n try {\n const requestUrl = `${proxy}/${domain.split('.').reverse().join('.')}`\n const config = (await axios.get<ApiEnvelope<DomainPayload>>(requestUrl)).data.data\n return new DomainPayloadWrapper(config)\n } catch (ex) {\n const error = ex as AxiosError\n console.log(`DomainConfig root file not found using proxy [${domain}] [${error.code}]`)\n }\n }\n\n async fetch(networkSlug?: string) {\n await this.fetchAliases(networkSlug)\n }\n\n async fetchAliases(networkSlug?: string) {\n //set it to null to signify fetch ran\n this.aliases = null\n\n const archivistUri = await this.findArchivistUri(networkSlug)\n if (this.payload().aliases) {\n const fetchedAliases = await Promise.all(\n Object.entries(this.payload().aliases ?? {}).map(([, alias]) => {\n return this.fetchAlias(alias, { archivistUri })\n }),\n )\n //cast to FetchedPayload[] after we filter out any null/undefined entries\n this.aliases = fetchedAliases.filter((alias) => alias) as FetchedAlias[]\n }\n }\n\n private async fetchAlias(alias: Alias, huriOptions?: HuriOptions): Promise<FetchedAlias | null> {\n const huri = new Huri(alias.huri, huriOptions)\n const payload = await huri.fetch()\n return payload ? { alias, huri, payload: payload } : null\n }\n\n private async findArchivistUri(hash?: string): Promise<string | undefined> {\n return (await this.getNetwork(hash))?.nodes?.find((payload) => (payload.type === 'archivist' ? payload : undefined))?.uri\n }\n\n private async getNetwork(hash?: string): Promise<NetworkPayload | undefined> {\n return hash ? await PayloadHasher.find(this.payload().networks, hash) : this.payload().networks?.[0]\n }\n}\n"],"mappings":"
|
|
1
|
+
{"version":3,"sources":["../../src/Wrapper.ts"],"sourcesContent":["import { reverse } from '@xylabs/lodash'\nimport { ApiEnvelope } from '@xyo-network/api-models'\nimport { axios, AxiosError } from '@xyo-network/axios'\nimport { isBrowser, PayloadHasher } from '@xyo-network/core'\nimport { DnsRecordType, domainResolve } from '@xyo-network/dns'\nimport { FetchedPayload, Huri, HuriOptions } from '@xyo-network/huri'\nimport { NetworkPayload } from '@xyo-network/network'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\nimport { Alias, DomainPayload } from './Payload'\n\nexport interface FetchedAlias extends FetchedPayload {\n alias: Alias\n}\n\nexport class DomainPayloadWrapper<T extends DomainPayload = DomainPayload> extends PayloadWrapper<T> {\n aliases?: FetchedAlias[] | null\n\n static async discover(reverseDomainName: string, proxy?: string) {\n const parts = reverseDomainName.split('.')\n for (let i = 2; i <= parts.length; i++) {\n const domainToCheck = reverse(parts.filter((_, index) => index < i)).join('.')\n return (await this.discoverDNSEntry(domainToCheck)) ?? (await this.discoverRootFile(domainToCheck, proxy))\n }\n }\n\n static async discoverDNSEntry(domain: string) {\n try {\n const hash = (await domainResolve(`_xyo.${domain}`, DnsRecordType.TXT))?.Answer?.[0]?.data\n if (hash) {\n const huri = new Huri(hash)\n const payload = (await huri.fetch()) as DomainPayload\n if (payload) {\n return new DomainPayloadWrapper(payload)\n }\n }\n } catch (ex) {\n console.log(`DomainConfig dns reading error entry not found [${domain}]`)\n }\n }\n\n static async discoverRootFile(domain: string, proxy?: string) {\n return isBrowser() || proxy ? await this.discoverRootFileWithProxy(domain, proxy) : await this.discoverRootFileDirect(domain)\n }\n\n static async discoverRootFileDirect(domain: string) {\n try {\n const config = (await axios.get<DomainPayload>(`https://${domain}/xyo-config.json`)).data\n return new DomainPayloadWrapper(config)\n } catch (ex) {\n console.log(`DomainConfig root file not found [${domain}]`)\n }\n }\n\n static async discoverRootFileWithProxy(domain: string, proxy = 'https://api.archivist.xyo.network/domain') {\n try {\n const requestUrl = `${proxy}/${domain.split('.').reverse().join('.')}`\n const config = (await axios.get<ApiEnvelope<DomainPayload>>(requestUrl)).data.data\n return new DomainPayloadWrapper(config)\n } catch (ex) {\n const error = ex as AxiosError\n console.log(`DomainConfig root file not found using proxy [${domain}] [${error.code}]`)\n }\n }\n\n async fetch(networkSlug?: string) {\n await this.fetchAliases(networkSlug)\n }\n\n async fetchAliases(networkSlug?: string) {\n //set it to null to signify fetch ran\n this.aliases = null\n\n const archivistUri = await this.findArchivistUri(networkSlug)\n if (this.payload().aliases) {\n const fetchedAliases = await Promise.all(\n Object.entries(this.payload().aliases ?? {}).map(([, alias]) => {\n return this.fetchAlias(alias, { archivistUri })\n }),\n )\n //cast to FetchedPayload[] after we filter out any null/undefined entries\n this.aliases = fetchedAliases.filter((alias) => alias) as FetchedAlias[]\n }\n }\n\n private async fetchAlias(alias: Alias, huriOptions?: HuriOptions): Promise<FetchedAlias | null> {\n const huri = new Huri(alias.huri, huriOptions)\n const payload = await huri.fetch()\n return payload ? { alias, huri, payload: payload } : null\n }\n\n private async findArchivistUri(hash?: string): Promise<string | undefined> {\n return (await this.getNetwork(hash))?.nodes?.find((payload) => (payload.type === 'archivist' ? payload : undefined))?.uri\n }\n\n private async getNetwork(hash?: string): Promise<NetworkPayload | undefined> {\n return hash ? await PayloadHasher.find(this.payload().networks, hash) : this.payload().networks?.[0]\n }\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { DomainPayloadPlugin } from './Plugin';
|
|
2
|
+
export * from './Payload';
|
|
3
|
+
export * from './Schema';
|
|
4
|
+
export * from './Template';
|
|
5
|
+
export * from './Wrapper';
|
|
6
|
+
export { DomainPayloadPlugin };
|
|
7
|
+
export default DomainPayloadPlugin;
|
|
8
|
+
//# 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,mBAAmB,EAAE,MAAM,UAAU,CAAA;AAE9C,cAAc,WAAW,CAAA;AACzB,cAAc,UAAU,CAAA;AACxB,cAAc,YAAY,CAAA;AAC1B,cAAc,WAAW,CAAA;AAEzB,OAAO,EAAE,mBAAmB,EAAE,CAAA;AAG9B,eAAe,mBAAmB,CAAA"}
|
package/dist/browser/index.js
CHANGED
|
@@ -1,128 +1,11 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
// src/Template.ts
|
|
8
|
-
var domainConfigTemplate = () => ({
|
|
9
|
-
aliases: {
|
|
10
|
-
"com.example.id": {
|
|
11
|
-
huri: ""
|
|
12
|
-
}
|
|
13
|
-
},
|
|
14
|
-
networks: [
|
|
15
|
-
{
|
|
16
|
-
name: "",
|
|
17
|
-
nodes: [
|
|
18
|
-
{
|
|
19
|
-
name: "",
|
|
20
|
-
schema: "network.xyo.network.node",
|
|
21
|
-
slug: "",
|
|
22
|
-
type: "archivist",
|
|
23
|
-
uri: ""
|
|
24
|
-
}
|
|
25
|
-
],
|
|
26
|
-
schema: "network.xyo.network",
|
|
27
|
-
slug: ""
|
|
28
|
-
}
|
|
29
|
-
],
|
|
30
|
-
schema: DomainSchema
|
|
31
|
-
});
|
|
32
|
-
|
|
33
|
-
// src/Wrapper.ts
|
|
34
|
-
import { reverse } from "@xylabs/lodash";
|
|
35
|
-
import { axios } from "@xyo-network/axios";
|
|
36
|
-
import { isBrowser, PayloadHasher } from "@xyo-network/core";
|
|
37
|
-
import { DnsRecordType, domainResolve } from "@xyo-network/dns";
|
|
38
|
-
import { Huri } from "@xyo-network/huri";
|
|
39
|
-
import { PayloadWrapper } from "@xyo-network/payload-wrapper";
|
|
40
|
-
var DomainPayloadWrapper = class _DomainPayloadWrapper extends PayloadWrapper {
|
|
41
|
-
aliases;
|
|
42
|
-
static async discover(reverseDomainName, proxy) {
|
|
43
|
-
const parts = reverseDomainName.split(".");
|
|
44
|
-
for (let i = 2; i <= parts.length; i++) {
|
|
45
|
-
const domainToCheck = reverse(parts.filter((_, index) => index < i)).join(".");
|
|
46
|
-
return await this.discoverDNSEntry(domainToCheck) ?? await this.discoverRootFile(domainToCheck, proxy);
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
static async discoverDNSEntry(domain) {
|
|
50
|
-
try {
|
|
51
|
-
const hash = (await domainResolve(`_xyo.${domain}`, DnsRecordType.TXT))?.Answer?.[0]?.data;
|
|
52
|
-
if (hash) {
|
|
53
|
-
const huri = new Huri(hash);
|
|
54
|
-
const payload = await huri.fetch();
|
|
55
|
-
if (payload) {
|
|
56
|
-
return new _DomainPayloadWrapper(payload);
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
} catch (ex) {
|
|
60
|
-
console.log(`DomainConfig dns reading error entry not found [${domain}]`);
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
static async discoverRootFile(domain, proxy) {
|
|
64
|
-
return isBrowser() || proxy ? await this.discoverRootFileWithProxy(domain, proxy) : await this.discoverRootFileDirect(domain);
|
|
65
|
-
}
|
|
66
|
-
static async discoverRootFileDirect(domain) {
|
|
67
|
-
try {
|
|
68
|
-
const config = (await axios.get(`https://${domain}/xyo-config.json`)).data;
|
|
69
|
-
return new _DomainPayloadWrapper(config);
|
|
70
|
-
} catch (ex) {
|
|
71
|
-
console.log(`DomainConfig root file not found [${domain}]`);
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
static async discoverRootFileWithProxy(domain, proxy = "https://api.archivist.xyo.network/domain") {
|
|
75
|
-
try {
|
|
76
|
-
const requestUrl = `${proxy}/${domain.split(".").reverse().join(".")}`;
|
|
77
|
-
const config = (await axios.get(requestUrl)).data.data;
|
|
78
|
-
return new _DomainPayloadWrapper(config);
|
|
79
|
-
} catch (ex) {
|
|
80
|
-
const error = ex;
|
|
81
|
-
console.log(`DomainConfig root file not found using proxy [${domain}] [${error.code}]`);
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
async fetch(networkSlug) {
|
|
85
|
-
await this.fetchAliases(networkSlug);
|
|
86
|
-
}
|
|
87
|
-
async fetchAliases(networkSlug) {
|
|
88
|
-
this.aliases = null;
|
|
89
|
-
const archivistUri = await this.findArchivistUri(networkSlug);
|
|
90
|
-
if (this.payload().aliases) {
|
|
91
|
-
const fetchedAliases = await Promise.all(
|
|
92
|
-
Object.entries(this.payload().aliases ?? {}).map(([, alias]) => {
|
|
93
|
-
return this.fetchAlias(alias, { archivistUri });
|
|
94
|
-
})
|
|
95
|
-
);
|
|
96
|
-
this.aliases = fetchedAliases.filter((alias) => alias);
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
async fetchAlias(alias, huriOptions) {
|
|
100
|
-
const huri = new Huri(alias.huri, huriOptions);
|
|
101
|
-
const payload = await huri.fetch();
|
|
102
|
-
return payload ? { alias, huri, payload } : null;
|
|
103
|
-
}
|
|
104
|
-
async findArchivistUri(hash) {
|
|
105
|
-
return (await this.getNetwork(hash))?.nodes?.find((payload) => payload.type === "archivist" ? payload : void 0)?.uri;
|
|
106
|
-
}
|
|
107
|
-
async getNetwork(hash) {
|
|
108
|
-
return hash ? await PayloadHasher.find(this.payload().networks, hash) : this.payload().networks?.[0];
|
|
109
|
-
}
|
|
110
|
-
};
|
|
111
|
-
|
|
112
|
-
// src/Plugin.ts
|
|
113
|
-
var DomainPayloadPlugin = () => createPayloadPlugin({
|
|
114
|
-
schema: DomainSchema,
|
|
115
|
-
template: domainConfigTemplate,
|
|
116
|
-
wrap: (payload) => DomainPayloadWrapper.wrap(payload)
|
|
117
|
-
});
|
|
118
|
-
|
|
119
|
-
// src/index.ts
|
|
1
|
+
import { DomainPayloadPlugin } from "./Plugin";
|
|
2
|
+
export * from "./Payload";
|
|
3
|
+
export * from "./Schema";
|
|
4
|
+
export * from "./Template";
|
|
5
|
+
export * from "./Wrapper";
|
|
120
6
|
var src_default = DomainPayloadPlugin;
|
|
121
7
|
export {
|
|
122
8
|
DomainPayloadPlugin,
|
|
123
|
-
|
|
124
|
-
DomainSchema,
|
|
125
|
-
src_default as default,
|
|
126
|
-
domainConfigTemplate
|
|
9
|
+
src_default as default
|
|
127
10
|
};
|
|
128
11
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts"],"sourcesContent":["import { DomainPayloadPlugin } from './Plugin'\n\nexport * from './Payload'\nexport * from './Schema'\nexport * from './Template'\nexport * from './Wrapper'\n\nexport { DomainPayloadPlugin }\n\n// eslint-disable-next-line import/no-default-export\nexport default DomainPayloadPlugin\n"],"mappings":"AAAA,SAAS,2BAA2B;AAEpC,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AAKd,IAAO,cAAQ;","names":[]}
|