@xyo-network/witness-blockchain-abstract 3.6.8 → 3.6.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,10 +1,7 @@
1
- var __defProp = Object.defineProperty;
2
- var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
-
4
1
  // src/lib/checkIpfsUrl.ts
5
2
  import { assertEx } from "@xylabs/assert";
6
3
  var allowIpfsIoRepair = true;
7
- var checkIpfsUrl = /* @__PURE__ */ __name((urlToCheck, ipfsGateway) => {
4
+ var checkIpfsUrl = (urlToCheck, ipfsGateway) => {
8
5
  try {
9
6
  const url = new URL(urlToCheck);
10
7
  let protocol = url.protocol;
@@ -33,28 +30,33 @@ var checkIpfsUrl = /* @__PURE__ */ __name((urlToCheck, ipfsGateway) => {
33
30
  } catch {
34
31
  return urlToCheck;
35
32
  }
36
- }, "checkIpfsUrl");
33
+ };
37
34
 
38
35
  // src/lib/getProviderFromEnv.ts
39
36
  import { assertEx as assertEx2 } from "@xylabs/assert";
40
- import { InfuraProvider, InfuraWebSocketProvider, JsonRpcProvider, WebSocketProvider } from "ethers";
41
- var createInfuraRpc = /* @__PURE__ */ __name((chainId) => {
37
+ import {
38
+ InfuraProvider,
39
+ InfuraWebSocketProvider,
40
+ JsonRpcProvider,
41
+ WebSocketProvider
42
+ } from "ethers";
43
+ var createInfuraRpc = (chainId) => {
42
44
  return process.env.INFURA_PROJECT_ID && process.env.INFURA_PROJECT_SECRET ? new InfuraProvider(chainId, process.env.INFURA_PROJECT_ID) : void 0;
43
- }, "createInfuraRpc");
44
- var createInfuraWss = /* @__PURE__ */ __name((chainId) => {
45
+ };
46
+ var createInfuraWss = (chainId) => {
45
47
  return process.env.INFURA_PROJECT_ID ? new InfuraWebSocketProvider(chainId, process.env.INFURA_PROJECT_ID) : void 0;
46
- }, "createInfuraWss");
47
- var createQuicknodeWss = /* @__PURE__ */ __name((chainId) => {
48
+ };
49
+ var createQuicknodeWss = (chainId) => {
48
50
  const quickNodeWSSUri = process.env.QUICKNODE_WSS_URI;
49
51
  return quickNodeWSSUri ? new WebSocketProvider(quickNodeWSSUri, chainId) : void 0;
50
- }, "createQuicknodeWss");
51
- var createQuicknodeRpc = /* @__PURE__ */ __name((chainId) => {
52
+ };
53
+ var createQuicknodeRpc = (chainId) => {
52
54
  const quickNodeHttpsUri = process.env.QUICKNODE_HTTPS_URI;
53
55
  return quickNodeHttpsUri ? new JsonRpcProvider(quickNodeHttpsUri, chainId) : void 0;
54
- }, "createQuicknodeRpc");
55
- var getProviderFromEnv = /* @__PURE__ */ __name((chainId = 1, { providerSource = "infura", providerType = "rpc" } = {}) => {
56
+ };
57
+ var getProviderFromEnv = (chainId = 1, { providerSource = "infura", providerType = "rpc" } = {}) => {
56
58
  let provider = void 0;
57
- const quicknodeCases = /* @__PURE__ */ __name(() => {
59
+ const quicknodeCases = () => {
58
60
  switch (providerType) {
59
61
  case "rpc": {
60
62
  provider = createQuicknodeRpc(chainId);
@@ -65,8 +67,8 @@ var getProviderFromEnv = /* @__PURE__ */ __name((chainId = 1, { providerSource =
65
67
  break;
66
68
  }
67
69
  }
68
- }, "quicknodeCases");
69
- const infuraCases = /* @__PURE__ */ __name(() => {
70
+ };
71
+ const infuraCases = () => {
70
72
  switch (providerType) {
71
73
  case "wss": {
72
74
  provider = createInfuraWss(chainId);
@@ -77,7 +79,7 @@ var getProviderFromEnv = /* @__PURE__ */ __name((chainId = 1, { providerSource =
77
79
  break;
78
80
  }
79
81
  }
80
- }, "infuraCases");
82
+ };
81
83
  switch (providerSource) {
82
84
  case "quicknode": {
83
85
  quicknodeCases();
@@ -93,20 +95,20 @@ var getProviderFromEnv = /* @__PURE__ */ __name((chainId = 1, { providerSource =
93
95
  provider = createInfuraWss(chainId) ?? createInfuraRpc(chainId) ?? createQuicknodeRpc(chainId);
94
96
  }
95
97
  return assertEx2(provider, () => `Unable to create provider [${chainId}]: ${providerSource}|${providerType}`);
96
- }, "getProviderFromEnv");
98
+ };
97
99
  var providers = {};
98
- var getSharedProviderFromEnv = /* @__PURE__ */ __name((chainId = 1, options) => {
100
+ var getSharedProviderFromEnv = (chainId = 1, options) => {
99
101
  const key = `${chainId}:${options ? JSON.stringify(options) : "default"}`;
100
102
  providers[key] = providers[key] ?? getProviderFromEnv(chainId, options);
101
103
  return providers[key];
102
- }, "getSharedProviderFromEnv");
103
- var getProvidersFromEnv = /* @__PURE__ */ __name((count = 1, chainId = 1, options = {}) => {
104
+ };
105
+ var getProvidersFromEnv = (count = 1, chainId = 1, options = {}) => {
104
106
  const result = [];
105
107
  for (let i = 0; i < count; i++) {
106
108
  result.push(getProviderFromEnv(chainId, options));
107
109
  }
108
110
  return result;
109
- }, "getProvidersFromEnv");
111
+ };
110
112
 
111
113
  // src/model.ts
112
114
  var BlockchainAddressSchema = "network.xyo.blockchain.address";
@@ -115,9 +117,6 @@ var BlockchainAddressSchema = "network.xyo.blockchain.address";
115
117
  import { AbstractWitness } from "@xyo-network/abstract-witness";
116
118
  var BlockchainWitnessConfigSchema = "network.xyo.blockchain.witness";
117
119
  var AbstractBlockchainWitness = class extends AbstractWitness {
118
- static {
119
- __name(this, "AbstractBlockchainWitness");
120
- }
121
120
  _providers = void 0;
122
121
  async getProvider(cache = false, error) {
123
122
  const providers2 = await this.getProviders(cache);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/lib/checkIpfsUrl.ts","../../src/lib/getProviderFromEnv.ts","../../src/model.ts","../../src/Witness.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\n\nconst allowIpfsIoRepair = true\n\n/**\n * Returns the equivalent IPFS gateway URL for the supplied URL.\n * @param urlToCheck The URL to check\n * @returns If the supplied URL is an IPFS URL, it converts the URL to the\n * equivalent IPFS gateway URL. Otherwise, returns the original URL.\n */\nexport const checkIpfsUrl = (urlToCheck: string, ipfsGateway?: string): string => {\n try {\n const url = new URL(urlToCheck)\n let protocol = url.protocol\n let host = url.host\n let path = url.pathname\n const query = url.search\n if (protocol === 'ipfs:') {\n protocol = 'https:'\n host = assertEx(ipfsGateway, () => 'No ipfsGateway provided')\n path = url.host === 'ipfs' ? `ipfs${path}` : `ipfs/${url.host}${path}`\n const root = `${protocol}//${host}/${path}`\n return query?.length > 0 ? `${root}?${query}` : root\n } else if (allowIpfsIoRepair && protocol === 'https' && host === 'ipfs.io') {\n protocol = 'https:'\n host = assertEx(ipfsGateway, () => 'No ipfsGateway provided')\n const pathParts = path.split('/')\n if (pathParts[0] === 'ipfs') {\n pathParts.shift()\n }\n path = pathParts.join('/')\n const root = `${protocol}//${host}/${path}`\n return query?.length > 0 ? `${root}?${query}` : root\n } else {\n return urlToCheck\n }\n } catch {\n // const error = ex as Error\n // console.error(`${error.name}:${error.message} [${urlToCheck}]`)\n // console.log(error.stack)\n return urlToCheck\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport type { Provider } from 'ethers'\nimport {\n InfuraProvider, InfuraWebSocketProvider, JsonRpcProvider, WebSocketProvider,\n} from 'ethers'\n\nexport type ProviderSource = 'infura' | 'quicknode'\nexport type ProviderType = 'rpc' | 'wss'\n\nexport interface GetProvidersFromEnvOptions {\n providerSource?: ProviderSource\n providerType?: ProviderType\n}\n\nconst createInfuraRpc = (chainId: number) => {\n return process.env.INFURA_PROJECT_ID && process.env.INFURA_PROJECT_SECRET ? new InfuraProvider(chainId, process.env.INFURA_PROJECT_ID) : undefined\n}\n\nconst createInfuraWss = (chainId: number) => {\n return process.env.INFURA_PROJECT_ID ? new InfuraWebSocketProvider(chainId, process.env.INFURA_PROJECT_ID) : undefined\n}\n\nconst createQuicknodeWss = (chainId: number) => {\n const quickNodeWSSUri = process.env.QUICKNODE_WSS_URI\n return quickNodeWSSUri ? new WebSocketProvider(quickNodeWSSUri, chainId) : undefined\n}\n\nconst createQuicknodeRpc = (chainId: number) => {\n const quickNodeHttpsUri = process.env.QUICKNODE_HTTPS_URI\n return quickNodeHttpsUri ? new JsonRpcProvider(quickNodeHttpsUri, chainId) : undefined\n}\n\nexport const getProviderFromEnv = (\n chainId: number = 0x01,\n { providerSource = 'infura', providerType = 'rpc' }: GetProvidersFromEnvOptions = {},\n): Provider => {\n let provider: Provider | undefined = undefined\n\n const quicknodeCases = () => {\n switch (providerType) {\n case 'rpc': {\n provider = createQuicknodeRpc(chainId)\n break\n }\n case 'wss': {\n provider = createQuicknodeWss(chainId)\n break\n }\n }\n }\n\n const infuraCases = () => {\n switch (providerType) {\n case 'wss': {\n provider = createInfuraWss(chainId)\n break\n }\n case 'rpc': {\n provider = createInfuraRpc(chainId)\n break\n }\n }\n }\n\n switch (providerSource) {\n case 'quicknode': {\n quicknodeCases()\n break\n }\n default:\n case 'infura': {\n infuraCases()\n break\n }\n }\n if (!provider) {\n provider = createInfuraWss(chainId) ?? createInfuraRpc(chainId) ?? createQuicknodeRpc(chainId)\n }\n return assertEx(provider, () => `Unable to create provider [${chainId}]: ${providerSource}|${providerType}`)\n}\n\nconst providers: Record<string, Provider> = {}\n\nexport const getSharedProviderFromEnv = (\n chainId: number = 0x01,\n options?: { providerSource?: ProviderSource; providerType?: ProviderType },\n): Provider => {\n const key = `${chainId}:${options ? JSON.stringify(options) : 'default'}`\n providers[key] = providers[key] ?? getProviderFromEnv(chainId, options)\n return providers[key]\n}\n\nexport const getProvidersFromEnv = (count: number = 1, chainId: number = 0x01, options: GetProvidersFromEnvOptions = {}): Provider[] => {\n const result: Provider[] = []\n for (let i = 0; i < count; i++) {\n result.push(getProviderFromEnv(chainId, options))\n }\n return result\n}\n","import type { Payload } from '@xyo-network/payload-model'\n\n/** @deprecated use EvmAddressSchema version instead */\nexport const BlockchainAddressSchema = 'network.xyo.blockchain.address' as const\n\n/** @deprecated use EvmAddressSchema version instead */\nexport type BlockchainAddressSchema = typeof BlockchainAddressSchema\n\n/** @deprecated use EvmAddress version instead */\nexport type BlockchainAddress = Payload<\n {\n address?: string\n blockTag?: string | number\n chainId?: number\n },\n BlockchainAddressSchema\n>\n","import type { EmptyObject, WithAdditional } from '@xylabs/object'\nimport type { Promisable } from '@xylabs/promise'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport type { AnyConfigSchema } from '@xyo-network/module-model'\nimport type { Payload } from '@xyo-network/payload-model'\nimport type {\n WitnessConfig, WitnessInstance, WitnessModuleEventData, WitnessParams,\n} from '@xyo-network/witness-model'\nimport type { Provider } from 'ethers'\n\n/** @deprecated use EvmWitnessConfigSchema version instead */\nexport const BlockchainWitnessConfigSchema = 'network.xyo.blockchain.witness' as const\n/** @deprecated use EvmWitnessConfigSchema version instead */\nexport type BlockchainWitnessConfigSchema = typeof BlockchainWitnessConfigSchema\n\n/** @deprecated use EvmWitnessConfig version instead */\nexport type BlockchainWitnessConfig<TAdditional extends EmptyObject | Payload | void = void, TSchema extends string | void = void> = WitnessConfig<\n TAdditional,\n TSchema extends void ?\n TAdditional extends Payload ?\n TAdditional['schema']\n : BlockchainWitnessConfigSchema\n : TSchema\n>\n\n/** @deprecated use AdditionalEvmWitnessParams version instead */\nexport type AdditionalBlockchainWitnessParams = {\n providers: Provider[]\n}\n\n/** @deprecated use EvmWitnessParams version instead */\nexport type BlockchainWitnessParams<\n TConfig extends AnyConfigSchema<BlockchainWitnessConfig> = BlockchainWitnessConfig,\n TAdditionalParams extends EmptyObject | void = void,\n> = WitnessParams<\n TConfig,\n WithAdditional<\n {\n providers: () => Promisable<Provider[]>\n },\n TAdditionalParams\n >\n>\n\n/** @deprecated use AbstractEvmWitness version instead */\nexport abstract class AbstractBlockchainWitness<\n TParams extends BlockchainWitnessParams<AnyConfigSchema<BlockchainWitnessConfig>> = BlockchainWitnessParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut> = WitnessModuleEventData<\n WitnessInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends AbstractWitness<TParams, TIn, TOut, TEventData> {\n private _providers: Provider[] | undefined = undefined\n\n async getProvider(cache?: boolean): Promise<Provider | undefined>\n async getProvider(cache: boolean, error: string | true): Promise<Provider>\n async getProvider(cache = false, error?: string | boolean): Promise<Provider | undefined> {\n const providers = await this.getProviders(cache)\n if (providers.length === 0) {\n if (error) {\n throw new Error(typeof error === 'string' ? error : 'No providers available')\n }\n return undefined\n }\n return providers[Date.now() % providers.length] // pick a random provider\n }\n\n async getProviders(cache = false): Promise<Provider[]> {\n const cachedProviders = cache ? this._providers : undefined\n this._providers = cachedProviders ?? (await this.params.providers())\n return this._providers\n }\n}\n"],"mappings":"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","names":["assertEx","allowIpfsIoRepair","checkIpfsUrl","urlToCheck","ipfsGateway","url","URL","protocol","host","path","pathname","query","search","assertEx","root","length","pathParts","split","shift","join","assertEx","InfuraProvider","InfuraWebSocketProvider","JsonRpcProvider","WebSocketProvider","createInfuraRpc","chainId","process","env","INFURA_PROJECT_ID","INFURA_PROJECT_SECRET","InfuraProvider","undefined","createInfuraWss","InfuraWebSocketProvider","createQuicknodeWss","quickNodeWSSUri","QUICKNODE_WSS_URI","WebSocketProvider","createQuicknodeRpc","quickNodeHttpsUri","QUICKNODE_HTTPS_URI","JsonRpcProvider","getProviderFromEnv","providerSource","providerType","provider","quicknodeCases","infuraCases","assertEx","providers","getSharedProviderFromEnv","options","key","JSON","stringify","getProvidersFromEnv","count","result","i","push","BlockchainAddressSchema","AbstractWitness","BlockchainWitnessConfigSchema","AbstractBlockchainWitness","AbstractWitness","_providers","undefined","getProvider","cache","error","providers","getProviders","length","Error","Date","now","cachedProviders","params"]}
1
+ {"version":3,"sources":["../../src/lib/checkIpfsUrl.ts","../../src/lib/getProviderFromEnv.ts","../../src/model.ts","../../src/Witness.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\n\nconst allowIpfsIoRepair = true\n\n/**\n * Returns the equivalent IPFS gateway URL for the supplied URL.\n * @param urlToCheck The URL to check\n * @returns If the supplied URL is an IPFS URL, it converts the URL to the\n * equivalent IPFS gateway URL. Otherwise, returns the original URL.\n */\nexport const checkIpfsUrl = (urlToCheck: string, ipfsGateway?: string): string => {\n try {\n const url = new URL(urlToCheck)\n let protocol = url.protocol\n let host = url.host\n let path = url.pathname\n const query = url.search\n if (protocol === 'ipfs:') {\n protocol = 'https:'\n host = assertEx(ipfsGateway, () => 'No ipfsGateway provided')\n path = url.host === 'ipfs' ? `ipfs${path}` : `ipfs/${url.host}${path}`\n const root = `${protocol}//${host}/${path}`\n return query?.length > 0 ? `${root}?${query}` : root\n } else if (allowIpfsIoRepair && protocol === 'https' && host === 'ipfs.io') {\n protocol = 'https:'\n host = assertEx(ipfsGateway, () => 'No ipfsGateway provided')\n const pathParts = path.split('/')\n if (pathParts[0] === 'ipfs') {\n pathParts.shift()\n }\n path = pathParts.join('/')\n const root = `${protocol}//${host}/${path}`\n return query?.length > 0 ? `${root}?${query}` : root\n } else {\n return urlToCheck\n }\n } catch {\n // const error = ex as Error\n // console.error(`${error.name}:${error.message} [${urlToCheck}]`)\n // console.log(error.stack)\n return urlToCheck\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport type { Provider } from 'ethers'\nimport {\n InfuraProvider, InfuraWebSocketProvider, JsonRpcProvider, WebSocketProvider,\n} from 'ethers'\n\nexport type ProviderSource = 'infura' | 'quicknode'\nexport type ProviderType = 'rpc' | 'wss'\n\nexport interface GetProvidersFromEnvOptions {\n providerSource?: ProviderSource\n providerType?: ProviderType\n}\n\nconst createInfuraRpc = (chainId: number) => {\n return process.env.INFURA_PROJECT_ID && process.env.INFURA_PROJECT_SECRET ? new InfuraProvider(chainId, process.env.INFURA_PROJECT_ID) : undefined\n}\n\nconst createInfuraWss = (chainId: number) => {\n return process.env.INFURA_PROJECT_ID ? new InfuraWebSocketProvider(chainId, process.env.INFURA_PROJECT_ID) : undefined\n}\n\nconst createQuicknodeWss = (chainId: number) => {\n const quickNodeWSSUri = process.env.QUICKNODE_WSS_URI\n return quickNodeWSSUri ? new WebSocketProvider(quickNodeWSSUri, chainId) : undefined\n}\n\nconst createQuicknodeRpc = (chainId: number) => {\n const quickNodeHttpsUri = process.env.QUICKNODE_HTTPS_URI\n return quickNodeHttpsUri ? new JsonRpcProvider(quickNodeHttpsUri, chainId) : undefined\n}\n\nexport const getProviderFromEnv = (\n chainId: number = 0x01,\n { providerSource = 'infura', providerType = 'rpc' }: GetProvidersFromEnvOptions = {},\n): Provider => {\n let provider: Provider | undefined = undefined\n\n const quicknodeCases = () => {\n switch (providerType) {\n case 'rpc': {\n provider = createQuicknodeRpc(chainId)\n break\n }\n case 'wss': {\n provider = createQuicknodeWss(chainId)\n break\n }\n }\n }\n\n const infuraCases = () => {\n switch (providerType) {\n case 'wss': {\n provider = createInfuraWss(chainId)\n break\n }\n case 'rpc': {\n provider = createInfuraRpc(chainId)\n break\n }\n }\n }\n\n switch (providerSource) {\n case 'quicknode': {\n quicknodeCases()\n break\n }\n default:\n case 'infura': {\n infuraCases()\n break\n }\n }\n if (!provider) {\n provider = createInfuraWss(chainId) ?? createInfuraRpc(chainId) ?? createQuicknodeRpc(chainId)\n }\n return assertEx(provider, () => `Unable to create provider [${chainId}]: ${providerSource}|${providerType}`)\n}\n\nconst providers: Record<string, Provider> = {}\n\nexport const getSharedProviderFromEnv = (\n chainId: number = 0x01,\n options?: { providerSource?: ProviderSource; providerType?: ProviderType },\n): Provider => {\n const key = `${chainId}:${options ? JSON.stringify(options) : 'default'}`\n providers[key] = providers[key] ?? getProviderFromEnv(chainId, options)\n return providers[key]\n}\n\nexport const getProvidersFromEnv = (count: number = 1, chainId: number = 0x01, options: GetProvidersFromEnvOptions = {}): Provider[] => {\n const result: Provider[] = []\n for (let i = 0; i < count; i++) {\n result.push(getProviderFromEnv(chainId, options))\n }\n return result\n}\n","import type { Payload } from '@xyo-network/payload-model'\n\n/** @deprecated use EvmAddressSchema version instead */\nexport const BlockchainAddressSchema = 'network.xyo.blockchain.address' as const\n\n/** @deprecated use EvmAddressSchema version instead */\nexport type BlockchainAddressSchema = typeof BlockchainAddressSchema\n\n/** @deprecated use EvmAddress version instead */\nexport type BlockchainAddress = Payload<\n {\n address?: string\n blockTag?: string | number\n chainId?: number\n },\n BlockchainAddressSchema\n>\n","import type { EmptyObject, WithAdditional } from '@xylabs/object'\nimport type { Promisable } from '@xylabs/promise'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport type { AnyConfigSchema } from '@xyo-network/module-model'\nimport type { Payload } from '@xyo-network/payload-model'\nimport type {\n WitnessConfig, WitnessInstance, WitnessModuleEventData, WitnessParams,\n} from '@xyo-network/witness-model'\nimport type { Provider } from 'ethers'\n\n/** @deprecated use EvmWitnessConfigSchema version instead */\nexport const BlockchainWitnessConfigSchema = 'network.xyo.blockchain.witness' as const\n/** @deprecated use EvmWitnessConfigSchema version instead */\nexport type BlockchainWitnessConfigSchema = typeof BlockchainWitnessConfigSchema\n\n/** @deprecated use EvmWitnessConfig version instead */\nexport type BlockchainWitnessConfig<TAdditional extends EmptyObject | Payload | void = void, TSchema extends string | void = void> = WitnessConfig<\n TAdditional,\n TSchema extends void ?\n TAdditional extends Payload ?\n TAdditional['schema']\n : BlockchainWitnessConfigSchema\n : TSchema\n>\n\n/** @deprecated use AdditionalEvmWitnessParams version instead */\nexport type AdditionalBlockchainWitnessParams = {\n providers: Provider[]\n}\n\n/** @deprecated use EvmWitnessParams version instead */\nexport type BlockchainWitnessParams<\n TConfig extends AnyConfigSchema<BlockchainWitnessConfig> = BlockchainWitnessConfig,\n TAdditionalParams extends EmptyObject | void = void,\n> = WitnessParams<\n TConfig,\n WithAdditional<\n {\n providers: () => Promisable<Provider[]>\n },\n TAdditionalParams\n >\n>\n\n/** @deprecated use AbstractEvmWitness version instead */\nexport abstract class AbstractBlockchainWitness<\n TParams extends BlockchainWitnessParams<AnyConfigSchema<BlockchainWitnessConfig>> = BlockchainWitnessParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut> = WitnessModuleEventData<\n WitnessInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends AbstractWitness<TParams, TIn, TOut, TEventData> {\n private _providers: Provider[] | undefined = undefined\n\n async getProvider(cache?: boolean): Promise<Provider | undefined>\n async getProvider(cache: boolean, error: string | true): Promise<Provider>\n async getProvider(cache = false, error?: string | boolean): Promise<Provider | undefined> {\n const providers = await this.getProviders(cache)\n if (providers.length === 0) {\n if (error) {\n throw new Error(typeof error === 'string' ? error : 'No providers available')\n }\n return undefined\n }\n return providers[Date.now() % providers.length] // pick a random provider\n }\n\n async getProviders(cache = false): Promise<Provider[]> {\n const cachedProviders = cache ? this._providers : undefined\n this._providers = cachedProviders ?? (await this.params.providers())\n return this._providers\n }\n}\n"],"mappings":"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","names":["assertEx","providers"]}
@@ -1,10 +1,7 @@
1
- var __defProp = Object.defineProperty;
2
- var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
-
4
1
  // src/lib/checkIpfsUrl.ts
5
2
  import { assertEx } from "@xylabs/assert";
6
3
  var allowIpfsIoRepair = true;
7
- var checkIpfsUrl = /* @__PURE__ */ __name((urlToCheck, ipfsGateway) => {
4
+ var checkIpfsUrl = (urlToCheck, ipfsGateway) => {
8
5
  try {
9
6
  const url = new URL(urlToCheck);
10
7
  let protocol = url.protocol;
@@ -33,28 +30,33 @@ var checkIpfsUrl = /* @__PURE__ */ __name((urlToCheck, ipfsGateway) => {
33
30
  } catch {
34
31
  return urlToCheck;
35
32
  }
36
- }, "checkIpfsUrl");
33
+ };
37
34
 
38
35
  // src/lib/getProviderFromEnv.ts
39
36
  import { assertEx as assertEx2 } from "@xylabs/assert";
40
- import { InfuraProvider, InfuraWebSocketProvider, JsonRpcProvider, WebSocketProvider } from "ethers";
41
- var createInfuraRpc = /* @__PURE__ */ __name((chainId) => {
37
+ import {
38
+ InfuraProvider,
39
+ InfuraWebSocketProvider,
40
+ JsonRpcProvider,
41
+ WebSocketProvider
42
+ } from "ethers";
43
+ var createInfuraRpc = (chainId) => {
42
44
  return process.env.INFURA_PROJECT_ID && process.env.INFURA_PROJECT_SECRET ? new InfuraProvider(chainId, process.env.INFURA_PROJECT_ID) : void 0;
43
- }, "createInfuraRpc");
44
- var createInfuraWss = /* @__PURE__ */ __name((chainId) => {
45
+ };
46
+ var createInfuraWss = (chainId) => {
45
47
  return process.env.INFURA_PROJECT_ID ? new InfuraWebSocketProvider(chainId, process.env.INFURA_PROJECT_ID) : void 0;
46
- }, "createInfuraWss");
47
- var createQuicknodeWss = /* @__PURE__ */ __name((chainId) => {
48
+ };
49
+ var createQuicknodeWss = (chainId) => {
48
50
  const quickNodeWSSUri = process.env.QUICKNODE_WSS_URI;
49
51
  return quickNodeWSSUri ? new WebSocketProvider(quickNodeWSSUri, chainId) : void 0;
50
- }, "createQuicknodeWss");
51
- var createQuicknodeRpc = /* @__PURE__ */ __name((chainId) => {
52
+ };
53
+ var createQuicknodeRpc = (chainId) => {
52
54
  const quickNodeHttpsUri = process.env.QUICKNODE_HTTPS_URI;
53
55
  return quickNodeHttpsUri ? new JsonRpcProvider(quickNodeHttpsUri, chainId) : void 0;
54
- }, "createQuicknodeRpc");
55
- var getProviderFromEnv = /* @__PURE__ */ __name((chainId = 1, { providerSource = "infura", providerType = "rpc" } = {}) => {
56
+ };
57
+ var getProviderFromEnv = (chainId = 1, { providerSource = "infura", providerType = "rpc" } = {}) => {
56
58
  let provider = void 0;
57
- const quicknodeCases = /* @__PURE__ */ __name(() => {
59
+ const quicknodeCases = () => {
58
60
  switch (providerType) {
59
61
  case "rpc": {
60
62
  provider = createQuicknodeRpc(chainId);
@@ -65,8 +67,8 @@ var getProviderFromEnv = /* @__PURE__ */ __name((chainId = 1, { providerSource =
65
67
  break;
66
68
  }
67
69
  }
68
- }, "quicknodeCases");
69
- const infuraCases = /* @__PURE__ */ __name(() => {
70
+ };
71
+ const infuraCases = () => {
70
72
  switch (providerType) {
71
73
  case "wss": {
72
74
  provider = createInfuraWss(chainId);
@@ -77,7 +79,7 @@ var getProviderFromEnv = /* @__PURE__ */ __name((chainId = 1, { providerSource =
77
79
  break;
78
80
  }
79
81
  }
80
- }, "infuraCases");
82
+ };
81
83
  switch (providerSource) {
82
84
  case "quicknode": {
83
85
  quicknodeCases();
@@ -93,20 +95,20 @@ var getProviderFromEnv = /* @__PURE__ */ __name((chainId = 1, { providerSource =
93
95
  provider = createInfuraWss(chainId) ?? createInfuraRpc(chainId) ?? createQuicknodeRpc(chainId);
94
96
  }
95
97
  return assertEx2(provider, () => `Unable to create provider [${chainId}]: ${providerSource}|${providerType}`);
96
- }, "getProviderFromEnv");
98
+ };
97
99
  var providers = {};
98
- var getSharedProviderFromEnv = /* @__PURE__ */ __name((chainId = 1, options) => {
100
+ var getSharedProviderFromEnv = (chainId = 1, options) => {
99
101
  const key = `${chainId}:${options ? JSON.stringify(options) : "default"}`;
100
102
  providers[key] = providers[key] ?? getProviderFromEnv(chainId, options);
101
103
  return providers[key];
102
- }, "getSharedProviderFromEnv");
103
- var getProvidersFromEnv = /* @__PURE__ */ __name((count = 1, chainId = 1, options = {}) => {
104
+ };
105
+ var getProvidersFromEnv = (count = 1, chainId = 1, options = {}) => {
104
106
  const result = [];
105
107
  for (let i = 0; i < count; i++) {
106
108
  result.push(getProviderFromEnv(chainId, options));
107
109
  }
108
110
  return result;
109
- }, "getProvidersFromEnv");
111
+ };
110
112
 
111
113
  // src/model.ts
112
114
  var BlockchainAddressSchema = "network.xyo.blockchain.address";
@@ -115,9 +117,6 @@ var BlockchainAddressSchema = "network.xyo.blockchain.address";
115
117
  import { AbstractWitness } from "@xyo-network/abstract-witness";
116
118
  var BlockchainWitnessConfigSchema = "network.xyo.blockchain.witness";
117
119
  var AbstractBlockchainWitness = class extends AbstractWitness {
118
- static {
119
- __name(this, "AbstractBlockchainWitness");
120
- }
121
120
  _providers = void 0;
122
121
  async getProvider(cache = false, error) {
123
122
  const providers2 = await this.getProviders(cache);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/lib/checkIpfsUrl.ts","../../src/lib/getProviderFromEnv.ts","../../src/model.ts","../../src/Witness.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\n\nconst allowIpfsIoRepair = true\n\n/**\n * Returns the equivalent IPFS gateway URL for the supplied URL.\n * @param urlToCheck The URL to check\n * @returns If the supplied URL is an IPFS URL, it converts the URL to the\n * equivalent IPFS gateway URL. Otherwise, returns the original URL.\n */\nexport const checkIpfsUrl = (urlToCheck: string, ipfsGateway?: string): string => {\n try {\n const url = new URL(urlToCheck)\n let protocol = url.protocol\n let host = url.host\n let path = url.pathname\n const query = url.search\n if (protocol === 'ipfs:') {\n protocol = 'https:'\n host = assertEx(ipfsGateway, () => 'No ipfsGateway provided')\n path = url.host === 'ipfs' ? `ipfs${path}` : `ipfs/${url.host}${path}`\n const root = `${protocol}//${host}/${path}`\n return query?.length > 0 ? `${root}?${query}` : root\n } else if (allowIpfsIoRepair && protocol === 'https' && host === 'ipfs.io') {\n protocol = 'https:'\n host = assertEx(ipfsGateway, () => 'No ipfsGateway provided')\n const pathParts = path.split('/')\n if (pathParts[0] === 'ipfs') {\n pathParts.shift()\n }\n path = pathParts.join('/')\n const root = `${protocol}//${host}/${path}`\n return query?.length > 0 ? `${root}?${query}` : root\n } else {\n return urlToCheck\n }\n } catch {\n // const error = ex as Error\n // console.error(`${error.name}:${error.message} [${urlToCheck}]`)\n // console.log(error.stack)\n return urlToCheck\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport type { Provider } from 'ethers'\nimport {\n InfuraProvider, InfuraWebSocketProvider, JsonRpcProvider, WebSocketProvider,\n} from 'ethers'\n\nexport type ProviderSource = 'infura' | 'quicknode'\nexport type ProviderType = 'rpc' | 'wss'\n\nexport interface GetProvidersFromEnvOptions {\n providerSource?: ProviderSource\n providerType?: ProviderType\n}\n\nconst createInfuraRpc = (chainId: number) => {\n return process.env.INFURA_PROJECT_ID && process.env.INFURA_PROJECT_SECRET ? new InfuraProvider(chainId, process.env.INFURA_PROJECT_ID) : undefined\n}\n\nconst createInfuraWss = (chainId: number) => {\n return process.env.INFURA_PROJECT_ID ? new InfuraWebSocketProvider(chainId, process.env.INFURA_PROJECT_ID) : undefined\n}\n\nconst createQuicknodeWss = (chainId: number) => {\n const quickNodeWSSUri = process.env.QUICKNODE_WSS_URI\n return quickNodeWSSUri ? new WebSocketProvider(quickNodeWSSUri, chainId) : undefined\n}\n\nconst createQuicknodeRpc = (chainId: number) => {\n const quickNodeHttpsUri = process.env.QUICKNODE_HTTPS_URI\n return quickNodeHttpsUri ? new JsonRpcProvider(quickNodeHttpsUri, chainId) : undefined\n}\n\nexport const getProviderFromEnv = (\n chainId: number = 0x01,\n { providerSource = 'infura', providerType = 'rpc' }: GetProvidersFromEnvOptions = {},\n): Provider => {\n let provider: Provider | undefined = undefined\n\n const quicknodeCases = () => {\n switch (providerType) {\n case 'rpc': {\n provider = createQuicknodeRpc(chainId)\n break\n }\n case 'wss': {\n provider = createQuicknodeWss(chainId)\n break\n }\n }\n }\n\n const infuraCases = () => {\n switch (providerType) {\n case 'wss': {\n provider = createInfuraWss(chainId)\n break\n }\n case 'rpc': {\n provider = createInfuraRpc(chainId)\n break\n }\n }\n }\n\n switch (providerSource) {\n case 'quicknode': {\n quicknodeCases()\n break\n }\n default:\n case 'infura': {\n infuraCases()\n break\n }\n }\n if (!provider) {\n provider = createInfuraWss(chainId) ?? createInfuraRpc(chainId) ?? createQuicknodeRpc(chainId)\n }\n return assertEx(provider, () => `Unable to create provider [${chainId}]: ${providerSource}|${providerType}`)\n}\n\nconst providers: Record<string, Provider> = {}\n\nexport const getSharedProviderFromEnv = (\n chainId: number = 0x01,\n options?: { providerSource?: ProviderSource; providerType?: ProviderType },\n): Provider => {\n const key = `${chainId}:${options ? JSON.stringify(options) : 'default'}`\n providers[key] = providers[key] ?? getProviderFromEnv(chainId, options)\n return providers[key]\n}\n\nexport const getProvidersFromEnv = (count: number = 1, chainId: number = 0x01, options: GetProvidersFromEnvOptions = {}): Provider[] => {\n const result: Provider[] = []\n for (let i = 0; i < count; i++) {\n result.push(getProviderFromEnv(chainId, options))\n }\n return result\n}\n","import type { Payload } from '@xyo-network/payload-model'\n\n/** @deprecated use EvmAddressSchema version instead */\nexport const BlockchainAddressSchema = 'network.xyo.blockchain.address' as const\n\n/** @deprecated use EvmAddressSchema version instead */\nexport type BlockchainAddressSchema = typeof BlockchainAddressSchema\n\n/** @deprecated use EvmAddress version instead */\nexport type BlockchainAddress = Payload<\n {\n address?: string\n blockTag?: string | number\n chainId?: number\n },\n BlockchainAddressSchema\n>\n","import type { EmptyObject, WithAdditional } from '@xylabs/object'\nimport type { Promisable } from '@xylabs/promise'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport type { AnyConfigSchema } from '@xyo-network/module-model'\nimport type { Payload } from '@xyo-network/payload-model'\nimport type {\n WitnessConfig, WitnessInstance, WitnessModuleEventData, WitnessParams,\n} from '@xyo-network/witness-model'\nimport type { Provider } from 'ethers'\n\n/** @deprecated use EvmWitnessConfigSchema version instead */\nexport const BlockchainWitnessConfigSchema = 'network.xyo.blockchain.witness' as const\n/** @deprecated use EvmWitnessConfigSchema version instead */\nexport type BlockchainWitnessConfigSchema = typeof BlockchainWitnessConfigSchema\n\n/** @deprecated use EvmWitnessConfig version instead */\nexport type BlockchainWitnessConfig<TAdditional extends EmptyObject | Payload | void = void, TSchema extends string | void = void> = WitnessConfig<\n TAdditional,\n TSchema extends void ?\n TAdditional extends Payload ?\n TAdditional['schema']\n : BlockchainWitnessConfigSchema\n : TSchema\n>\n\n/** @deprecated use AdditionalEvmWitnessParams version instead */\nexport type AdditionalBlockchainWitnessParams = {\n providers: Provider[]\n}\n\n/** @deprecated use EvmWitnessParams version instead */\nexport type BlockchainWitnessParams<\n TConfig extends AnyConfigSchema<BlockchainWitnessConfig> = BlockchainWitnessConfig,\n TAdditionalParams extends EmptyObject | void = void,\n> = WitnessParams<\n TConfig,\n WithAdditional<\n {\n providers: () => Promisable<Provider[]>\n },\n TAdditionalParams\n >\n>\n\n/** @deprecated use AbstractEvmWitness version instead */\nexport abstract class AbstractBlockchainWitness<\n TParams extends BlockchainWitnessParams<AnyConfigSchema<BlockchainWitnessConfig>> = BlockchainWitnessParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut> = WitnessModuleEventData<\n WitnessInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends AbstractWitness<TParams, TIn, TOut, TEventData> {\n private _providers: Provider[] | undefined = undefined\n\n async getProvider(cache?: boolean): Promise<Provider | undefined>\n async getProvider(cache: boolean, error: string | true): Promise<Provider>\n async getProvider(cache = false, error?: string | boolean): Promise<Provider | undefined> {\n const providers = await this.getProviders(cache)\n if (providers.length === 0) {\n if (error) {\n throw new Error(typeof error === 'string' ? error : 'No providers available')\n }\n return undefined\n }\n return providers[Date.now() % providers.length] // pick a random provider\n }\n\n async getProviders(cache = false): Promise<Provider[]> {\n const cachedProviders = cache ? this._providers : undefined\n this._providers = cachedProviders ?? (await this.params.providers())\n return this._providers\n }\n}\n"],"mappings":";;;;AAAA,SAASA,gBAAgB;AAEzB,IAAMC,oBAAoB;AAQnB,IAAMC,eAAe,wBAACC,YAAoBC,gBAAAA;AAC/C,MAAI;AACF,UAAMC,MAAM,IAAIC,IAAIH,UAAAA;AACpB,QAAII,WAAWF,IAAIE;AACnB,QAAIC,OAAOH,IAAIG;AACf,QAAIC,OAAOJ,IAAIK;AACf,UAAMC,QAAQN,IAAIO;AAClB,QAAIL,aAAa,SAAS;AACxBA,iBAAW;AACXC,aAAOK,SAAST,aAAa,MAAM,yBAAA;AACnCK,aAAOJ,IAAIG,SAAS,SAAS,OAAOC,IAAAA,KAAS,QAAQJ,IAAIG,IAAI,GAAGC,IAAAA;AAChE,YAAMK,OAAO,GAAGP,QAAAA,KAAaC,IAAAA,IAAQC,IAAAA;AACrC,aAAOE,OAAOI,SAAS,IAAI,GAAGD,IAAAA,IAAQH,KAAAA,KAAUG;IAClD,WAAWb,qBAAqBM,aAAa,WAAWC,SAAS,WAAW;AAC1ED,iBAAW;AACXC,aAAOK,SAAST,aAAa,MAAM,yBAAA;AACnC,YAAMY,YAAYP,KAAKQ,MAAM,GAAA;AAC7B,UAAID,UAAU,CAAA,MAAO,QAAQ;AAC3BA,kBAAUE,MAAK;MACjB;AACAT,aAAOO,UAAUG,KAAK,GAAA;AACtB,YAAML,OAAO,GAAGP,QAAAA,KAAaC,IAAAA,IAAQC,IAAAA;AACrC,aAAOE,OAAOI,SAAS,IAAI,GAAGD,IAAAA,IAAQH,KAAAA,KAAUG;IAClD,OAAO;AACL,aAAOX;IACT;EACF,QAAQ;AAIN,WAAOA;EACT;AACF,GAhC4B;;;ACV5B,SAASiB,YAAAA,iBAAgB;AAEzB,SACEC,gBAAgBC,yBAAyBC,iBAAiBC,yBACrD;AAUP,IAAMC,kBAAkB,wBAACC,YAAAA;AACvB,SAAOC,QAAQC,IAAIC,qBAAqBF,QAAQC,IAAIE,wBAAwB,IAAIC,eAAeL,SAASC,QAAQC,IAAIC,iBAAiB,IAAIG;AAC3I,GAFwB;AAIxB,IAAMC,kBAAkB,wBAACP,YAAAA;AACvB,SAAOC,QAAQC,IAAIC,oBAAoB,IAAIK,wBAAwBR,SAASC,QAAQC,IAAIC,iBAAiB,IAAIG;AAC/G,GAFwB;AAIxB,IAAMG,qBAAqB,wBAACT,YAAAA;AAC1B,QAAMU,kBAAkBT,QAAQC,IAAIS;AACpC,SAAOD,kBAAkB,IAAIE,kBAAkBF,iBAAiBV,OAAAA,IAAWM;AAC7E,GAH2B;AAK3B,IAAMO,qBAAqB,wBAACb,YAAAA;AAC1B,QAAMc,oBAAoBb,QAAQC,IAAIa;AACtC,SAAOD,oBAAoB,IAAIE,gBAAgBF,mBAAmBd,OAAAA,IAAWM;AAC/E,GAH2B;AAKpB,IAAMW,qBAAqB,wBAChCjB,UAAkB,GAClB,EAAEkB,iBAAiB,UAAUC,eAAe,MAAK,IAAiC,CAAC,MAAC;AAEpF,MAAIC,WAAiCd;AAErC,QAAMe,iBAAiB,6BAAA;AACrB,YAAQF,cAAAA;MACN,KAAK,OAAO;AACVC,mBAAWP,mBAAmBb,OAAAA;AAC9B;MACF;MACA,KAAK,OAAO;AACVoB,mBAAWX,mBAAmBT,OAAAA;AAC9B;MACF;IACF;EACF,GAXuB;AAavB,QAAMsB,cAAc,6BAAA;AAClB,YAAQH,cAAAA;MACN,KAAK,OAAO;AACVC,mBAAWb,gBAAgBP,OAAAA;AAC3B;MACF;MACA,KAAK,OAAO;AACVoB,mBAAWrB,gBAAgBC,OAAAA;AAC3B;MACF;IACF;EACF,GAXoB;AAapB,UAAQkB,gBAAAA;IACN,KAAK,aAAa;AAChBG,qBAAAA;AACA;IACF;IACA;IACA,KAAK,UAAU;AACbC,kBAAAA;AACA;IACF;EACF;AACA,MAAI,CAACF,UAAU;AACbA,eAAWb,gBAAgBP,OAAAA,KAAYD,gBAAgBC,OAAAA,KAAYa,mBAAmBb,OAAAA;EACxF;AACA,SAAOuB,UAASH,UAAU,MAAM,8BAA8BpB,OAAAA,MAAakB,cAAAA,IAAkBC,YAAAA,EAAc;AAC7G,GA/CkC;AAiDlC,IAAMK,YAAsC,CAAC;AAEtC,IAAMC,2BAA2B,wBACtCzB,UAAkB,GAClB0B,YAAAA;AAEA,QAAMC,MAAM,GAAG3B,OAAAA,IAAW0B,UAAUE,KAAKC,UAAUH,OAAAA,IAAW,SAAA;AAC9DF,YAAUG,GAAAA,IAAOH,UAAUG,GAAAA,KAAQV,mBAAmBjB,SAAS0B,OAAAA;AAC/D,SAAOF,UAAUG,GAAAA;AACnB,GAPwC;AASjC,IAAMG,sBAAsB,wBAACC,QAAgB,GAAG/B,UAAkB,GAAM0B,UAAsC,CAAC,MAAC;AACrH,QAAMM,SAAqB,CAAA;AAC3B,WAASC,IAAI,GAAGA,IAAIF,OAAOE,KAAK;AAC9BD,WAAOE,KAAKjB,mBAAmBjB,SAAS0B,OAAAA,CAAAA;EAC1C;AACA,SAAOM;AACT,GANmC;;;ACzF5B,IAAMG,0BAA0B;;;ACDvC,SAASC,uBAAuB;AASzB,IAAMC,gCAAgC;AAkCtC,IAAeC,4BAAf,cASGC,gBAAAA;EApDV,OAoDUA;;;EACAC,aAAqCC;EAI7C,MAAMC,YAAYC,QAAQ,OAAOC,OAAyD;AACxF,UAAMC,aAAY,MAAM,KAAKC,aAAaH,KAAAA;AAC1C,QAAIE,WAAUE,WAAW,GAAG;AAC1B,UAAIH,OAAO;AACT,cAAM,IAAII,MAAM,OAAOJ,UAAU,WAAWA,QAAQ,wBAAA;MACtD;AACA,aAAOH;IACT;AACA,WAAOI,WAAUI,KAAKC,IAAG,IAAKL,WAAUE,MAAM;EAChD;EAEA,MAAMD,aAAaH,QAAQ,OAA4B;AACrD,UAAMQ,kBAAkBR,QAAQ,KAAKH,aAAaC;AAClD,SAAKD,aAAaW,mBAAoB,MAAM,KAAKC,OAAOP,UAAS;AACjE,WAAO,KAAKL;EACd;AACF;","names":["assertEx","allowIpfsIoRepair","checkIpfsUrl","urlToCheck","ipfsGateway","url","URL","protocol","host","path","pathname","query","search","assertEx","root","length","pathParts","split","shift","join","assertEx","InfuraProvider","InfuraWebSocketProvider","JsonRpcProvider","WebSocketProvider","createInfuraRpc","chainId","process","env","INFURA_PROJECT_ID","INFURA_PROJECT_SECRET","InfuraProvider","undefined","createInfuraWss","InfuraWebSocketProvider","createQuicknodeWss","quickNodeWSSUri","QUICKNODE_WSS_URI","WebSocketProvider","createQuicknodeRpc","quickNodeHttpsUri","QUICKNODE_HTTPS_URI","JsonRpcProvider","getProviderFromEnv","providerSource","providerType","provider","quicknodeCases","infuraCases","assertEx","providers","getSharedProviderFromEnv","options","key","JSON","stringify","getProvidersFromEnv","count","result","i","push","BlockchainAddressSchema","AbstractWitness","BlockchainWitnessConfigSchema","AbstractBlockchainWitness","AbstractWitness","_providers","undefined","getProvider","cache","error","providers","getProviders","length","Error","Date","now","cachedProviders","params"]}
1
+ {"version":3,"sources":["../../src/lib/checkIpfsUrl.ts","../../src/lib/getProviderFromEnv.ts","../../src/model.ts","../../src/Witness.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\n\nconst allowIpfsIoRepair = true\n\n/**\n * Returns the equivalent IPFS gateway URL for the supplied URL.\n * @param urlToCheck The URL to check\n * @returns If the supplied URL is an IPFS URL, it converts the URL to the\n * equivalent IPFS gateway URL. Otherwise, returns the original URL.\n */\nexport const checkIpfsUrl = (urlToCheck: string, ipfsGateway?: string): string => {\n try {\n const url = new URL(urlToCheck)\n let protocol = url.protocol\n let host = url.host\n let path = url.pathname\n const query = url.search\n if (protocol === 'ipfs:') {\n protocol = 'https:'\n host = assertEx(ipfsGateway, () => 'No ipfsGateway provided')\n path = url.host === 'ipfs' ? `ipfs${path}` : `ipfs/${url.host}${path}`\n const root = `${protocol}//${host}/${path}`\n return query?.length > 0 ? `${root}?${query}` : root\n } else if (allowIpfsIoRepair && protocol === 'https' && host === 'ipfs.io') {\n protocol = 'https:'\n host = assertEx(ipfsGateway, () => 'No ipfsGateway provided')\n const pathParts = path.split('/')\n if (pathParts[0] === 'ipfs') {\n pathParts.shift()\n }\n path = pathParts.join('/')\n const root = `${protocol}//${host}/${path}`\n return query?.length > 0 ? `${root}?${query}` : root\n } else {\n return urlToCheck\n }\n } catch {\n // const error = ex as Error\n // console.error(`${error.name}:${error.message} [${urlToCheck}]`)\n // console.log(error.stack)\n return urlToCheck\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport type { Provider } from 'ethers'\nimport {\n InfuraProvider, InfuraWebSocketProvider, JsonRpcProvider, WebSocketProvider,\n} from 'ethers'\n\nexport type ProviderSource = 'infura' | 'quicknode'\nexport type ProviderType = 'rpc' | 'wss'\n\nexport interface GetProvidersFromEnvOptions {\n providerSource?: ProviderSource\n providerType?: ProviderType\n}\n\nconst createInfuraRpc = (chainId: number) => {\n return process.env.INFURA_PROJECT_ID && process.env.INFURA_PROJECT_SECRET ? new InfuraProvider(chainId, process.env.INFURA_PROJECT_ID) : undefined\n}\n\nconst createInfuraWss = (chainId: number) => {\n return process.env.INFURA_PROJECT_ID ? new InfuraWebSocketProvider(chainId, process.env.INFURA_PROJECT_ID) : undefined\n}\n\nconst createQuicknodeWss = (chainId: number) => {\n const quickNodeWSSUri = process.env.QUICKNODE_WSS_URI\n return quickNodeWSSUri ? new WebSocketProvider(quickNodeWSSUri, chainId) : undefined\n}\n\nconst createQuicknodeRpc = (chainId: number) => {\n const quickNodeHttpsUri = process.env.QUICKNODE_HTTPS_URI\n return quickNodeHttpsUri ? new JsonRpcProvider(quickNodeHttpsUri, chainId) : undefined\n}\n\nexport const getProviderFromEnv = (\n chainId: number = 0x01,\n { providerSource = 'infura', providerType = 'rpc' }: GetProvidersFromEnvOptions = {},\n): Provider => {\n let provider: Provider | undefined = undefined\n\n const quicknodeCases = () => {\n switch (providerType) {\n case 'rpc': {\n provider = createQuicknodeRpc(chainId)\n break\n }\n case 'wss': {\n provider = createQuicknodeWss(chainId)\n break\n }\n }\n }\n\n const infuraCases = () => {\n switch (providerType) {\n case 'wss': {\n provider = createInfuraWss(chainId)\n break\n }\n case 'rpc': {\n provider = createInfuraRpc(chainId)\n break\n }\n }\n }\n\n switch (providerSource) {\n case 'quicknode': {\n quicknodeCases()\n break\n }\n default:\n case 'infura': {\n infuraCases()\n break\n }\n }\n if (!provider) {\n provider = createInfuraWss(chainId) ?? createInfuraRpc(chainId) ?? createQuicknodeRpc(chainId)\n }\n return assertEx(provider, () => `Unable to create provider [${chainId}]: ${providerSource}|${providerType}`)\n}\n\nconst providers: Record<string, Provider> = {}\n\nexport const getSharedProviderFromEnv = (\n chainId: number = 0x01,\n options?: { providerSource?: ProviderSource; providerType?: ProviderType },\n): Provider => {\n const key = `${chainId}:${options ? JSON.stringify(options) : 'default'}`\n providers[key] = providers[key] ?? getProviderFromEnv(chainId, options)\n return providers[key]\n}\n\nexport const getProvidersFromEnv = (count: number = 1, chainId: number = 0x01, options: GetProvidersFromEnvOptions = {}): Provider[] => {\n const result: Provider[] = []\n for (let i = 0; i < count; i++) {\n result.push(getProviderFromEnv(chainId, options))\n }\n return result\n}\n","import type { Payload } from '@xyo-network/payload-model'\n\n/** @deprecated use EvmAddressSchema version instead */\nexport const BlockchainAddressSchema = 'network.xyo.blockchain.address' as const\n\n/** @deprecated use EvmAddressSchema version instead */\nexport type BlockchainAddressSchema = typeof BlockchainAddressSchema\n\n/** @deprecated use EvmAddress version instead */\nexport type BlockchainAddress = Payload<\n {\n address?: string\n blockTag?: string | number\n chainId?: number\n },\n BlockchainAddressSchema\n>\n","import type { EmptyObject, WithAdditional } from '@xylabs/object'\nimport type { Promisable } from '@xylabs/promise'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport type { AnyConfigSchema } from '@xyo-network/module-model'\nimport type { Payload } from '@xyo-network/payload-model'\nimport type {\n WitnessConfig, WitnessInstance, WitnessModuleEventData, WitnessParams,\n} from '@xyo-network/witness-model'\nimport type { Provider } from 'ethers'\n\n/** @deprecated use EvmWitnessConfigSchema version instead */\nexport const BlockchainWitnessConfigSchema = 'network.xyo.blockchain.witness' as const\n/** @deprecated use EvmWitnessConfigSchema version instead */\nexport type BlockchainWitnessConfigSchema = typeof BlockchainWitnessConfigSchema\n\n/** @deprecated use EvmWitnessConfig version instead */\nexport type BlockchainWitnessConfig<TAdditional extends EmptyObject | Payload | void = void, TSchema extends string | void = void> = WitnessConfig<\n TAdditional,\n TSchema extends void ?\n TAdditional extends Payload ?\n TAdditional['schema']\n : BlockchainWitnessConfigSchema\n : TSchema\n>\n\n/** @deprecated use AdditionalEvmWitnessParams version instead */\nexport type AdditionalBlockchainWitnessParams = {\n providers: Provider[]\n}\n\n/** @deprecated use EvmWitnessParams version instead */\nexport type BlockchainWitnessParams<\n TConfig extends AnyConfigSchema<BlockchainWitnessConfig> = BlockchainWitnessConfig,\n TAdditionalParams extends EmptyObject | void = void,\n> = WitnessParams<\n TConfig,\n WithAdditional<\n {\n providers: () => Promisable<Provider[]>\n },\n TAdditionalParams\n >\n>\n\n/** @deprecated use AbstractEvmWitness version instead */\nexport abstract class AbstractBlockchainWitness<\n TParams extends BlockchainWitnessParams<AnyConfigSchema<BlockchainWitnessConfig>> = BlockchainWitnessParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut> = WitnessModuleEventData<\n WitnessInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends AbstractWitness<TParams, TIn, TOut, TEventData> {\n private _providers: Provider[] | undefined = undefined\n\n async getProvider(cache?: boolean): Promise<Provider | undefined>\n async getProvider(cache: boolean, error: string | true): Promise<Provider>\n async getProvider(cache = false, error?: string | boolean): Promise<Provider | undefined> {\n const providers = await this.getProviders(cache)\n if (providers.length === 0) {\n if (error) {\n throw new Error(typeof error === 'string' ? error : 'No providers available')\n }\n return undefined\n }\n return providers[Date.now() % providers.length] // pick a random provider\n }\n\n async getProviders(cache = false): Promise<Provider[]> {\n const cachedProviders = cache ? this._providers : undefined\n this._providers = cachedProviders ?? (await this.params.providers())\n return this._providers\n }\n}\n"],"mappings":"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","names":["assertEx","providers"]}
@@ -1,10 +1,7 @@
1
- var __defProp = Object.defineProperty;
2
- var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
-
4
1
  // src/lib/checkIpfsUrl.ts
5
2
  import { assertEx } from "@xylabs/assert";
6
3
  var allowIpfsIoRepair = true;
7
- var checkIpfsUrl = /* @__PURE__ */ __name((urlToCheck, ipfsGateway) => {
4
+ var checkIpfsUrl = (urlToCheck, ipfsGateway) => {
8
5
  try {
9
6
  const url = new URL(urlToCheck);
10
7
  let protocol = url.protocol;
@@ -33,28 +30,33 @@ var checkIpfsUrl = /* @__PURE__ */ __name((urlToCheck, ipfsGateway) => {
33
30
  } catch {
34
31
  return urlToCheck;
35
32
  }
36
- }, "checkIpfsUrl");
33
+ };
37
34
 
38
35
  // src/lib/getProviderFromEnv.ts
39
36
  import { assertEx as assertEx2 } from "@xylabs/assert";
40
- import { InfuraProvider, InfuraWebSocketProvider, JsonRpcProvider, WebSocketProvider } from "ethers";
41
- var createInfuraRpc = /* @__PURE__ */ __name((chainId) => {
37
+ import {
38
+ InfuraProvider,
39
+ InfuraWebSocketProvider,
40
+ JsonRpcProvider,
41
+ WebSocketProvider
42
+ } from "ethers";
43
+ var createInfuraRpc = (chainId) => {
42
44
  return process.env.INFURA_PROJECT_ID && process.env.INFURA_PROJECT_SECRET ? new InfuraProvider(chainId, process.env.INFURA_PROJECT_ID) : void 0;
43
- }, "createInfuraRpc");
44
- var createInfuraWss = /* @__PURE__ */ __name((chainId) => {
45
+ };
46
+ var createInfuraWss = (chainId) => {
45
47
  return process.env.INFURA_PROJECT_ID ? new InfuraWebSocketProvider(chainId, process.env.INFURA_PROJECT_ID) : void 0;
46
- }, "createInfuraWss");
47
- var createQuicknodeWss = /* @__PURE__ */ __name((chainId) => {
48
+ };
49
+ var createQuicknodeWss = (chainId) => {
48
50
  const quickNodeWSSUri = process.env.QUICKNODE_WSS_URI;
49
51
  return quickNodeWSSUri ? new WebSocketProvider(quickNodeWSSUri, chainId) : void 0;
50
- }, "createQuicknodeWss");
51
- var createQuicknodeRpc = /* @__PURE__ */ __name((chainId) => {
52
+ };
53
+ var createQuicknodeRpc = (chainId) => {
52
54
  const quickNodeHttpsUri = process.env.QUICKNODE_HTTPS_URI;
53
55
  return quickNodeHttpsUri ? new JsonRpcProvider(quickNodeHttpsUri, chainId) : void 0;
54
- }, "createQuicknodeRpc");
55
- var getProviderFromEnv = /* @__PURE__ */ __name((chainId = 1, { providerSource = "infura", providerType = "rpc" } = {}) => {
56
+ };
57
+ var getProviderFromEnv = (chainId = 1, { providerSource = "infura", providerType = "rpc" } = {}) => {
56
58
  let provider = void 0;
57
- const quicknodeCases = /* @__PURE__ */ __name(() => {
59
+ const quicknodeCases = () => {
58
60
  switch (providerType) {
59
61
  case "rpc": {
60
62
  provider = createQuicknodeRpc(chainId);
@@ -65,8 +67,8 @@ var getProviderFromEnv = /* @__PURE__ */ __name((chainId = 1, { providerSource =
65
67
  break;
66
68
  }
67
69
  }
68
- }, "quicknodeCases");
69
- const infuraCases = /* @__PURE__ */ __name(() => {
70
+ };
71
+ const infuraCases = () => {
70
72
  switch (providerType) {
71
73
  case "wss": {
72
74
  provider = createInfuraWss(chainId);
@@ -77,7 +79,7 @@ var getProviderFromEnv = /* @__PURE__ */ __name((chainId = 1, { providerSource =
77
79
  break;
78
80
  }
79
81
  }
80
- }, "infuraCases");
82
+ };
81
83
  switch (providerSource) {
82
84
  case "quicknode": {
83
85
  quicknodeCases();
@@ -93,20 +95,20 @@ var getProviderFromEnv = /* @__PURE__ */ __name((chainId = 1, { providerSource =
93
95
  provider = createInfuraWss(chainId) ?? createInfuraRpc(chainId) ?? createQuicknodeRpc(chainId);
94
96
  }
95
97
  return assertEx2(provider, () => `Unable to create provider [${chainId}]: ${providerSource}|${providerType}`);
96
- }, "getProviderFromEnv");
98
+ };
97
99
  var providers = {};
98
- var getSharedProviderFromEnv = /* @__PURE__ */ __name((chainId = 1, options) => {
100
+ var getSharedProviderFromEnv = (chainId = 1, options) => {
99
101
  const key = `${chainId}:${options ? JSON.stringify(options) : "default"}`;
100
102
  providers[key] = providers[key] ?? getProviderFromEnv(chainId, options);
101
103
  return providers[key];
102
- }, "getSharedProviderFromEnv");
103
- var getProvidersFromEnv = /* @__PURE__ */ __name((count = 1, chainId = 1, options = {}) => {
104
+ };
105
+ var getProvidersFromEnv = (count = 1, chainId = 1, options = {}) => {
104
106
  const result = [];
105
107
  for (let i = 0; i < count; i++) {
106
108
  result.push(getProviderFromEnv(chainId, options));
107
109
  }
108
110
  return result;
109
- }, "getProvidersFromEnv");
111
+ };
110
112
 
111
113
  // src/model.ts
112
114
  var BlockchainAddressSchema = "network.xyo.blockchain.address";
@@ -115,9 +117,6 @@ var BlockchainAddressSchema = "network.xyo.blockchain.address";
115
117
  import { AbstractWitness } from "@xyo-network/abstract-witness";
116
118
  var BlockchainWitnessConfigSchema = "network.xyo.blockchain.witness";
117
119
  var AbstractBlockchainWitness = class extends AbstractWitness {
118
- static {
119
- __name(this, "AbstractBlockchainWitness");
120
- }
121
120
  _providers = void 0;
122
121
  async getProvider(cache = false, error) {
123
122
  const providers2 = await this.getProviders(cache);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/lib/checkIpfsUrl.ts","../../src/lib/getProviderFromEnv.ts","../../src/model.ts","../../src/Witness.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\n\nconst allowIpfsIoRepair = true\n\n/**\n * Returns the equivalent IPFS gateway URL for the supplied URL.\n * @param urlToCheck The URL to check\n * @returns If the supplied URL is an IPFS URL, it converts the URL to the\n * equivalent IPFS gateway URL. Otherwise, returns the original URL.\n */\nexport const checkIpfsUrl = (urlToCheck: string, ipfsGateway?: string): string => {\n try {\n const url = new URL(urlToCheck)\n let protocol = url.protocol\n let host = url.host\n let path = url.pathname\n const query = url.search\n if (protocol === 'ipfs:') {\n protocol = 'https:'\n host = assertEx(ipfsGateway, () => 'No ipfsGateway provided')\n path = url.host === 'ipfs' ? `ipfs${path}` : `ipfs/${url.host}${path}`\n const root = `${protocol}//${host}/${path}`\n return query?.length > 0 ? `${root}?${query}` : root\n } else if (allowIpfsIoRepair && protocol === 'https' && host === 'ipfs.io') {\n protocol = 'https:'\n host = assertEx(ipfsGateway, () => 'No ipfsGateway provided')\n const pathParts = path.split('/')\n if (pathParts[0] === 'ipfs') {\n pathParts.shift()\n }\n path = pathParts.join('/')\n const root = `${protocol}//${host}/${path}`\n return query?.length > 0 ? `${root}?${query}` : root\n } else {\n return urlToCheck\n }\n } catch {\n // const error = ex as Error\n // console.error(`${error.name}:${error.message} [${urlToCheck}]`)\n // console.log(error.stack)\n return urlToCheck\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport type { Provider } from 'ethers'\nimport {\n InfuraProvider, InfuraWebSocketProvider, JsonRpcProvider, WebSocketProvider,\n} from 'ethers'\n\nexport type ProviderSource = 'infura' | 'quicknode'\nexport type ProviderType = 'rpc' | 'wss'\n\nexport interface GetProvidersFromEnvOptions {\n providerSource?: ProviderSource\n providerType?: ProviderType\n}\n\nconst createInfuraRpc = (chainId: number) => {\n return process.env.INFURA_PROJECT_ID && process.env.INFURA_PROJECT_SECRET ? new InfuraProvider(chainId, process.env.INFURA_PROJECT_ID) : undefined\n}\n\nconst createInfuraWss = (chainId: number) => {\n return process.env.INFURA_PROJECT_ID ? new InfuraWebSocketProvider(chainId, process.env.INFURA_PROJECT_ID) : undefined\n}\n\nconst createQuicknodeWss = (chainId: number) => {\n const quickNodeWSSUri = process.env.QUICKNODE_WSS_URI\n return quickNodeWSSUri ? new WebSocketProvider(quickNodeWSSUri, chainId) : undefined\n}\n\nconst createQuicknodeRpc = (chainId: number) => {\n const quickNodeHttpsUri = process.env.QUICKNODE_HTTPS_URI\n return quickNodeHttpsUri ? new JsonRpcProvider(quickNodeHttpsUri, chainId) : undefined\n}\n\nexport const getProviderFromEnv = (\n chainId: number = 0x01,\n { providerSource = 'infura', providerType = 'rpc' }: GetProvidersFromEnvOptions = {},\n): Provider => {\n let provider: Provider | undefined = undefined\n\n const quicknodeCases = () => {\n switch (providerType) {\n case 'rpc': {\n provider = createQuicknodeRpc(chainId)\n break\n }\n case 'wss': {\n provider = createQuicknodeWss(chainId)\n break\n }\n }\n }\n\n const infuraCases = () => {\n switch (providerType) {\n case 'wss': {\n provider = createInfuraWss(chainId)\n break\n }\n case 'rpc': {\n provider = createInfuraRpc(chainId)\n break\n }\n }\n }\n\n switch (providerSource) {\n case 'quicknode': {\n quicknodeCases()\n break\n }\n default:\n case 'infura': {\n infuraCases()\n break\n }\n }\n if (!provider) {\n provider = createInfuraWss(chainId) ?? createInfuraRpc(chainId) ?? createQuicknodeRpc(chainId)\n }\n return assertEx(provider, () => `Unable to create provider [${chainId}]: ${providerSource}|${providerType}`)\n}\n\nconst providers: Record<string, Provider> = {}\n\nexport const getSharedProviderFromEnv = (\n chainId: number = 0x01,\n options?: { providerSource?: ProviderSource; providerType?: ProviderType },\n): Provider => {\n const key = `${chainId}:${options ? JSON.stringify(options) : 'default'}`\n providers[key] = providers[key] ?? getProviderFromEnv(chainId, options)\n return providers[key]\n}\n\nexport const getProvidersFromEnv = (count: number = 1, chainId: number = 0x01, options: GetProvidersFromEnvOptions = {}): Provider[] => {\n const result: Provider[] = []\n for (let i = 0; i < count; i++) {\n result.push(getProviderFromEnv(chainId, options))\n }\n return result\n}\n","import type { Payload } from '@xyo-network/payload-model'\n\n/** @deprecated use EvmAddressSchema version instead */\nexport const BlockchainAddressSchema = 'network.xyo.blockchain.address' as const\n\n/** @deprecated use EvmAddressSchema version instead */\nexport type BlockchainAddressSchema = typeof BlockchainAddressSchema\n\n/** @deprecated use EvmAddress version instead */\nexport type BlockchainAddress = Payload<\n {\n address?: string\n blockTag?: string | number\n chainId?: number\n },\n BlockchainAddressSchema\n>\n","import type { EmptyObject, WithAdditional } from '@xylabs/object'\nimport type { Promisable } from '@xylabs/promise'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport type { AnyConfigSchema } from '@xyo-network/module-model'\nimport type { Payload } from '@xyo-network/payload-model'\nimport type {\n WitnessConfig, WitnessInstance, WitnessModuleEventData, WitnessParams,\n} from '@xyo-network/witness-model'\nimport type { Provider } from 'ethers'\n\n/** @deprecated use EvmWitnessConfigSchema version instead */\nexport const BlockchainWitnessConfigSchema = 'network.xyo.blockchain.witness' as const\n/** @deprecated use EvmWitnessConfigSchema version instead */\nexport type BlockchainWitnessConfigSchema = typeof BlockchainWitnessConfigSchema\n\n/** @deprecated use EvmWitnessConfig version instead */\nexport type BlockchainWitnessConfig<TAdditional extends EmptyObject | Payload | void = void, TSchema extends string | void = void> = WitnessConfig<\n TAdditional,\n TSchema extends void ?\n TAdditional extends Payload ?\n TAdditional['schema']\n : BlockchainWitnessConfigSchema\n : TSchema\n>\n\n/** @deprecated use AdditionalEvmWitnessParams version instead */\nexport type AdditionalBlockchainWitnessParams = {\n providers: Provider[]\n}\n\n/** @deprecated use EvmWitnessParams version instead */\nexport type BlockchainWitnessParams<\n TConfig extends AnyConfigSchema<BlockchainWitnessConfig> = BlockchainWitnessConfig,\n TAdditionalParams extends EmptyObject | void = void,\n> = WitnessParams<\n TConfig,\n WithAdditional<\n {\n providers: () => Promisable<Provider[]>\n },\n TAdditionalParams\n >\n>\n\n/** @deprecated use AbstractEvmWitness version instead */\nexport abstract class AbstractBlockchainWitness<\n TParams extends BlockchainWitnessParams<AnyConfigSchema<BlockchainWitnessConfig>> = BlockchainWitnessParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut> = WitnessModuleEventData<\n WitnessInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends AbstractWitness<TParams, TIn, TOut, TEventData> {\n private _providers: Provider[] | undefined = undefined\n\n async getProvider(cache?: boolean): Promise<Provider | undefined>\n async getProvider(cache: boolean, error: string | true): Promise<Provider>\n async getProvider(cache = false, error?: string | boolean): Promise<Provider | undefined> {\n const providers = await this.getProviders(cache)\n if (providers.length === 0) {\n if (error) {\n throw new Error(typeof error === 'string' ? error : 'No providers available')\n }\n return undefined\n }\n return providers[Date.now() % providers.length] // pick a random provider\n }\n\n async getProviders(cache = false): Promise<Provider[]> {\n const cachedProviders = cache ? this._providers : undefined\n this._providers = cachedProviders ?? (await this.params.providers())\n return this._providers\n }\n}\n"],"mappings":"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","names":["assertEx","allowIpfsIoRepair","checkIpfsUrl","urlToCheck","ipfsGateway","url","URL","protocol","host","path","pathname","query","search","assertEx","root","length","pathParts","split","shift","join","assertEx","InfuraProvider","InfuraWebSocketProvider","JsonRpcProvider","WebSocketProvider","createInfuraRpc","chainId","process","env","INFURA_PROJECT_ID","INFURA_PROJECT_SECRET","InfuraProvider","undefined","createInfuraWss","InfuraWebSocketProvider","createQuicknodeWss","quickNodeWSSUri","QUICKNODE_WSS_URI","WebSocketProvider","createQuicknodeRpc","quickNodeHttpsUri","QUICKNODE_HTTPS_URI","JsonRpcProvider","getProviderFromEnv","providerSource","providerType","provider","quicknodeCases","infuraCases","assertEx","providers","getSharedProviderFromEnv","options","key","JSON","stringify","getProvidersFromEnv","count","result","i","push","BlockchainAddressSchema","AbstractWitness","BlockchainWitnessConfigSchema","AbstractBlockchainWitness","AbstractWitness","_providers","undefined","getProvider","cache","error","providers","getProviders","length","Error","Date","now","cachedProviders","params"]}
1
+ {"version":3,"sources":["../../src/lib/checkIpfsUrl.ts","../../src/lib/getProviderFromEnv.ts","../../src/model.ts","../../src/Witness.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\n\nconst allowIpfsIoRepair = true\n\n/**\n * Returns the equivalent IPFS gateway URL for the supplied URL.\n * @param urlToCheck The URL to check\n * @returns If the supplied URL is an IPFS URL, it converts the URL to the\n * equivalent IPFS gateway URL. Otherwise, returns the original URL.\n */\nexport const checkIpfsUrl = (urlToCheck: string, ipfsGateway?: string): string => {\n try {\n const url = new URL(urlToCheck)\n let protocol = url.protocol\n let host = url.host\n let path = url.pathname\n const query = url.search\n if (protocol === 'ipfs:') {\n protocol = 'https:'\n host = assertEx(ipfsGateway, () => 'No ipfsGateway provided')\n path = url.host === 'ipfs' ? `ipfs${path}` : `ipfs/${url.host}${path}`\n const root = `${protocol}//${host}/${path}`\n return query?.length > 0 ? `${root}?${query}` : root\n } else if (allowIpfsIoRepair && protocol === 'https' && host === 'ipfs.io') {\n protocol = 'https:'\n host = assertEx(ipfsGateway, () => 'No ipfsGateway provided')\n const pathParts = path.split('/')\n if (pathParts[0] === 'ipfs') {\n pathParts.shift()\n }\n path = pathParts.join('/')\n const root = `${protocol}//${host}/${path}`\n return query?.length > 0 ? `${root}?${query}` : root\n } else {\n return urlToCheck\n }\n } catch {\n // const error = ex as Error\n // console.error(`${error.name}:${error.message} [${urlToCheck}]`)\n // console.log(error.stack)\n return urlToCheck\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport type { Provider } from 'ethers'\nimport {\n InfuraProvider, InfuraWebSocketProvider, JsonRpcProvider, WebSocketProvider,\n} from 'ethers'\n\nexport type ProviderSource = 'infura' | 'quicknode'\nexport type ProviderType = 'rpc' | 'wss'\n\nexport interface GetProvidersFromEnvOptions {\n providerSource?: ProviderSource\n providerType?: ProviderType\n}\n\nconst createInfuraRpc = (chainId: number) => {\n return process.env.INFURA_PROJECT_ID && process.env.INFURA_PROJECT_SECRET ? new InfuraProvider(chainId, process.env.INFURA_PROJECT_ID) : undefined\n}\n\nconst createInfuraWss = (chainId: number) => {\n return process.env.INFURA_PROJECT_ID ? new InfuraWebSocketProvider(chainId, process.env.INFURA_PROJECT_ID) : undefined\n}\n\nconst createQuicknodeWss = (chainId: number) => {\n const quickNodeWSSUri = process.env.QUICKNODE_WSS_URI\n return quickNodeWSSUri ? new WebSocketProvider(quickNodeWSSUri, chainId) : undefined\n}\n\nconst createQuicknodeRpc = (chainId: number) => {\n const quickNodeHttpsUri = process.env.QUICKNODE_HTTPS_URI\n return quickNodeHttpsUri ? new JsonRpcProvider(quickNodeHttpsUri, chainId) : undefined\n}\n\nexport const getProviderFromEnv = (\n chainId: number = 0x01,\n { providerSource = 'infura', providerType = 'rpc' }: GetProvidersFromEnvOptions = {},\n): Provider => {\n let provider: Provider | undefined = undefined\n\n const quicknodeCases = () => {\n switch (providerType) {\n case 'rpc': {\n provider = createQuicknodeRpc(chainId)\n break\n }\n case 'wss': {\n provider = createQuicknodeWss(chainId)\n break\n }\n }\n }\n\n const infuraCases = () => {\n switch (providerType) {\n case 'wss': {\n provider = createInfuraWss(chainId)\n break\n }\n case 'rpc': {\n provider = createInfuraRpc(chainId)\n break\n }\n }\n }\n\n switch (providerSource) {\n case 'quicknode': {\n quicknodeCases()\n break\n }\n default:\n case 'infura': {\n infuraCases()\n break\n }\n }\n if (!provider) {\n provider = createInfuraWss(chainId) ?? createInfuraRpc(chainId) ?? createQuicknodeRpc(chainId)\n }\n return assertEx(provider, () => `Unable to create provider [${chainId}]: ${providerSource}|${providerType}`)\n}\n\nconst providers: Record<string, Provider> = {}\n\nexport const getSharedProviderFromEnv = (\n chainId: number = 0x01,\n options?: { providerSource?: ProviderSource; providerType?: ProviderType },\n): Provider => {\n const key = `${chainId}:${options ? JSON.stringify(options) : 'default'}`\n providers[key] = providers[key] ?? getProviderFromEnv(chainId, options)\n return providers[key]\n}\n\nexport const getProvidersFromEnv = (count: number = 1, chainId: number = 0x01, options: GetProvidersFromEnvOptions = {}): Provider[] => {\n const result: Provider[] = []\n for (let i = 0; i < count; i++) {\n result.push(getProviderFromEnv(chainId, options))\n }\n return result\n}\n","import type { Payload } from '@xyo-network/payload-model'\n\n/** @deprecated use EvmAddressSchema version instead */\nexport const BlockchainAddressSchema = 'network.xyo.blockchain.address' as const\n\n/** @deprecated use EvmAddressSchema version instead */\nexport type BlockchainAddressSchema = typeof BlockchainAddressSchema\n\n/** @deprecated use EvmAddress version instead */\nexport type BlockchainAddress = Payload<\n {\n address?: string\n blockTag?: string | number\n chainId?: number\n },\n BlockchainAddressSchema\n>\n","import type { EmptyObject, WithAdditional } from '@xylabs/object'\nimport type { Promisable } from '@xylabs/promise'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport type { AnyConfigSchema } from '@xyo-network/module-model'\nimport type { Payload } from '@xyo-network/payload-model'\nimport type {\n WitnessConfig, WitnessInstance, WitnessModuleEventData, WitnessParams,\n} from '@xyo-network/witness-model'\nimport type { Provider } from 'ethers'\n\n/** @deprecated use EvmWitnessConfigSchema version instead */\nexport const BlockchainWitnessConfigSchema = 'network.xyo.blockchain.witness' as const\n/** @deprecated use EvmWitnessConfigSchema version instead */\nexport type BlockchainWitnessConfigSchema = typeof BlockchainWitnessConfigSchema\n\n/** @deprecated use EvmWitnessConfig version instead */\nexport type BlockchainWitnessConfig<TAdditional extends EmptyObject | Payload | void = void, TSchema extends string | void = void> = WitnessConfig<\n TAdditional,\n TSchema extends void ?\n TAdditional extends Payload ?\n TAdditional['schema']\n : BlockchainWitnessConfigSchema\n : TSchema\n>\n\n/** @deprecated use AdditionalEvmWitnessParams version instead */\nexport type AdditionalBlockchainWitnessParams = {\n providers: Provider[]\n}\n\n/** @deprecated use EvmWitnessParams version instead */\nexport type BlockchainWitnessParams<\n TConfig extends AnyConfigSchema<BlockchainWitnessConfig> = BlockchainWitnessConfig,\n TAdditionalParams extends EmptyObject | void = void,\n> = WitnessParams<\n TConfig,\n WithAdditional<\n {\n providers: () => Promisable<Provider[]>\n },\n TAdditionalParams\n >\n>\n\n/** @deprecated use AbstractEvmWitness version instead */\nexport abstract class AbstractBlockchainWitness<\n TParams extends BlockchainWitnessParams<AnyConfigSchema<BlockchainWitnessConfig>> = BlockchainWitnessParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut> = WitnessModuleEventData<\n WitnessInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends AbstractWitness<TParams, TIn, TOut, TEventData> {\n private _providers: Provider[] | undefined = undefined\n\n async getProvider(cache?: boolean): Promise<Provider | undefined>\n async getProvider(cache: boolean, error: string | true): Promise<Provider>\n async getProvider(cache = false, error?: string | boolean): Promise<Provider | undefined> {\n const providers = await this.getProviders(cache)\n if (providers.length === 0) {\n if (error) {\n throw new Error(typeof error === 'string' ? error : 'No providers available')\n }\n return undefined\n }\n return providers[Date.now() % providers.length] // pick a random provider\n }\n\n async getProviders(cache = false): Promise<Provider[]> {\n const cachedProviders = cache ? this._providers : undefined\n this._providers = cachedProviders ?? (await this.params.providers())\n return this._providers\n }\n}\n"],"mappings":"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","names":["assertEx","providers"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@xyo-network/witness-blockchain-abstract",
3
- "version": "3.6.8",
3
+ "version": "3.6.10",
4
4
  "description": "Primary SDK for using XYO Protocol 2.0",
5
5
  "homepage": "https://xyo.network",
6
6
  "bugs": {
@@ -29,20 +29,20 @@
29
29
  "module": "dist/neutral/index.mjs",
30
30
  "types": "dist/neutral/index.d.ts",
31
31
  "dependencies": {
32
- "@xylabs/assert": "^4.4.34",
33
- "@xylabs/object": "^4.4.34",
34
- "@xylabs/promise": "^4.4.34",
35
- "@xyo-network/abstract-witness": "^3.6.8",
36
- "@xyo-network/module-model": "^3.6.8",
37
- "@xyo-network/payload-model": "^3.6.8",
38
- "@xyo-network/witness-model": "^3.6.8",
39
- "ethers": "6.13.4"
32
+ "@xylabs/assert": "^4.5.1",
33
+ "@xylabs/object": "^4.5.1",
34
+ "@xylabs/promise": "^4.5.1",
35
+ "@xyo-network/abstract-witness": "^3.6.10",
36
+ "@xyo-network/module-model": "^3.6.10",
37
+ "@xyo-network/payload-model": "^3.6.10",
38
+ "@xyo-network/witness-model": "^3.6.10",
39
+ "ethers": "6.13.5"
40
40
  },
41
41
  "devDependencies": {
42
42
  "@xylabs/ts-scripts-yarn3": "^4.2.6",
43
43
  "@xylabs/tsconfig": "^4.2.6",
44
- "ethers": "6.13.4",
45
- "typescript": "^5.7.2"
44
+ "ethers": "6.13.5",
45
+ "typescript": "^5.7.3"
46
46
  },
47
47
  "publishConfig": {
48
48
  "access": "public"