@xyo-network/witness-blockchain-abstract 3.18.9 → 4.0.0

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.
@@ -108,35 +108,7 @@ var getProvidersFromEnv = (count = 1, chainId = 1, options = {}) => {
108
108
  }
109
109
  return result;
110
110
  };
111
-
112
- // src/model.ts
113
- var BlockchainAddressSchema = "network.xyo.blockchain.address";
114
-
115
- // src/Witness.ts
116
- import { AbstractWitness } from "@xyo-network/abstract-witness";
117
- var BlockchainWitnessConfigSchema = "network.xyo.blockchain.witness";
118
- var AbstractBlockchainWitness = class extends AbstractWitness {
119
- _providers = void 0;
120
- async getProvider(cache = false, error) {
121
- const providers2 = await this.getProviders(cache);
122
- if (providers2.length === 0) {
123
- if (error) {
124
- throw new Error(typeof error === "string" ? error : "No providers available");
125
- }
126
- return void 0;
127
- }
128
- return providers2[Date.now() % providers2.length];
129
- }
130
- async getProviders(cache = false) {
131
- const cachedProviders = cache ? this._providers : void 0;
132
- this._providers = cachedProviders ?? await this.params.providers();
133
- return this._providers;
134
- }
135
- };
136
111
  export {
137
- AbstractBlockchainWitness,
138
- BlockchainAddressSchema,
139
- BlockchainWitnessConfigSchema,
140
112
  checkIpfsUrl,
141
113
  getProviderFromEnv,
142
114
  getProvidersFromEnv,
@@ -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,\n 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 ?? 'infura') {\n case 'quicknode': {\n quicknodeCases()\n break\n }\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","/* eslint-disable sonarjs/deprecation */\nimport 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","/* eslint-disable sonarjs/deprecation */\nimport 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
+ {"version":3,"sources":["../../src/lib/checkIpfsUrl.ts","../../src/lib/getProviderFromEnv.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,\n 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 ?? 'infura') {\n case 'quicknode': {\n quicknodeCases()\n break\n }\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"],"mappings":"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","names":["assertEx"]}
@@ -108,35 +108,7 @@ var getProvidersFromEnv = (count = 1, chainId = 1, options = {}) => {
108
108
  }
109
109
  return result;
110
110
  };
111
-
112
- // src/model.ts
113
- var BlockchainAddressSchema = "network.xyo.blockchain.address";
114
-
115
- // src/Witness.ts
116
- import { AbstractWitness } from "@xyo-network/abstract-witness";
117
- var BlockchainWitnessConfigSchema = "network.xyo.blockchain.witness";
118
- var AbstractBlockchainWitness = class extends AbstractWitness {
119
- _providers = void 0;
120
- async getProvider(cache = false, error) {
121
- const providers2 = await this.getProviders(cache);
122
- if (providers2.length === 0) {
123
- if (error) {
124
- throw new Error(typeof error === "string" ? error : "No providers available");
125
- }
126
- return void 0;
127
- }
128
- return providers2[Date.now() % providers2.length];
129
- }
130
- async getProviders(cache = false) {
131
- const cachedProviders = cache ? this._providers : void 0;
132
- this._providers = cachedProviders ?? await this.params.providers();
133
- return this._providers;
134
- }
135
- };
136
111
  export {
137
- AbstractBlockchainWitness,
138
- BlockchainAddressSchema,
139
- BlockchainWitnessConfigSchema,
140
112
  checkIpfsUrl,
141
113
  getProviderFromEnv,
142
114
  getProvidersFromEnv,
@@ -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,\n 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 ?? 'infura') {\n case 'quicknode': {\n quicknodeCases()\n break\n }\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","/* eslint-disable sonarjs/deprecation */\nimport 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","/* eslint-disable sonarjs/deprecation */\nimport 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
+ {"version":3,"sources":["../../src/lib/checkIpfsUrl.ts","../../src/lib/getProviderFromEnv.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,\n 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 ?? 'infura') {\n case 'quicknode': {\n quicknodeCases()\n break\n }\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"],"mappings":"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","names":["assertEx"]}
@@ -108,35 +108,7 @@ var getProvidersFromEnv = (count = 1, chainId = 1, options = {}) => {
108
108
  }
109
109
  return result;
110
110
  };
111
-
112
- // src/model.ts
113
- var BlockchainAddressSchema = "network.xyo.blockchain.address";
114
-
115
- // src/Witness.ts
116
- import { AbstractWitness } from "@xyo-network/abstract-witness";
117
- var BlockchainWitnessConfigSchema = "network.xyo.blockchain.witness";
118
- var AbstractBlockchainWitness = class extends AbstractWitness {
119
- _providers = void 0;
120
- async getProvider(cache = false, error) {
121
- const providers2 = await this.getProviders(cache);
122
- if (providers2.length === 0) {
123
- if (error) {
124
- throw new Error(typeof error === "string" ? error : "No providers available");
125
- }
126
- return void 0;
127
- }
128
- return providers2[Date.now() % providers2.length];
129
- }
130
- async getProviders(cache = false) {
131
- const cachedProviders = cache ? this._providers : void 0;
132
- this._providers = cachedProviders ?? await this.params.providers();
133
- return this._providers;
134
- }
135
- };
136
111
  export {
137
- AbstractBlockchainWitness,
138
- BlockchainAddressSchema,
139
- BlockchainWitnessConfigSchema,
140
112
  checkIpfsUrl,
141
113
  getProviderFromEnv,
142
114
  getProvidersFromEnv,
@@ -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,\n 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 ?? 'infura') {\n case 'quicknode': {\n quicknodeCases()\n break\n }\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","/* eslint-disable sonarjs/deprecation */\nimport 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","/* eslint-disable sonarjs/deprecation */\nimport 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
+ {"version":3,"sources":["../../src/lib/checkIpfsUrl.ts","../../src/lib/getProviderFromEnv.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,\n 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 ?? 'infura') {\n case 'quicknode': {\n quicknodeCases()\n break\n }\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"],"mappings":"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","names":["assertEx"]}
@@ -1,4 +1,2 @@
1
1
  export * from './lib/index.ts';
2
- export * from './model.ts';
3
- export * from './Witness.ts';
4
2
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAA;AAC9B,cAAc,YAAY,CAAA;AAC1B,cAAc,cAAc,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAA"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@xyo-network/witness-blockchain-abstract",
3
- "version": "3.18.9",
3
+ "version": "4.0.0",
4
4
  "description": "Primary SDK for using XYO Protocol 2.0",
5
5
  "homepage": "https://xyo.network",
6
6
  "bugs": {
@@ -29,18 +29,18 @@
29
29
  "module": "dist/neutral/index.mjs",
30
30
  "types": "dist/types/index.d.ts",
31
31
  "dependencies": {
32
- "@xylabs/assert": "^4.11.21",
33
- "@xylabs/object": "^4.11.21",
34
- "@xylabs/promise": "^4.11.21",
35
- "@xyo-network/abstract-witness": "^3.18.9",
36
- "@xyo-network/module-model": "^3.18.9",
37
- "@xyo-network/payload-model": "^3.18.9",
38
- "@xyo-network/witness-model": "^3.18.9",
39
- "ethers": "^6.14.4"
32
+ "@xylabs/assert": "^4.12.30",
33
+ "@xylabs/object": "^4.12.30",
34
+ "@xylabs/promise": "^4.12.30",
35
+ "@xyo-network/abstract-witness": "^4.0.0",
36
+ "@xyo-network/module-model": "^4.0.0",
37
+ "@xyo-network/payload-model": "^4.0.0",
38
+ "@xyo-network/witness-model": "^4.0.0",
39
+ "ethers": "^6.15.0"
40
40
  },
41
41
  "devDependencies": {
42
- "@xylabs/ts-scripts-yarn3": "^6.5.8",
43
- "@xylabs/tsconfig": "^6.5.8",
42
+ "@xylabs/ts-scripts-yarn3": "^6.5.12",
43
+ "@xylabs/tsconfig": "^6.5.12",
44
44
  "typescript": "^5.8.3"
45
45
  },
46
46
  "publishConfig": {
package/src/index.ts CHANGED
@@ -1,3 +1 @@
1
1
  export * from './lib/index.ts'
2
- export * from './model.ts'
3
- export * from './Witness.ts'
@@ -1,29 +0,0 @@
1
- import type { EmptyObject, WithAdditional } from '@xylabs/object';
2
- import type { Promisable } from '@xylabs/promise';
3
- import { AbstractWitness } from '@xyo-network/abstract-witness';
4
- import type { AnyConfigSchema } from '@xyo-network/module-model';
5
- import type { Payload } from '@xyo-network/payload-model';
6
- import type { WitnessConfig, WitnessInstance, WitnessModuleEventData, WitnessParams } from '@xyo-network/witness-model';
7
- import type { Provider } from 'ethers';
8
- /** @deprecated use EvmWitnessConfigSchema version instead */
9
- export declare const BlockchainWitnessConfigSchema: "network.xyo.blockchain.witness";
10
- /** @deprecated use EvmWitnessConfigSchema version instead */
11
- export type BlockchainWitnessConfigSchema = typeof BlockchainWitnessConfigSchema;
12
- /** @deprecated use EvmWitnessConfig version instead */
13
- export type BlockchainWitnessConfig<TAdditional extends EmptyObject | Payload | void = void, TSchema extends string | void = void> = WitnessConfig<TAdditional, TSchema extends void ? TAdditional extends Payload ? TAdditional['schema'] : BlockchainWitnessConfigSchema : TSchema>;
14
- /** @deprecated use AdditionalEvmWitnessParams version instead */
15
- export type AdditionalBlockchainWitnessParams = {
16
- providers: Provider[];
17
- };
18
- /** @deprecated use EvmWitnessParams version instead */
19
- export type BlockchainWitnessParams<TConfig extends AnyConfigSchema<BlockchainWitnessConfig> = BlockchainWitnessConfig, TAdditionalParams extends EmptyObject | void = void> = WitnessParams<TConfig, WithAdditional<{
20
- providers: () => Promisable<Provider[]>;
21
- }, TAdditionalParams>>;
22
- /** @deprecated use AbstractEvmWitness version instead */
23
- export declare abstract class AbstractBlockchainWitness<TParams extends BlockchainWitnessParams<AnyConfigSchema<BlockchainWitnessConfig>> = BlockchainWitnessParams, TIn extends Payload = Payload, TOut extends Payload = Payload, TEventData extends WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut> = WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut>> extends AbstractWitness<TParams, TIn, TOut, TEventData> {
24
- private _providers;
25
- getProvider(cache?: boolean): Promise<Provider | undefined>;
26
- getProvider(cache: boolean, error: string | true): Promise<Provider>;
27
- getProviders(cache?: boolean): Promise<Provider[]>;
28
- }
29
- //# sourceMappingURL=Witness.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Witness.d.ts","sourceRoot":"","sources":["../../src/Witness.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AACjE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AACjD,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAC/D,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAChE,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACzD,OAAO,KAAK,EACV,aAAa,EAAE,eAAe,EAAE,sBAAsB,EAAE,aAAa,EACtE,MAAM,4BAA4B,CAAA;AACnC,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAA;AAEtC,6DAA6D;AAC7D,eAAO,MAAM,6BAA6B,EAAG,gCAAyC,CAAA;AACtF,6DAA6D;AAC7D,MAAM,MAAM,6BAA6B,GAAG,OAAO,6BAA6B,CAAA;AAEhF,uDAAuD;AACvD,MAAM,MAAM,uBAAuB,CAAC,WAAW,SAAS,WAAW,GAAG,OAAO,GAAG,IAAI,GAAG,IAAI,EAAE,OAAO,SAAS,MAAM,GAAG,IAAI,GAAG,IAAI,IAAI,aAAa,CAChJ,WAAW,EACX,OAAO,SAAS,IAAI,GAClB,WAAW,SAAS,OAAO,GACzB,WAAW,CAAC,QAAQ,CAAC,GACnB,6BAA6B,GAC/B,OAAO,CACZ,CAAA;AAED,iEAAiE;AACjE,MAAM,MAAM,iCAAiC,GAAG;IAC9C,SAAS,EAAE,QAAQ,EAAE,CAAA;CACtB,CAAA;AAED,uDAAuD;AACvD,MAAM,MAAM,uBAAuB,CACjC,OAAO,SAAS,eAAe,CAAC,uBAAuB,CAAC,GAAG,uBAAuB,EAClF,iBAAiB,SAAS,WAAW,GAAG,IAAI,GAAG,IAAI,IACjD,aAAa,CACf,OAAO,EACP,cAAc,CACZ;IACE,SAAS,EAAE,MAAM,UAAU,CAAC,QAAQ,EAAE,CAAC,CAAA;CACxC,EACD,iBAAiB,CAClB,CACF,CAAA;AAED,yDAAyD;AACzD,8BAAsB,yBAAyB,CAC7C,OAAO,SAAS,uBAAuB,CAAC,eAAe,CAAC,uBAAuB,CAAC,CAAC,GAAG,uBAAuB,EAC3G,GAAG,SAAS,OAAO,GAAG,OAAO,EAC7B,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACvD,OAAO,CAAC,UAAU,CAAoC;IAEhD,WAAW,CAAC,KAAK,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,QAAQ,GAAG,SAAS,CAAC;IAC3D,WAAW,CAAC,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI,GAAG,OAAO,CAAC,QAAQ,CAAC;IAYpE,YAAY,CAAC,KAAK,UAAQ,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC;CAKvD"}
@@ -1,12 +0,0 @@
1
- import type { Payload } from '@xyo-network/payload-model';
2
- /** @deprecated use EvmAddressSchema version instead */
3
- export declare const BlockchainAddressSchema: "network.xyo.blockchain.address";
4
- /** @deprecated use EvmAddressSchema version instead */
5
- export type BlockchainAddressSchema = typeof BlockchainAddressSchema;
6
- /** @deprecated use EvmAddress version instead */
7
- export type BlockchainAddress = Payload<{
8
- address?: string;
9
- blockTag?: string | number;
10
- chainId?: number;
11
- }, BlockchainAddressSchema>;
12
- //# sourceMappingURL=model.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"model.d.ts","sourceRoot":"","sources":["../../src/model.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEzD,uDAAuD;AACvD,eAAO,MAAM,uBAAuB,EAAG,gCAAyC,CAAA;AAEhF,uDAAuD;AACvD,MAAM,MAAM,uBAAuB,GAAG,OAAO,uBAAuB,CAAA;AAEpE,iDAAiD;AACjD,MAAM,MAAM,iBAAiB,GAAG,OAAO,CACrC;IACE,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,QAAQ,CAAC,EAAE,MAAM,GAAG,MAAM,CAAA;IAC1B,OAAO,CAAC,EAAE,MAAM,CAAA;CACjB,EACD,uBAAuB,CACxB,CAAA"}
package/src/Witness.ts DELETED
@@ -1,77 +0,0 @@
1
- /* eslint-disable sonarjs/deprecation */
2
- import type { EmptyObject, WithAdditional } from '@xylabs/object'
3
- import type { Promisable } from '@xylabs/promise'
4
- import { AbstractWitness } from '@xyo-network/abstract-witness'
5
- import type { AnyConfigSchema } from '@xyo-network/module-model'
6
- import type { Payload } from '@xyo-network/payload-model'
7
- import type {
8
- WitnessConfig, WitnessInstance, WitnessModuleEventData, WitnessParams,
9
- } from '@xyo-network/witness-model'
10
- import type { Provider } from 'ethers'
11
-
12
- /** @deprecated use EvmWitnessConfigSchema version instead */
13
- export const BlockchainWitnessConfigSchema = 'network.xyo.blockchain.witness' as const
14
- /** @deprecated use EvmWitnessConfigSchema version instead */
15
- export type BlockchainWitnessConfigSchema = typeof BlockchainWitnessConfigSchema
16
-
17
- /** @deprecated use EvmWitnessConfig version instead */
18
- export type BlockchainWitnessConfig<TAdditional extends EmptyObject | Payload | void = void, TSchema extends string | void = void> = WitnessConfig<
19
- TAdditional,
20
- TSchema extends void ?
21
- TAdditional extends Payload ?
22
- TAdditional['schema']
23
- : BlockchainWitnessConfigSchema
24
- : TSchema
25
- >
26
-
27
- /** @deprecated use AdditionalEvmWitnessParams version instead */
28
- export type AdditionalBlockchainWitnessParams = {
29
- providers: Provider[]
30
- }
31
-
32
- /** @deprecated use EvmWitnessParams version instead */
33
- export type BlockchainWitnessParams<
34
- TConfig extends AnyConfigSchema<BlockchainWitnessConfig> = BlockchainWitnessConfig,
35
- TAdditionalParams extends EmptyObject | void = void,
36
- > = WitnessParams<
37
- TConfig,
38
- WithAdditional<
39
- {
40
- providers: () => Promisable<Provider[]>
41
- },
42
- TAdditionalParams
43
- >
44
- >
45
-
46
- /** @deprecated use AbstractEvmWitness version instead */
47
- export abstract class AbstractBlockchainWitness<
48
- TParams extends BlockchainWitnessParams<AnyConfigSchema<BlockchainWitnessConfig>> = BlockchainWitnessParams,
49
- TIn extends Payload = Payload,
50
- TOut extends Payload = Payload,
51
- TEventData extends WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut> = WitnessModuleEventData<
52
- WitnessInstance<TParams, TIn, TOut>,
53
- TIn,
54
- TOut
55
- >,
56
- > extends AbstractWitness<TParams, TIn, TOut, TEventData> {
57
- private _providers: Provider[] | undefined = undefined
58
-
59
- async getProvider(cache?: boolean): Promise<Provider | undefined>
60
- async getProvider(cache: boolean, error: string | true): Promise<Provider>
61
- async getProvider(cache = false, error?: string | boolean): Promise<Provider | undefined> {
62
- const providers = await this.getProviders(cache)
63
- if (providers.length === 0) {
64
- if (error) {
65
- throw new Error(typeof error === 'string' ? error : 'No providers available')
66
- }
67
- return undefined
68
- }
69
- return providers[Date.now() % providers.length] // pick a random provider
70
- }
71
-
72
- async getProviders(cache = false): Promise<Provider[]> {
73
- const cachedProviders = cache ? this._providers : undefined
74
- this._providers = cachedProviders ?? (await this.params.providers())
75
- return this._providers
76
- }
77
- }
package/src/model.ts DELETED
@@ -1,18 +0,0 @@
1
- /* eslint-disable sonarjs/deprecation */
2
- import type { Payload } from '@xyo-network/payload-model'
3
-
4
- /** @deprecated use EvmAddressSchema version instead */
5
- export const BlockchainAddressSchema = 'network.xyo.blockchain.address' as const
6
-
7
- /** @deprecated use EvmAddressSchema version instead */
8
- export type BlockchainAddressSchema = typeof BlockchainAddressSchema
9
-
10
- /** @deprecated use EvmAddress version instead */
11
- export type BlockchainAddress = Payload<
12
- {
13
- address?: string
14
- blockTag?: string | number
15
- chainId?: number
16
- },
17
- BlockchainAddressSchema
18
- >