@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.
Files changed (69) hide show
  1. package/dist/browser/Payload.d.cts +19 -0
  2. package/dist/browser/Payload.d.cts.map +1 -0
  3. package/dist/browser/Plugin.d.cts +21 -0
  4. package/dist/browser/Plugin.d.cts.map +1 -0
  5. package/dist/browser/Plugin.js +4 -112
  6. package/dist/browser/Plugin.js.map +1 -1
  7. package/dist/browser/Schema.d.cts +3 -0
  8. package/dist/browser/Schema.d.cts.map +1 -0
  9. package/dist/browser/Schema.js +1 -2
  10. package/dist/browser/Schema.js.map +1 -1
  11. package/dist/browser/Template.d.cts +3 -0
  12. package/dist/browser/Template.d.cts.map +1 -0
  13. package/dist/browser/Template.js +2 -5
  14. package/dist/browser/Template.js.map +1 -1
  15. package/dist/browser/Wrapper.d.cts +115 -0
  16. package/dist/browser/Wrapper.d.cts.map +1 -0
  17. package/dist/browser/Wrapper.js +5 -6
  18. package/dist/browser/Wrapper.js.map +1 -1
  19. package/dist/browser/index.d.cts +8 -0
  20. package/dist/browser/index.d.cts.map +1 -0
  21. package/dist/browser/index.js +6 -123
  22. package/dist/browser/index.js.map +1 -1
  23. package/dist/browser/schemadef.cjs +122 -0
  24. package/dist/browser/schemadef.cjs.map +1 -0
  25. package/dist/browser/schemadef.js +129 -0
  26. package/dist/browser/schemadef.js.map +1 -0
  27. package/dist/docs.json +11936 -0
  28. package/dist/node/Payload.d.cts +19 -0
  29. package/dist/node/Payload.d.cts.map +1 -0
  30. package/dist/node/Payload.js +2 -0
  31. package/dist/node/Payload.js.map +1 -1
  32. package/dist/node/Plugin.d.cts +21 -0
  33. package/dist/node/Plugin.d.cts.map +1 -0
  34. package/dist/node/Plugin.js +119 -7
  35. package/dist/node/Plugin.js.map +1 -1
  36. package/dist/node/Plugin.mjs +115 -4
  37. package/dist/node/Plugin.mjs.map +1 -1
  38. package/dist/node/Schema.d.cts +3 -0
  39. package/dist/node/Schema.d.cts.map +1 -0
  40. package/dist/node/Schema.js +3 -1
  41. package/dist/node/Schema.js.map +1 -1
  42. package/dist/node/Schema.mjs +2 -1
  43. package/dist/node/Schema.mjs.map +1 -1
  44. package/dist/node/Template.d.cts +3 -0
  45. package/dist/node/Template.d.cts.map +1 -0
  46. package/dist/node/Template.js +9 -3
  47. package/dist/node/Template.js.map +1 -1
  48. package/dist/node/Template.mjs +5 -2
  49. package/dist/node/Template.mjs.map +1 -1
  50. package/dist/node/Wrapper.d.cts +115 -0
  51. package/dist/node/Wrapper.d.cts.map +1 -0
  52. package/dist/node/Wrapper.js +13 -8
  53. package/dist/node/Wrapper.js.map +1 -1
  54. package/dist/node/Wrapper.mjs +12 -8
  55. package/dist/node/Wrapper.mjs.map +1 -1
  56. package/dist/node/index.d.cts +8 -0
  57. package/dist/node/index.d.cts.map +1 -0
  58. package/dist/node/index.js +134 -13
  59. package/dist/node/index.js.map +1 -1
  60. package/dist/node/index.mjs +126 -6
  61. package/dist/node/index.mjs.map +1 -1
  62. package/dist/node/schemadef.js +130 -0
  63. package/dist/node/schemadef.js.map +1 -0
  64. package/dist/node/schemadef.mjs +130 -0
  65. package/dist/node/schemadef.mjs.map +1 -0
  66. package/package.json +14 -14
  67. package/dist/node/schema.json +0 -115
  68. package/src/schema.json +0 -115
  69. /package/{dist/browser/schema.json → src/schemadef.json} +0 -0
@@ -16,6 +16,8 @@ var __copyProps = (to, from, except, desc) => {
16
16
  return to;
17
17
  };
18
18
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/Wrapper.ts
19
21
  var Wrapper_exports = {};
20
22
  __export(Wrapper_exports, {
21
23
  DomainPayloadWrapper: () => DomainPayloadWrapper
@@ -27,7 +29,7 @@ var import_core = require("@xyo-network/core");
27
29
  var import_dns = require("@xyo-network/dns");
28
30
  var import_huri = require("@xyo-network/huri");
29
31
  var import_payload_wrapper = require("@xyo-network/payload-wrapper");
30
- class DomainPayloadWrapper extends import_payload_wrapper.PayloadWrapper {
32
+ var DomainPayloadWrapper = class _DomainPayloadWrapper extends import_payload_wrapper.PayloadWrapper {
31
33
  aliases;
32
34
  static async discover(reverseDomainName, proxy) {
33
35
  const parts = reverseDomainName.split(".");
@@ -37,13 +39,14 @@ class DomainPayloadWrapper extends import_payload_wrapper.PayloadWrapper {
37
39
  }
38
40
  }
39
41
  static async discoverDNSEntry(domain) {
42
+ var _a, _b, _c;
40
43
  try {
41
- const hash = (await (0, import_dns.domainResolve)(`_xyo.${domain}`, import_dns.DnsRecordType.TXT))?.Answer?.[0]?.data;
44
+ const hash = (_c = (_b = (_a = await (0, import_dns.domainResolve)(`_xyo.${domain}`, import_dns.DnsRecordType.TXT)) == null ? void 0 : _a.Answer) == null ? void 0 : _b[0]) == null ? void 0 : _c.data;
42
45
  if (hash) {
43
46
  const huri = new import_huri.Huri(hash);
44
47
  const payload = await huri.fetch();
45
48
  if (payload) {
46
- return new DomainPayloadWrapper(payload);
49
+ return new _DomainPayloadWrapper(payload);
47
50
  }
48
51
  }
49
52
  } catch (ex) {
@@ -56,7 +59,7 @@ class DomainPayloadWrapper extends import_payload_wrapper.PayloadWrapper {
56
59
  static async discoverRootFileDirect(domain) {
57
60
  try {
58
61
  const config = (await import_axios.axios.get(`https://${domain}/xyo-config.json`)).data;
59
- return new DomainPayloadWrapper(config);
62
+ return new _DomainPayloadWrapper(config);
60
63
  } catch (ex) {
61
64
  console.log(`DomainConfig root file not found [${domain}]`);
62
65
  }
@@ -65,7 +68,7 @@ class DomainPayloadWrapper extends import_payload_wrapper.PayloadWrapper {
65
68
  try {
66
69
  const requestUrl = `${proxy}/${domain.split(".").reverse().join(".")}`;
67
70
  const config = (await import_axios.axios.get(requestUrl)).data.data;
68
- return new DomainPayloadWrapper(config);
71
+ return new _DomainPayloadWrapper(config);
69
72
  } catch (ex) {
70
73
  const error = ex;
71
74
  console.log(`DomainConfig root file not found using proxy [${domain}] [${error.code}]`);
@@ -92,12 +95,14 @@ class DomainPayloadWrapper extends import_payload_wrapper.PayloadWrapper {
92
95
  return payload ? { alias, huri, payload } : null;
93
96
  }
94
97
  async findArchivistUri(hash) {
95
- return (await this.getNetwork(hash))?.nodes?.find((payload) => payload.type === "archivist" ? payload : void 0)?.uri;
98
+ var _a, _b, _c;
99
+ return (_c = (_b = (_a = await this.getNetwork(hash)) == null ? void 0 : _a.nodes) == null ? void 0 : _b.find((payload) => payload.type === "archivist" ? payload : void 0)) == null ? void 0 : _c.uri;
96
100
  }
97
101
  async getNetwork(hash) {
98
- return hash ? await import_core.PayloadHasher.find(this.payload().networks, hash) : this.payload().networks?.[0];
102
+ var _a;
103
+ return hash ? await import_core.PayloadHasher.find(this.payload().networks, hash) : (_a = this.payload().networks) == null ? void 0 : _a[0];
99
104
  }
100
- }
105
+ };
101
106
  // Annotate the CommonJS export names for ESM import in node:
102
107
  0 && (module.exports = {
103
108
  DomainPayloadWrapper
@@ -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":"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","names":[]}
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":[]}
@@ -1,10 +1,11 @@
1
+ // src/Wrapper.ts
1
2
  import { reverse } from "@xylabs/lodash";
2
3
  import { axios } from "@xyo-network/axios";
3
4
  import { isBrowser, PayloadHasher } from "@xyo-network/core";
4
5
  import { DnsRecordType, domainResolve } from "@xyo-network/dns";
5
6
  import { Huri } from "@xyo-network/huri";
6
7
  import { PayloadWrapper } from "@xyo-network/payload-wrapper";
7
- class DomainPayloadWrapper extends PayloadWrapper {
8
+ var DomainPayloadWrapper = class _DomainPayloadWrapper extends PayloadWrapper {
8
9
  aliases;
9
10
  static async discover(reverseDomainName, proxy) {
10
11
  const parts = reverseDomainName.split(".");
@@ -14,13 +15,14 @@ class DomainPayloadWrapper extends PayloadWrapper {
14
15
  }
15
16
  }
16
17
  static async discoverDNSEntry(domain) {
18
+ var _a, _b, _c;
17
19
  try {
18
- const hash = (await domainResolve(`_xyo.${domain}`, DnsRecordType.TXT))?.Answer?.[0]?.data;
20
+ const hash = (_c = (_b = (_a = await domainResolve(`_xyo.${domain}`, DnsRecordType.TXT)) == null ? void 0 : _a.Answer) == null ? void 0 : _b[0]) == null ? void 0 : _c.data;
19
21
  if (hash) {
20
22
  const huri = new Huri(hash);
21
23
  const payload = await huri.fetch();
22
24
  if (payload) {
23
- return new DomainPayloadWrapper(payload);
25
+ return new _DomainPayloadWrapper(payload);
24
26
  }
25
27
  }
26
28
  } catch (ex) {
@@ -33,7 +35,7 @@ class DomainPayloadWrapper extends PayloadWrapper {
33
35
  static async discoverRootFileDirect(domain) {
34
36
  try {
35
37
  const config = (await axios.get(`https://${domain}/xyo-config.json`)).data;
36
- return new DomainPayloadWrapper(config);
38
+ return new _DomainPayloadWrapper(config);
37
39
  } catch (ex) {
38
40
  console.log(`DomainConfig root file not found [${domain}]`);
39
41
  }
@@ -42,7 +44,7 @@ class DomainPayloadWrapper extends PayloadWrapper {
42
44
  try {
43
45
  const requestUrl = `${proxy}/${domain.split(".").reverse().join(".")}`;
44
46
  const config = (await axios.get(requestUrl)).data.data;
45
- return new DomainPayloadWrapper(config);
47
+ return new _DomainPayloadWrapper(config);
46
48
  } catch (ex) {
47
49
  const error = ex;
48
50
  console.log(`DomainConfig root file not found using proxy [${domain}] [${error.code}]`);
@@ -69,12 +71,14 @@ class DomainPayloadWrapper extends PayloadWrapper {
69
71
  return payload ? { alias, huri, payload } : null;
70
72
  }
71
73
  async findArchivistUri(hash) {
72
- return (await this.getNetwork(hash))?.nodes?.find((payload) => payload.type === "archivist" ? payload : void 0)?.uri;
74
+ var _a, _b, _c;
75
+ return (_c = (_b = (_a = await this.getNetwork(hash)) == null ? void 0 : _a.nodes) == null ? void 0 : _b.find((payload) => payload.type === "archivist" ? payload : void 0)) == null ? void 0 : _c.uri;
73
76
  }
74
77
  async getNetwork(hash) {
75
- return hash ? await PayloadHasher.find(this.payload().networks, hash) : this.payload().networks?.[0];
78
+ var _a;
79
+ return hash ? await PayloadHasher.find(this.payload().networks, hash) : (_a = this.payload().networks) == null ? void 0 : _a[0];
76
80
  }
77
- }
81
+ };
78
82
  export {
79
83
  DomainPayloadWrapper
80
84
  };
@@ -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":"AAAA,SAAS,eAAe;AAExB,SAAS,aAAyB;AAClC,SAAS,WAAW,qBAAqB;AACzC,SAAS,eAAe,qBAAqB;AAC7C,SAAyB,YAAyB;AAElD,SAAS,sBAAsB;AAQxB,MAAM,6BAAsE,eAAkB;AAAA,EACnG;AAAA,EAEA,aAAa,SAAS,mBAA2B,OAAgB;AAC/D,UAAM,QAAQ,kBAAkB,MAAM,GAAG;AACzC,aAAS,IAAI,GAAG,KAAK,MAAM,QAAQ,KAAK;AACtC,YAAM,gBAAgB,QAAQ,MAAM,OAAO,CAAC,GAAG,UAAU,QAAQ,CAAC,CAAC,EAAE,KAAK,GAAG;AAC7E,aAAQ,MAAM,KAAK,iBAAiB,aAAa,KAAO,MAAM,KAAK,iBAAiB,eAAe,KAAK;AAAA,IAC1G;AAAA,EACF;AAAA,EAEA,aAAa,iBAAiB,QAAgB;AAC5C,QAAI;AACF,YAAM,QAAQ,MAAM,cAAc,QAAQ,MAAM,IAAI,cAAc,GAAG,IAAI,SAAS,CAAC,GAAG;AACtF,UAAI,MAAM;AACR,cAAM,OAAO,IAAI,KAAK,IAAI;AAC1B,cAAM,UAAW,MAAM,KAAK,MAAM;AAClC,YAAI,SAAS;AACX,iBAAO,IAAI,qBAAqB,OAAO;AAAA,QACzC;AAAA,MACF;AAAA,IACF,SAAS,IAAI;AACX,cAAQ,IAAI,mDAAmD,MAAM,GAAG;AAAA,IAC1E;AAAA,EACF;AAAA,EAEA,aAAa,iBAAiB,QAAgB,OAAgB;AAC5D,WAAO,UAAU,KAAK,QAAQ,MAAM,KAAK,0BAA0B,QAAQ,KAAK,IAAI,MAAM,KAAK,uBAAuB,MAAM;AAAA,EAC9H;AAAA,EAEA,aAAa,uBAAuB,QAAgB;AAClD,QAAI;AACF,YAAM,UAAU,MAAM,MAAM,IAAmB,WAAW,MAAM,kBAAkB,GAAG;AACrF,aAAO,IAAI,qBAAqB,MAAM;AAAA,IACxC,SAAS,IAAI;AACX,cAAQ,IAAI,qCAAqC,MAAM,GAAG;AAAA,IAC5D;AAAA,EACF;AAAA,EAEA,aAAa,0BAA0B,QAAgB,QAAQ,4CAA4C;AACzG,QAAI;AACF,YAAM,aAAa,GAAG,KAAK,IAAI,OAAO,MAAM,GAAG,EAAE,QAAQ,EAAE,KAAK,GAAG,CAAC;AACpE,YAAM,UAAU,MAAM,MAAM,IAAgC,UAAU,GAAG,KAAK;AAC9E,aAAO,IAAI,qBAAqB,MAAM;AAAA,IACxC,SAAS,IAAI;AACX,YAAM,QAAQ;AACd,cAAQ,IAAI,iDAAiD,MAAM,MAAM,MAAM,IAAI,GAAG;AAAA,IACxF;AAAA,EACF;AAAA,EAEA,MAAM,MAAM,aAAsB;AAChC,UAAM,KAAK,aAAa,WAAW;AAAA,EACrC;AAAA,EAEA,MAAM,aAAa,aAAsB;AAEvC,SAAK,UAAU;AAEf,UAAM,eAAe,MAAM,KAAK,iBAAiB,WAAW;AAC5D,QAAI,KAAK,QAAQ,EAAE,SAAS;AAC1B,YAAM,iBAAiB,MAAM,QAAQ;AAAA,QACnC,OAAO,QAAQ,KAAK,QAAQ,EAAE,WAAW,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,EAAE,KAAK,MAAM;AAC9D,iBAAO,KAAK,WAAW,OAAO,EAAE,aAAa,CAAC;AAAA,QAChD,CAAC;AAAA,MACH;AAEA,WAAK,UAAU,eAAe,OAAO,CAAC,UAAU,KAAK;AAAA,IACvD;AAAA,EACF;AAAA,EAEA,MAAc,WAAW,OAAc,aAAyD;AAC9F,UAAM,OAAO,IAAI,KAAK,MAAM,MAAM,WAAW;AAC7C,UAAM,UAAU,MAAM,KAAK,MAAM;AACjC,WAAO,UAAU,EAAE,OAAO,MAAM,QAAiB,IAAI;AAAA,EACvD;AAAA,EAEA,MAAc,iBAAiB,MAA4C;AACzE,YAAQ,MAAM,KAAK,WAAW,IAAI,IAAI,OAAO,KAAK,CAAC,YAAa,QAAQ,SAAS,cAAc,UAAU,MAAU,GAAG;AAAA,EACxH;AAAA,EAEA,MAAc,WAAW,MAAoD;AAC3E,WAAO,OAAO,MAAM,cAAc,KAAK,KAAK,QAAQ,EAAE,UAAU,IAAI,IAAI,KAAK,QAAQ,EAAE,WAAW,CAAC;AAAA,EACrG;AACF;","names":[]}
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"}
@@ -15,26 +15,147 @@ var __copyProps = (to, from, except, desc) => {
15
15
  }
16
16
  return to;
17
17
  };
18
- var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
19
18
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/index.ts
20
21
  var src_exports = {};
21
22
  __export(src_exports, {
22
- DomainPayloadPlugin: () => import_Plugin.DomainPayloadPlugin,
23
- default: () => src_default
23
+ DomainPayloadPlugin: () => DomainPayloadPlugin,
24
+ DomainPayloadWrapper: () => DomainPayloadWrapper,
25
+ DomainSchema: () => DomainSchema,
26
+ default: () => src_default,
27
+ domainConfigTemplate: () => domainConfigTemplate
24
28
  });
25
29
  module.exports = __toCommonJS(src_exports);
26
- var import_Plugin = require("./Plugin");
27
- __reExport(src_exports, require("./Payload"), module.exports);
28
- __reExport(src_exports, require("./Schema"), module.exports);
29
- __reExport(src_exports, require("./Template"), module.exports);
30
- __reExport(src_exports, require("./Wrapper"), module.exports);
31
- var src_default = import_Plugin.DomainPayloadPlugin;
30
+
31
+ // src/Plugin.ts
32
+ var import_payload_plugin = require("@xyo-network/payload-plugin");
33
+
34
+ // src/Schema.ts
35
+ var DomainSchema = "network.xyo.domain";
36
+
37
+ // src/Template.ts
38
+ var domainConfigTemplate = () => ({
39
+ aliases: {
40
+ "com.example.id": {
41
+ huri: ""
42
+ }
43
+ },
44
+ networks: [
45
+ {
46
+ name: "",
47
+ nodes: [
48
+ {
49
+ name: "",
50
+ schema: "network.xyo.network.node",
51
+ slug: "",
52
+ type: "archivist",
53
+ uri: ""
54
+ }
55
+ ],
56
+ schema: "network.xyo.network",
57
+ slug: ""
58
+ }
59
+ ],
60
+ schema: DomainSchema
61
+ });
62
+
63
+ // src/Wrapper.ts
64
+ var import_lodash = require("@xylabs/lodash");
65
+ var import_axios = require("@xyo-network/axios");
66
+ var import_core = require("@xyo-network/core");
67
+ var import_dns = require("@xyo-network/dns");
68
+ var import_huri = require("@xyo-network/huri");
69
+ var import_payload_wrapper = require("@xyo-network/payload-wrapper");
70
+ var DomainPayloadWrapper = class _DomainPayloadWrapper extends import_payload_wrapper.PayloadWrapper {
71
+ aliases;
72
+ static async discover(reverseDomainName, proxy) {
73
+ const parts = reverseDomainName.split(".");
74
+ for (let i = 2; i <= parts.length; i++) {
75
+ const domainToCheck = (0, import_lodash.reverse)(parts.filter((_, index) => index < i)).join(".");
76
+ return await this.discoverDNSEntry(domainToCheck) ?? await this.discoverRootFile(domainToCheck, proxy);
77
+ }
78
+ }
79
+ static async discoverDNSEntry(domain) {
80
+ var _a, _b, _c;
81
+ try {
82
+ const hash = (_c = (_b = (_a = await (0, import_dns.domainResolve)(`_xyo.${domain}`, import_dns.DnsRecordType.TXT)) == null ? void 0 : _a.Answer) == null ? void 0 : _b[0]) == null ? void 0 : _c.data;
83
+ if (hash) {
84
+ const huri = new import_huri.Huri(hash);
85
+ const payload = await huri.fetch();
86
+ if (payload) {
87
+ return new _DomainPayloadWrapper(payload);
88
+ }
89
+ }
90
+ } catch (ex) {
91
+ console.log(`DomainConfig dns reading error entry not found [${domain}]`);
92
+ }
93
+ }
94
+ static async discoverRootFile(domain, proxy) {
95
+ return (0, import_core.isBrowser)() || proxy ? await this.discoverRootFileWithProxy(domain, proxy) : await this.discoverRootFileDirect(domain);
96
+ }
97
+ static async discoverRootFileDirect(domain) {
98
+ try {
99
+ const config = (await import_axios.axios.get(`https://${domain}/xyo-config.json`)).data;
100
+ return new _DomainPayloadWrapper(config);
101
+ } catch (ex) {
102
+ console.log(`DomainConfig root file not found [${domain}]`);
103
+ }
104
+ }
105
+ static async discoverRootFileWithProxy(domain, proxy = "https://api.archivist.xyo.network/domain") {
106
+ try {
107
+ const requestUrl = `${proxy}/${domain.split(".").reverse().join(".")}`;
108
+ const config = (await import_axios.axios.get(requestUrl)).data.data;
109
+ return new _DomainPayloadWrapper(config);
110
+ } catch (ex) {
111
+ const error = ex;
112
+ console.log(`DomainConfig root file not found using proxy [${domain}] [${error.code}]`);
113
+ }
114
+ }
115
+ async fetch(networkSlug) {
116
+ await this.fetchAliases(networkSlug);
117
+ }
118
+ async fetchAliases(networkSlug) {
119
+ this.aliases = null;
120
+ const archivistUri = await this.findArchivistUri(networkSlug);
121
+ if (this.payload().aliases) {
122
+ const fetchedAliases = await Promise.all(
123
+ Object.entries(this.payload().aliases ?? {}).map(([, alias]) => {
124
+ return this.fetchAlias(alias, { archivistUri });
125
+ })
126
+ );
127
+ this.aliases = fetchedAliases.filter((alias) => alias);
128
+ }
129
+ }
130
+ async fetchAlias(alias, huriOptions) {
131
+ const huri = new import_huri.Huri(alias.huri, huriOptions);
132
+ const payload = await huri.fetch();
133
+ return payload ? { alias, huri, payload } : null;
134
+ }
135
+ async findArchivistUri(hash) {
136
+ var _a, _b, _c;
137
+ return (_c = (_b = (_a = await this.getNetwork(hash)) == null ? void 0 : _a.nodes) == null ? void 0 : _b.find((payload) => payload.type === "archivist" ? payload : void 0)) == null ? void 0 : _c.uri;
138
+ }
139
+ async getNetwork(hash) {
140
+ var _a;
141
+ return hash ? await import_core.PayloadHasher.find(this.payload().networks, hash) : (_a = this.payload().networks) == null ? void 0 : _a[0];
142
+ }
143
+ };
144
+
145
+ // src/Plugin.ts
146
+ var DomainPayloadPlugin = () => (0, import_payload_plugin.createPayloadPlugin)({
147
+ schema: DomainSchema,
148
+ template: domainConfigTemplate,
149
+ wrap: (payload) => DomainPayloadWrapper.wrap(payload)
150
+ });
151
+
152
+ // src/index.ts
153
+ var src_default = DomainPayloadPlugin;
32
154
  // Annotate the CommonJS export names for ESM import in node:
33
155
  0 && (module.exports = {
34
156
  DomainPayloadPlugin,
35
- ...require("./Payload"),
36
- ...require("./Schema"),
37
- ...require("./Template"),
38
- ...require("./Wrapper")
157
+ DomainPayloadWrapper,
158
+ DomainSchema,
159
+ domainConfigTemplate
39
160
  });
40
161
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
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;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAAoC;AAEpC,wBAAc,sBAFd;AAGA,wBAAc,qBAHd;AAIA,wBAAc,uBAJd;AAKA,wBAAc,sBALd;AAUA,IAAO,cAAQ;","names":[]}
1
+ {"version":3,"sources":["../../src/index.ts","../../src/Plugin.ts","../../src/Schema.ts","../../src/Template.ts","../../src/Wrapper.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","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","export type DomainSchema = 'network.xyo.domain'\nexport const DomainSchema: DomainSchema = 'network.xyo.domain'\n","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","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":[]}
@@ -1,11 +1,131 @@
1
- import { DomainPayloadPlugin } from "./Plugin";
2
- export * from "./Payload";
3
- export * from "./Schema";
4
- export * from "./Template";
5
- export * from "./Wrapper";
1
+ // src/Plugin.ts
2
+ import { createPayloadPlugin } from "@xyo-network/payload-plugin";
3
+
4
+ // src/Schema.ts
5
+ var DomainSchema = "network.xyo.domain";
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
+ var _a, _b, _c;
51
+ try {
52
+ const hash = (_c = (_b = (_a = await domainResolve(`_xyo.${domain}`, DnsRecordType.TXT)) == null ? void 0 : _a.Answer) == null ? void 0 : _b[0]) == null ? void 0 : _c.data;
53
+ if (hash) {
54
+ const huri = new Huri(hash);
55
+ const payload = await huri.fetch();
56
+ if (payload) {
57
+ return new _DomainPayloadWrapper(payload);
58
+ }
59
+ }
60
+ } catch (ex) {
61
+ console.log(`DomainConfig dns reading error entry not found [${domain}]`);
62
+ }
63
+ }
64
+ static async discoverRootFile(domain, proxy) {
65
+ return isBrowser() || proxy ? await this.discoverRootFileWithProxy(domain, proxy) : await this.discoverRootFileDirect(domain);
66
+ }
67
+ static async discoverRootFileDirect(domain) {
68
+ try {
69
+ const config = (await axios.get(`https://${domain}/xyo-config.json`)).data;
70
+ return new _DomainPayloadWrapper(config);
71
+ } catch (ex) {
72
+ console.log(`DomainConfig root file not found [${domain}]`);
73
+ }
74
+ }
75
+ static async discoverRootFileWithProxy(domain, proxy = "https://api.archivist.xyo.network/domain") {
76
+ try {
77
+ const requestUrl = `${proxy}/${domain.split(".").reverse().join(".")}`;
78
+ const config = (await axios.get(requestUrl)).data.data;
79
+ return new _DomainPayloadWrapper(config);
80
+ } catch (ex) {
81
+ const error = ex;
82
+ console.log(`DomainConfig root file not found using proxy [${domain}] [${error.code}]`);
83
+ }
84
+ }
85
+ async fetch(networkSlug) {
86
+ await this.fetchAliases(networkSlug);
87
+ }
88
+ async fetchAliases(networkSlug) {
89
+ this.aliases = null;
90
+ const archivistUri = await this.findArchivistUri(networkSlug);
91
+ if (this.payload().aliases) {
92
+ const fetchedAliases = await Promise.all(
93
+ Object.entries(this.payload().aliases ?? {}).map(([, alias]) => {
94
+ return this.fetchAlias(alias, { archivistUri });
95
+ })
96
+ );
97
+ this.aliases = fetchedAliases.filter((alias) => alias);
98
+ }
99
+ }
100
+ async fetchAlias(alias, huriOptions) {
101
+ const huri = new Huri(alias.huri, huriOptions);
102
+ const payload = await huri.fetch();
103
+ return payload ? { alias, huri, payload } : null;
104
+ }
105
+ async findArchivistUri(hash) {
106
+ var _a, _b, _c;
107
+ return (_c = (_b = (_a = await this.getNetwork(hash)) == null ? void 0 : _a.nodes) == null ? void 0 : _b.find((payload) => payload.type === "archivist" ? payload : void 0)) == null ? void 0 : _c.uri;
108
+ }
109
+ async getNetwork(hash) {
110
+ var _a;
111
+ return hash ? await PayloadHasher.find(this.payload().networks, hash) : (_a = this.payload().networks) == null ? void 0 : _a[0];
112
+ }
113
+ };
114
+
115
+ // src/Plugin.ts
116
+ var DomainPayloadPlugin = () => createPayloadPlugin({
117
+ schema: DomainSchema,
118
+ template: domainConfigTemplate,
119
+ wrap: (payload) => DomainPayloadWrapper.wrap(payload)
120
+ });
121
+
122
+ // src/index.ts
6
123
  var src_default = DomainPayloadPlugin;
7
124
  export {
8
125
  DomainPayloadPlugin,
9
- src_default as default
126
+ DomainPayloadWrapper,
127
+ DomainSchema,
128
+ src_default as default,
129
+ domainConfigTemplate
10
130
  };
11
131
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
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":[]}
1
+ {"version":3,"sources":["../../src/Plugin.ts","../../src/Schema.ts","../../src/Template.ts","../../src/Wrapper.ts","../../src/index.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","export type DomainSchema = 'network.xyo.domain'\nexport const DomainSchema: DomainSchema = 'network.xyo.domain'\n","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","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","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":";AACA,SAAS,2BAA2B;;;ACA7B,IAAM,eAA6B;;;ACEnC,IAAM,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;;;AC1BA,SAAS,eAAe;AAExB,SAAS,aAAyB;AAClC,SAAS,WAAW,qBAAqB;AACzC,SAAS,eAAe,qBAAqB;AAC7C,SAAyB,YAAyB;AAElD,SAAS,sBAAsB;AAQxB,IAAM,uBAAN,MAAM,8BAAsE,eAAkB;AAAA,EACnG;AAAA,EAEA,aAAa,SAAS,mBAA2B,OAAgB;AAC/D,UAAM,QAAQ,kBAAkB,MAAM,GAAG;AACzC,aAAS,IAAI,GAAG,KAAK,MAAM,QAAQ,KAAK;AACtC,YAAM,gBAAgB,QAAQ,MAAM,OAAO,CAAC,GAAG,UAAU,QAAQ,CAAC,CAAC,EAAE,KAAK,GAAG;AAC7E,aAAQ,MAAM,KAAK,iBAAiB,aAAa,KAAO,MAAM,KAAK,iBAAiB,eAAe,KAAK;AAAA,IAC1G;AAAA,EACF;AAAA,EAEA,aAAa,iBAAiB,QAAgB;AA1BhD;AA2BI,QAAI;AACF,YAAM,QAAQ,uBAAM,cAAc,QAAQ,MAAM,IAAI,cAAc,GAAG,MAAvD,mBAA2D,WAA3D,mBAAoE,OAApE,mBAAwE;AACtF,UAAI,MAAM;AACR,cAAM,OAAO,IAAI,KAAK,IAAI;AAC1B,cAAM,UAAW,MAAM,KAAK,MAAM;AAClC,YAAI,SAAS;AACX,iBAAO,IAAI,sBAAqB,OAAO;AAAA,QACzC;AAAA,MACF;AAAA,IACF,SAAS,IAAI;AACX,cAAQ,IAAI,mDAAmD,MAAM,GAAG;AAAA,IAC1E;AAAA,EACF;AAAA,EAEA,aAAa,iBAAiB,QAAgB,OAAgB;AAC5D,WAAO,UAAU,KAAK,QAAQ,MAAM,KAAK,0BAA0B,QAAQ,KAAK,IAAI,MAAM,KAAK,uBAAuB,MAAM;AAAA,EAC9H;AAAA,EAEA,aAAa,uBAAuB,QAAgB;AAClD,QAAI;AACF,YAAM,UAAU,MAAM,MAAM,IAAmB,WAAW,MAAM,kBAAkB,GAAG;AACrF,aAAO,IAAI,sBAAqB,MAAM;AAAA,IACxC,SAAS,IAAI;AACX,cAAQ,IAAI,qCAAqC,MAAM,GAAG;AAAA,IAC5D;AAAA,EACF;AAAA,EAEA,aAAa,0BAA0B,QAAgB,QAAQ,4CAA4C;AACzG,QAAI;AACF,YAAM,aAAa,GAAG,KAAK,IAAI,OAAO,MAAM,GAAG,EAAE,QAAQ,EAAE,KAAK,GAAG,CAAC;AACpE,YAAM,UAAU,MAAM,MAAM,IAAgC,UAAU,GAAG,KAAK;AAC9E,aAAO,IAAI,sBAAqB,MAAM;AAAA,IACxC,SAAS,IAAI;AACX,YAAM,QAAQ;AACd,cAAQ,IAAI,iDAAiD,MAAM,MAAM,MAAM,IAAI,GAAG;AAAA,IACxF;AAAA,EACF;AAAA,EAEA,MAAM,MAAM,aAAsB;AAChC,UAAM,KAAK,aAAa,WAAW;AAAA,EACrC;AAAA,EAEA,MAAM,aAAa,aAAsB;AAEvC,SAAK,UAAU;AAEf,UAAM,eAAe,MAAM,KAAK,iBAAiB,WAAW;AAC5D,QAAI,KAAK,QAAQ,EAAE,SAAS;AAC1B,YAAM,iBAAiB,MAAM,QAAQ;AAAA,QACnC,OAAO,QAAQ,KAAK,QAAQ,EAAE,WAAW,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,EAAE,KAAK,MAAM;AAC9D,iBAAO,KAAK,WAAW,OAAO,EAAE,aAAa,CAAC;AAAA,QAChD,CAAC;AAAA,MACH;AAEA,WAAK,UAAU,eAAe,OAAO,CAAC,UAAU,KAAK;AAAA,IACvD;AAAA,EACF;AAAA,EAEA,MAAc,WAAW,OAAc,aAAyD;AAC9F,UAAM,OAAO,IAAI,KAAK,MAAM,MAAM,WAAW;AAC7C,UAAM,UAAU,MAAM,KAAK,MAAM;AACjC,WAAO,UAAU,EAAE,OAAO,MAAM,QAAiB,IAAI;AAAA,EACvD;AAAA,EAEA,MAAc,iBAAiB,MAA4C;AA3F7E;AA4FI,YAAQ,uBAAM,KAAK,WAAW,IAAI,MAA1B,mBAA8B,UAA9B,mBAAqC,KAAK,CAAC,YAAa,QAAQ,SAAS,cAAc,UAAU,YAAjG,mBAA8G;AAAA,EACxH;AAAA,EAEA,MAAc,WAAW,MAAoD;AA/F/E;AAgGI,WAAO,OAAO,MAAM,cAAc,KAAK,KAAK,QAAQ,EAAE,UAAU,IAAI,KAAI,UAAK,QAAQ,EAAE,aAAf,mBAA0B;AAAA,EACpG;AACF;;;AH1FO,IAAM,sBAAsB,MACjC,oBAAmC;AAAA,EACjC,QAAQ;AAAA,EACR,UAAU;AAAA,EACV,MAAM,CAAC,YAAqB,qBAAqB,KAAK,OAAwB;AAChF,CAAC;;;AIHH,IAAO,cAAQ;","names":[]}