@xyo-network/witness-blockchain-abstract 2.111.3 → 3.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.
- package/dist/browser/index.d.ts +48 -4
- package/dist/neutral/index.d.ts +48 -4
- package/dist/node/index.d.ts +48 -4
- package/dist/node/index.mjs +6 -5
- package/dist/node/index.mjs.map +1 -1
- package/package.json +11 -30
- package/dist/browser/Witness.d.cts +0 -23
- package/dist/browser/Witness.d.cts.map +0 -1
- package/dist/browser/Witness.d.mts +0 -23
- package/dist/browser/Witness.d.mts.map +0 -1
- package/dist/browser/Witness.d.ts +0 -23
- package/dist/browser/Witness.d.ts.map +0 -1
- package/dist/browser/index.cjs +0 -168
- package/dist/browser/index.cjs.map +0 -1
- package/dist/browser/index.d.cts +0 -4
- package/dist/browser/index.d.cts.map +0 -1
- package/dist/browser/index.d.mts +0 -4
- package/dist/browser/index.d.mts.map +0 -1
- package/dist/browser/index.d.ts.map +0 -1
- package/dist/browser/lib/checkIpfsUrl.d.cts +0 -2
- package/dist/browser/lib/checkIpfsUrl.d.cts.map +0 -1
- package/dist/browser/lib/checkIpfsUrl.d.mts +0 -2
- package/dist/browser/lib/checkIpfsUrl.d.mts.map +0 -1
- package/dist/browser/lib/checkIpfsUrl.d.ts +0 -2
- package/dist/browser/lib/checkIpfsUrl.d.ts.map +0 -1
- package/dist/browser/lib/getProviderFromEnv.d.cts +0 -14
- package/dist/browser/lib/getProviderFromEnv.d.cts.map +0 -1
- package/dist/browser/lib/getProviderFromEnv.d.mts +0 -14
- package/dist/browser/lib/getProviderFromEnv.d.mts.map +0 -1
- package/dist/browser/lib/getProviderFromEnv.d.ts +0 -14
- package/dist/browser/lib/getProviderFromEnv.d.ts.map +0 -1
- package/dist/browser/lib/index.d.cts +0 -3
- package/dist/browser/lib/index.d.cts.map +0 -1
- package/dist/browser/lib/index.d.mts +0 -3
- package/dist/browser/lib/index.d.mts.map +0 -1
- package/dist/browser/lib/index.d.ts +0 -3
- package/dist/browser/lib/index.d.ts.map +0 -1
- package/dist/browser/model.d.cts +0 -9
- package/dist/browser/model.d.cts.map +0 -1
- package/dist/browser/model.d.mts +0 -9
- package/dist/browser/model.d.mts.map +0 -1
- package/dist/browser/model.d.ts +0 -9
- package/dist/browser/model.d.ts.map +0 -1
- package/dist/neutral/Witness.d.cts +0 -23
- package/dist/neutral/Witness.d.cts.map +0 -1
- package/dist/neutral/Witness.d.mts +0 -23
- package/dist/neutral/Witness.d.mts.map +0 -1
- package/dist/neutral/Witness.d.ts +0 -23
- package/dist/neutral/Witness.d.ts.map +0 -1
- package/dist/neutral/index.cjs +0 -168
- package/dist/neutral/index.cjs.map +0 -1
- package/dist/neutral/index.d.cts +0 -4
- package/dist/neutral/index.d.cts.map +0 -1
- package/dist/neutral/index.d.mts +0 -4
- package/dist/neutral/index.d.mts.map +0 -1
- package/dist/neutral/index.d.ts.map +0 -1
- package/dist/neutral/lib/checkIpfsUrl.d.cts +0 -2
- package/dist/neutral/lib/checkIpfsUrl.d.cts.map +0 -1
- package/dist/neutral/lib/checkIpfsUrl.d.mts +0 -2
- package/dist/neutral/lib/checkIpfsUrl.d.mts.map +0 -1
- package/dist/neutral/lib/checkIpfsUrl.d.ts +0 -2
- package/dist/neutral/lib/checkIpfsUrl.d.ts.map +0 -1
- package/dist/neutral/lib/getProviderFromEnv.d.cts +0 -14
- package/dist/neutral/lib/getProviderFromEnv.d.cts.map +0 -1
- package/dist/neutral/lib/getProviderFromEnv.d.mts +0 -14
- package/dist/neutral/lib/getProviderFromEnv.d.mts.map +0 -1
- package/dist/neutral/lib/getProviderFromEnv.d.ts +0 -14
- package/dist/neutral/lib/getProviderFromEnv.d.ts.map +0 -1
- package/dist/neutral/lib/index.d.cts +0 -3
- package/dist/neutral/lib/index.d.cts.map +0 -1
- package/dist/neutral/lib/index.d.mts +0 -3
- package/dist/neutral/lib/index.d.mts.map +0 -1
- package/dist/neutral/lib/index.d.ts +0 -3
- package/dist/neutral/lib/index.d.ts.map +0 -1
- package/dist/neutral/model.d.cts +0 -9
- package/dist/neutral/model.d.cts.map +0 -1
- package/dist/neutral/model.d.mts +0 -9
- package/dist/neutral/model.d.mts.map +0 -1
- package/dist/neutral/model.d.ts +0 -9
- package/dist/neutral/model.d.ts.map +0 -1
- package/dist/node/Witness.d.cts +0 -23
- package/dist/node/Witness.d.cts.map +0 -1
- package/dist/node/Witness.d.mts +0 -23
- package/dist/node/Witness.d.mts.map +0 -1
- package/dist/node/Witness.d.ts +0 -23
- package/dist/node/Witness.d.ts.map +0 -1
- package/dist/node/index.cjs +0 -177
- package/dist/node/index.cjs.map +0 -1
- package/dist/node/index.d.cts +0 -4
- package/dist/node/index.d.cts.map +0 -1
- package/dist/node/index.d.mts +0 -4
- package/dist/node/index.d.mts.map +0 -1
- package/dist/node/index.d.ts.map +0 -1
- package/dist/node/lib/checkIpfsUrl.d.cts +0 -2
- package/dist/node/lib/checkIpfsUrl.d.cts.map +0 -1
- package/dist/node/lib/checkIpfsUrl.d.mts +0 -2
- package/dist/node/lib/checkIpfsUrl.d.mts.map +0 -1
- package/dist/node/lib/checkIpfsUrl.d.ts +0 -2
- package/dist/node/lib/checkIpfsUrl.d.ts.map +0 -1
- package/dist/node/lib/getProviderFromEnv.d.cts +0 -14
- package/dist/node/lib/getProviderFromEnv.d.cts.map +0 -1
- package/dist/node/lib/getProviderFromEnv.d.mts +0 -14
- package/dist/node/lib/getProviderFromEnv.d.mts.map +0 -1
- package/dist/node/lib/getProviderFromEnv.d.ts +0 -14
- package/dist/node/lib/getProviderFromEnv.d.ts.map +0 -1
- package/dist/node/lib/index.d.cts +0 -3
- package/dist/node/lib/index.d.cts.map +0 -1
- package/dist/node/lib/index.d.mts +0 -3
- package/dist/node/lib/index.d.mts.map +0 -1
- package/dist/node/lib/index.d.ts +0 -3
- package/dist/node/lib/index.d.ts.map +0 -1
- package/dist/node/model.d.cts +0 -9
- package/dist/node/model.d.cts.map +0 -1
- package/dist/node/model.d.mts +0 -9
- package/dist/node/model.d.mts.map +0 -1
- package/dist/node/model.d.ts +0 -9
- package/dist/node/model.d.ts.map +0 -1
package/dist/browser/index.d.ts
CHANGED
|
@@ -1,4 +1,48 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
1
|
+
import { Provider } from 'ethers';
|
|
2
|
+
import { Payload } from '@xyo-network/payload-model';
|
|
3
|
+
import { EmptyObject, WithAdditional } from '@xylabs/object';
|
|
4
|
+
import { Promisable } from '@xylabs/promise';
|
|
5
|
+
import { AbstractWitness } from '@xyo-network/abstract-witness';
|
|
6
|
+
import { AnyConfigSchema } from '@xyo-network/module-model';
|
|
7
|
+
import { WitnessConfig, WitnessParams, WitnessModuleEventData, WitnessInstance } from '@xyo-network/witness-model';
|
|
8
|
+
|
|
9
|
+
declare const checkIpfsUrl: (urlToCheck: string, ipfsGateway?: string) => string;
|
|
10
|
+
|
|
11
|
+
type ProviderSource = 'infura' | 'quicknode';
|
|
12
|
+
type ProviderType = 'rpc' | 'wss';
|
|
13
|
+
interface GetProvidersFromEnvOptions {
|
|
14
|
+
providerSource?: ProviderSource;
|
|
15
|
+
providerType?: ProviderType;
|
|
16
|
+
}
|
|
17
|
+
declare const getProviderFromEnv: (chainId?: number, { providerSource, providerType }?: GetProvidersFromEnvOptions) => Provider;
|
|
18
|
+
declare const getSharedProviderFromEnv: (chainId?: number, options?: {
|
|
19
|
+
providerSource?: ProviderSource;
|
|
20
|
+
providerType?: ProviderType;
|
|
21
|
+
}) => Provider;
|
|
22
|
+
declare const getProvidersFromEnv: (count?: number, chainId?: number, options?: GetProvidersFromEnvOptions) => Provider[];
|
|
23
|
+
|
|
24
|
+
declare const BlockchainAddressSchema: "network.xyo.blockchain.address";
|
|
25
|
+
type BlockchainAddressSchema = typeof BlockchainAddressSchema;
|
|
26
|
+
type BlockchainAddress = Payload<{
|
|
27
|
+
address?: string;
|
|
28
|
+
blockTag?: string | number;
|
|
29
|
+
chainId?: number;
|
|
30
|
+
}, BlockchainAddressSchema>;
|
|
31
|
+
|
|
32
|
+
declare const BlockchainWitnessConfigSchema: "network.xyo.blockchain.witness";
|
|
33
|
+
type BlockchainWitnessConfigSchema = typeof BlockchainWitnessConfigSchema;
|
|
34
|
+
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>;
|
|
35
|
+
type AdditionalBlockchainWitnessParams = {
|
|
36
|
+
providers: Provider[];
|
|
37
|
+
};
|
|
38
|
+
type BlockchainWitnessParams<TConfig extends AnyConfigSchema<BlockchainWitnessConfig> = BlockchainWitnessConfig, TAdditionalParams extends EmptyObject | void = void> = WitnessParams<TConfig, WithAdditional<{
|
|
39
|
+
providers: () => Promisable<Provider[]>;
|
|
40
|
+
}, TAdditionalParams>>;
|
|
41
|
+
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> {
|
|
42
|
+
private _providers;
|
|
43
|
+
getProvider(cache?: boolean): Promise<Provider | undefined>;
|
|
44
|
+
getProvider(cache: boolean, error: string | true): Promise<Provider>;
|
|
45
|
+
getProviders(cache?: boolean): Promise<Provider[]>;
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
export { AbstractBlockchainWitness, type AdditionalBlockchainWitnessParams, type BlockchainAddress, BlockchainAddressSchema, type BlockchainWitnessConfig, BlockchainWitnessConfigSchema, type BlockchainWitnessParams, type GetProvidersFromEnvOptions, type ProviderSource, type ProviderType, checkIpfsUrl, getProviderFromEnv, getProvidersFromEnv, getSharedProviderFromEnv };
|
package/dist/neutral/index.d.ts
CHANGED
|
@@ -1,4 +1,48 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
1
|
+
import { Provider } from 'ethers';
|
|
2
|
+
import { Payload } from '@xyo-network/payload-model';
|
|
3
|
+
import { EmptyObject, WithAdditional } from '@xylabs/object';
|
|
4
|
+
import { Promisable } from '@xylabs/promise';
|
|
5
|
+
import { AbstractWitness } from '@xyo-network/abstract-witness';
|
|
6
|
+
import { AnyConfigSchema } from '@xyo-network/module-model';
|
|
7
|
+
import { WitnessConfig, WitnessParams, WitnessModuleEventData, WitnessInstance } from '@xyo-network/witness-model';
|
|
8
|
+
|
|
9
|
+
declare const checkIpfsUrl: (urlToCheck: string, ipfsGateway?: string) => string;
|
|
10
|
+
|
|
11
|
+
type ProviderSource = 'infura' | 'quicknode';
|
|
12
|
+
type ProviderType = 'rpc' | 'wss';
|
|
13
|
+
interface GetProvidersFromEnvOptions {
|
|
14
|
+
providerSource?: ProviderSource;
|
|
15
|
+
providerType?: ProviderType;
|
|
16
|
+
}
|
|
17
|
+
declare const getProviderFromEnv: (chainId?: number, { providerSource, providerType }?: GetProvidersFromEnvOptions) => Provider;
|
|
18
|
+
declare const getSharedProviderFromEnv: (chainId?: number, options?: {
|
|
19
|
+
providerSource?: ProviderSource;
|
|
20
|
+
providerType?: ProviderType;
|
|
21
|
+
}) => Provider;
|
|
22
|
+
declare const getProvidersFromEnv: (count?: number, chainId?: number, options?: GetProvidersFromEnvOptions) => Provider[];
|
|
23
|
+
|
|
24
|
+
declare const BlockchainAddressSchema: "network.xyo.blockchain.address";
|
|
25
|
+
type BlockchainAddressSchema = typeof BlockchainAddressSchema;
|
|
26
|
+
type BlockchainAddress = Payload<{
|
|
27
|
+
address?: string;
|
|
28
|
+
blockTag?: string | number;
|
|
29
|
+
chainId?: number;
|
|
30
|
+
}, BlockchainAddressSchema>;
|
|
31
|
+
|
|
32
|
+
declare const BlockchainWitnessConfigSchema: "network.xyo.blockchain.witness";
|
|
33
|
+
type BlockchainWitnessConfigSchema = typeof BlockchainWitnessConfigSchema;
|
|
34
|
+
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>;
|
|
35
|
+
type AdditionalBlockchainWitnessParams = {
|
|
36
|
+
providers: Provider[];
|
|
37
|
+
};
|
|
38
|
+
type BlockchainWitnessParams<TConfig extends AnyConfigSchema<BlockchainWitnessConfig> = BlockchainWitnessConfig, TAdditionalParams extends EmptyObject | void = void> = WitnessParams<TConfig, WithAdditional<{
|
|
39
|
+
providers: () => Promisable<Provider[]>;
|
|
40
|
+
}, TAdditionalParams>>;
|
|
41
|
+
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> {
|
|
42
|
+
private _providers;
|
|
43
|
+
getProvider(cache?: boolean): Promise<Provider | undefined>;
|
|
44
|
+
getProvider(cache: boolean, error: string | true): Promise<Provider>;
|
|
45
|
+
getProviders(cache?: boolean): Promise<Provider[]>;
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
export { AbstractBlockchainWitness, type AdditionalBlockchainWitnessParams, type BlockchainAddress, BlockchainAddressSchema, type BlockchainWitnessConfig, BlockchainWitnessConfigSchema, type BlockchainWitnessParams, type GetProvidersFromEnvOptions, type ProviderSource, type ProviderType, checkIpfsUrl, getProviderFromEnv, getProvidersFromEnv, getSharedProviderFromEnv };
|
package/dist/node/index.d.ts
CHANGED
|
@@ -1,4 +1,48 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
1
|
+
import { Provider } from 'ethers';
|
|
2
|
+
import { Payload } from '@xyo-network/payload-model';
|
|
3
|
+
import { EmptyObject, WithAdditional } from '@xylabs/object';
|
|
4
|
+
import { Promisable } from '@xylabs/promise';
|
|
5
|
+
import { AbstractWitness } from '@xyo-network/abstract-witness';
|
|
6
|
+
import { AnyConfigSchema } from '@xyo-network/module-model';
|
|
7
|
+
import { WitnessConfig, WitnessParams, WitnessModuleEventData, WitnessInstance } from '@xyo-network/witness-model';
|
|
8
|
+
|
|
9
|
+
declare const checkIpfsUrl: (urlToCheck: string, ipfsGateway?: string) => string;
|
|
10
|
+
|
|
11
|
+
type ProviderSource = 'infura' | 'quicknode';
|
|
12
|
+
type ProviderType = 'rpc' | 'wss';
|
|
13
|
+
interface GetProvidersFromEnvOptions {
|
|
14
|
+
providerSource?: ProviderSource;
|
|
15
|
+
providerType?: ProviderType;
|
|
16
|
+
}
|
|
17
|
+
declare const getProviderFromEnv: (chainId?: number, { providerSource, providerType }?: GetProvidersFromEnvOptions) => Provider;
|
|
18
|
+
declare const getSharedProviderFromEnv: (chainId?: number, options?: {
|
|
19
|
+
providerSource?: ProviderSource;
|
|
20
|
+
providerType?: ProviderType;
|
|
21
|
+
}) => Provider;
|
|
22
|
+
declare const getProvidersFromEnv: (count?: number, chainId?: number, options?: GetProvidersFromEnvOptions) => Provider[];
|
|
23
|
+
|
|
24
|
+
declare const BlockchainAddressSchema: "network.xyo.blockchain.address";
|
|
25
|
+
type BlockchainAddressSchema = typeof BlockchainAddressSchema;
|
|
26
|
+
type BlockchainAddress = Payload<{
|
|
27
|
+
address?: string;
|
|
28
|
+
blockTag?: string | number;
|
|
29
|
+
chainId?: number;
|
|
30
|
+
}, BlockchainAddressSchema>;
|
|
31
|
+
|
|
32
|
+
declare const BlockchainWitnessConfigSchema: "network.xyo.blockchain.witness";
|
|
33
|
+
type BlockchainWitnessConfigSchema = typeof BlockchainWitnessConfigSchema;
|
|
34
|
+
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>;
|
|
35
|
+
type AdditionalBlockchainWitnessParams = {
|
|
36
|
+
providers: Provider[];
|
|
37
|
+
};
|
|
38
|
+
type BlockchainWitnessParams<TConfig extends AnyConfigSchema<BlockchainWitnessConfig> = BlockchainWitnessConfig, TAdditionalParams extends EmptyObject | void = void> = WitnessParams<TConfig, WithAdditional<{
|
|
39
|
+
providers: () => Promisable<Provider[]>;
|
|
40
|
+
}, TAdditionalParams>>;
|
|
41
|
+
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> {
|
|
42
|
+
private _providers;
|
|
43
|
+
getProvider(cache?: boolean): Promise<Provider | undefined>;
|
|
44
|
+
getProvider(cache: boolean, error: string | true): Promise<Provider>;
|
|
45
|
+
getProviders(cache?: boolean): Promise<Provider[]>;
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
export { AbstractBlockchainWitness, type AdditionalBlockchainWitnessParams, type BlockchainAddress, BlockchainAddressSchema, type BlockchainWitnessConfig, BlockchainWitnessConfigSchema, type BlockchainWitnessParams, type GetProvidersFromEnvOptions, type ProviderSource, type ProviderType, checkIpfsUrl, getProviderFromEnv, getProvidersFromEnv, getSharedProviderFromEnv };
|
package/dist/node/index.mjs
CHANGED
|
@@ -16,7 +16,7 @@ var checkIpfsUrl = /* @__PURE__ */ __name((urlToCheck, ipfsGateway) => {
|
|
|
16
16
|
host = assertEx(ipfsGateway, () => "No ipfsGateway provided");
|
|
17
17
|
path = url.host === "ipfs" ? `ipfs${path}` : `ipfs/${url.host}${path}`;
|
|
18
18
|
const root = `${protocol}//${host}/${path}`;
|
|
19
|
-
return
|
|
19
|
+
return query?.length > 0 ? `${root}?${query}` : root;
|
|
20
20
|
} else if (allowIpfsIoRepair && protocol === "https" && host === "ipfs.io") {
|
|
21
21
|
protocol = "https:";
|
|
22
22
|
host = assertEx(ipfsGateway, () => "No ipfsGateway provided");
|
|
@@ -26,7 +26,7 @@ var checkIpfsUrl = /* @__PURE__ */ __name((urlToCheck, ipfsGateway) => {
|
|
|
26
26
|
}
|
|
27
27
|
path = pathParts.join("/");
|
|
28
28
|
const root = `${protocol}//${host}/${path}`;
|
|
29
|
-
return
|
|
29
|
+
return query?.length > 0 ? `${root}?${query}` : root;
|
|
30
30
|
} else {
|
|
31
31
|
return urlToCheck;
|
|
32
32
|
}
|
|
@@ -114,7 +114,10 @@ var BlockchainAddressSchema = "network.xyo.blockchain.address";
|
|
|
114
114
|
// src/Witness.ts
|
|
115
115
|
import { AbstractWitness } from "@xyo-network/abstract-witness";
|
|
116
116
|
var BlockchainWitnessConfigSchema = "network.xyo.blockchain.witness";
|
|
117
|
-
var
|
|
117
|
+
var AbstractBlockchainWitness = class extends AbstractWitness {
|
|
118
|
+
static {
|
|
119
|
+
__name(this, "AbstractBlockchainWitness");
|
|
120
|
+
}
|
|
118
121
|
_providers = void 0;
|
|
119
122
|
async getProvider(cache = false, error) {
|
|
120
123
|
const providers2 = await this.getProviders(cache);
|
|
@@ -132,8 +135,6 @@ var _AbstractBlockchainWitness = class _AbstractBlockchainWitness extends Abstra
|
|
|
132
135
|
return this._providers;
|
|
133
136
|
}
|
|
134
137
|
};
|
|
135
|
-
__name(_AbstractBlockchainWitness, "AbstractBlockchainWitness");
|
|
136
|
-
var AbstractBlockchainWitness = _AbstractBlockchainWitness;
|
|
137
138
|
export {
|
|
138
139
|
AbstractBlockchainWitness,
|
|
139
140
|
BlockchainAddressSchema,
|
package/dist/node/index.mjs.map
CHANGED
|
@@ -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 { InfuraProvider, InfuraWebSocketProvider, JsonRpcProvider, Provider, WebSocketProvider } 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 { 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 { EmptyObject, WithAdditional } from '@xylabs/object'\nimport { Promisable } from '@xylabs/promise'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport { AnyConfigSchema } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport { WitnessConfig, WitnessInstance, WitnessModuleEventData, WitnessParams } from '@xyo-network/witness-model'\nimport { 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 { InfuraProvider, InfuraWebSocketProvider, JsonRpcProvider, Provider, WebSocketProvider } 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 { 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 { EmptyObject, WithAdditional } from '@xylabs/object'\nimport { Promisable } from '@xylabs/promise'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport { AnyConfigSchema } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport { WitnessConfig, WitnessInstance, WitnessModuleEventData, WitnessParams } from '@xyo-network/witness-model'\nimport { 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"]}
|
package/package.json
CHANGED
|
@@ -13,49 +13,30 @@
|
|
|
13
13
|
"@xylabs/assert": "^3.6.12",
|
|
14
14
|
"@xylabs/object": "^3.6.12",
|
|
15
15
|
"@xylabs/promise": "^3.6.12",
|
|
16
|
-
"@xyo-network/abstract-witness": "^
|
|
17
|
-
"@xyo-network/module-model": "^
|
|
18
|
-
"@xyo-network/payload-model": "^
|
|
19
|
-
"@xyo-network/witness-model": "^
|
|
16
|
+
"@xyo-network/abstract-witness": "^3.0.0",
|
|
17
|
+
"@xyo-network/module-model": "^3.0.0",
|
|
18
|
+
"@xyo-network/payload-model": "^3.0.0",
|
|
19
|
+
"@xyo-network/witness-model": "^3.0.0",
|
|
20
20
|
"ethers": "6.13.2"
|
|
21
21
|
},
|
|
22
22
|
"devDependencies": {
|
|
23
23
|
"@xylabs/jest-helpers": "^3.6.12",
|
|
24
|
-
"@xylabs/ts-scripts-yarn3": "
|
|
25
|
-
"@xylabs/tsconfig": "
|
|
24
|
+
"@xylabs/ts-scripts-yarn3": "next",
|
|
25
|
+
"@xylabs/tsconfig": "next",
|
|
26
26
|
"ethers": "6.13.2",
|
|
27
27
|
"jest": "^29.7.0",
|
|
28
28
|
"typescript": "^5.5.4"
|
|
29
29
|
},
|
|
30
30
|
"description": "Primary SDK for using XYO Protocol 2.0",
|
|
31
|
-
"types": "dist/node/index.d.mts",
|
|
32
31
|
"exports": {
|
|
33
32
|
".": {
|
|
34
|
-
"
|
|
35
|
-
|
|
36
|
-
"types": "./dist/browser/index.d.cts",
|
|
37
|
-
"default": "./dist/browser/index.cjs"
|
|
38
|
-
},
|
|
39
|
-
"import": {
|
|
40
|
-
"types": "./dist/browser/index.d.mts",
|
|
41
|
-
"default": "./dist/browser/index.mjs"
|
|
42
|
-
}
|
|
43
|
-
},
|
|
44
|
-
"node": {
|
|
45
|
-
"require": {
|
|
46
|
-
"types": "./dist/node/index.d.mts",
|
|
47
|
-
"default": "./dist/node/index.cjs"
|
|
48
|
-
},
|
|
49
|
-
"import": {
|
|
50
|
-
"types": "./dist/node/index.d.mts",
|
|
51
|
-
"default": "./dist/node/index.mjs"
|
|
52
|
-
}
|
|
53
|
-
}
|
|
33
|
+
"types": "./dist/neutral/index.d.ts",
|
|
34
|
+
"default": "./dist/neutral/index.mjs"
|
|
54
35
|
},
|
|
55
36
|
"./package.json": "./package.json"
|
|
56
37
|
},
|
|
57
|
-
"
|
|
58
|
-
"module": "dist/
|
|
38
|
+
"types": "dist/neutral/index.d.ts",
|
|
39
|
+
"module": "dist/neutral/index.mjs",
|
|
59
40
|
"homepage": "https://xyo.network",
|
|
60
41
|
"license": "LGPL-3.0-only",
|
|
61
42
|
"publishConfig": {
|
|
@@ -66,6 +47,6 @@
|
|
|
66
47
|
"url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
|
|
67
48
|
},
|
|
68
49
|
"sideEffects": false,
|
|
69
|
-
"version": "
|
|
50
|
+
"version": "3.0.0",
|
|
70
51
|
"type": "module"
|
|
71
52
|
}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import { EmptyObject, WithAdditional } from '@xylabs/object';
|
|
2
|
-
import { Promisable } from '@xylabs/promise';
|
|
3
|
-
import { AbstractWitness } from '@xyo-network/abstract-witness';
|
|
4
|
-
import { AnyConfigSchema } from '@xyo-network/module-model';
|
|
5
|
-
import { Payload } from '@xyo-network/payload-model';
|
|
6
|
-
import { WitnessConfig, WitnessInstance, WitnessModuleEventData, WitnessParams } from '@xyo-network/witness-model';
|
|
7
|
-
import { Provider } from 'ethers';
|
|
8
|
-
export declare const BlockchainWitnessConfigSchema: "network.xyo.blockchain.witness";
|
|
9
|
-
export type BlockchainWitnessConfigSchema = typeof BlockchainWitnessConfigSchema;
|
|
10
|
-
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>;
|
|
11
|
-
export type AdditionalBlockchainWitnessParams = {
|
|
12
|
-
providers: Provider[];
|
|
13
|
-
};
|
|
14
|
-
export type BlockchainWitnessParams<TConfig extends AnyConfigSchema<BlockchainWitnessConfig> = BlockchainWitnessConfig, TAdditionalParams extends EmptyObject | void = void> = WitnessParams<TConfig, WithAdditional<{
|
|
15
|
-
providers: () => Promisable<Provider[]>;
|
|
16
|
-
}, TAdditionalParams>>;
|
|
17
|
-
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> {
|
|
18
|
-
private _providers;
|
|
19
|
-
getProvider(cache?: boolean): Promise<Provider | undefined>;
|
|
20
|
-
getProvider(cache: boolean, error: string | true): Promise<Provider>;
|
|
21
|
-
getProviders(cache?: boolean): Promise<Provider[]>;
|
|
22
|
-
}
|
|
23
|
-
//# sourceMappingURL=Witness.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Witness.d.ts","sourceRoot":"","sources":["../../src/Witness.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC5D,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAC/D,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAC3D,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EAAE,aAAa,EAAE,eAAe,EAAE,sBAAsB,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AAClH,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAA;AAGjC,eAAO,MAAM,6BAA6B,kCAA4C,CAAA;AAEtF,MAAM,MAAM,6BAA6B,GAAG,OAAO,6BAA6B,CAAA;AAGhF,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;AAGD,MAAM,MAAM,iCAAiC,GAAG;IAC9C,SAAS,EAAE,QAAQ,EAAE,CAAA;CACtB,CAAA;AAGD,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;AAGD,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,23 +0,0 @@
|
|
|
1
|
-
import { EmptyObject, WithAdditional } from '@xylabs/object';
|
|
2
|
-
import { Promisable } from '@xylabs/promise';
|
|
3
|
-
import { AbstractWitness } from '@xyo-network/abstract-witness';
|
|
4
|
-
import { AnyConfigSchema } from '@xyo-network/module-model';
|
|
5
|
-
import { Payload } from '@xyo-network/payload-model';
|
|
6
|
-
import { WitnessConfig, WitnessInstance, WitnessModuleEventData, WitnessParams } from '@xyo-network/witness-model';
|
|
7
|
-
import { Provider } from 'ethers';
|
|
8
|
-
export declare const BlockchainWitnessConfigSchema: "network.xyo.blockchain.witness";
|
|
9
|
-
export type BlockchainWitnessConfigSchema = typeof BlockchainWitnessConfigSchema;
|
|
10
|
-
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>;
|
|
11
|
-
export type AdditionalBlockchainWitnessParams = {
|
|
12
|
-
providers: Provider[];
|
|
13
|
-
};
|
|
14
|
-
export type BlockchainWitnessParams<TConfig extends AnyConfigSchema<BlockchainWitnessConfig> = BlockchainWitnessConfig, TAdditionalParams extends EmptyObject | void = void> = WitnessParams<TConfig, WithAdditional<{
|
|
15
|
-
providers: () => Promisable<Provider[]>;
|
|
16
|
-
}, TAdditionalParams>>;
|
|
17
|
-
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> {
|
|
18
|
-
private _providers;
|
|
19
|
-
getProvider(cache?: boolean): Promise<Provider | undefined>;
|
|
20
|
-
getProvider(cache: boolean, error: string | true): Promise<Provider>;
|
|
21
|
-
getProviders(cache?: boolean): Promise<Provider[]>;
|
|
22
|
-
}
|
|
23
|
-
//# sourceMappingURL=Witness.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Witness.d.ts","sourceRoot":"","sources":["../../src/Witness.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC5D,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAC/D,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAC3D,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EAAE,aAAa,EAAE,eAAe,EAAE,sBAAsB,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AAClH,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAA;AAGjC,eAAO,MAAM,6BAA6B,kCAA4C,CAAA;AAEtF,MAAM,MAAM,6BAA6B,GAAG,OAAO,6BAA6B,CAAA;AAGhF,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;AAGD,MAAM,MAAM,iCAAiC,GAAG;IAC9C,SAAS,EAAE,QAAQ,EAAE,CAAA;CACtB,CAAA;AAGD,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;AAGD,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,23 +0,0 @@
|
|
|
1
|
-
import { EmptyObject, WithAdditional } from '@xylabs/object';
|
|
2
|
-
import { Promisable } from '@xylabs/promise';
|
|
3
|
-
import { AbstractWitness } from '@xyo-network/abstract-witness';
|
|
4
|
-
import { AnyConfigSchema } from '@xyo-network/module-model';
|
|
5
|
-
import { Payload } from '@xyo-network/payload-model';
|
|
6
|
-
import { WitnessConfig, WitnessInstance, WitnessModuleEventData, WitnessParams } from '@xyo-network/witness-model';
|
|
7
|
-
import { Provider } from 'ethers';
|
|
8
|
-
export declare const BlockchainWitnessConfigSchema: "network.xyo.blockchain.witness";
|
|
9
|
-
export type BlockchainWitnessConfigSchema = typeof BlockchainWitnessConfigSchema;
|
|
10
|
-
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>;
|
|
11
|
-
export type AdditionalBlockchainWitnessParams = {
|
|
12
|
-
providers: Provider[];
|
|
13
|
-
};
|
|
14
|
-
export type BlockchainWitnessParams<TConfig extends AnyConfigSchema<BlockchainWitnessConfig> = BlockchainWitnessConfig, TAdditionalParams extends EmptyObject | void = void> = WitnessParams<TConfig, WithAdditional<{
|
|
15
|
-
providers: () => Promisable<Provider[]>;
|
|
16
|
-
}, TAdditionalParams>>;
|
|
17
|
-
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> {
|
|
18
|
-
private _providers;
|
|
19
|
-
getProvider(cache?: boolean): Promise<Provider | undefined>;
|
|
20
|
-
getProvider(cache: boolean, error: string | true): Promise<Provider>;
|
|
21
|
-
getProviders(cache?: boolean): Promise<Provider[]>;
|
|
22
|
-
}
|
|
23
|
-
//# sourceMappingURL=Witness.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Witness.d.ts","sourceRoot":"","sources":["../../src/Witness.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC5D,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAC/D,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAC3D,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EAAE,aAAa,EAAE,eAAe,EAAE,sBAAsB,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AAClH,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAA;AAGjC,eAAO,MAAM,6BAA6B,kCAA4C,CAAA;AAEtF,MAAM,MAAM,6BAA6B,GAAG,OAAO,6BAA6B,CAAA;AAGhF,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;AAGD,MAAM,MAAM,iCAAiC,GAAG;IAC9C,SAAS,EAAE,QAAQ,EAAE,CAAA;CACtB,CAAA;AAGD,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;AAGD,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"}
|
package/dist/browser/index.cjs
DELETED
|
@@ -1,168 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
7
|
-
var __export = (target, all) => {
|
|
8
|
-
for (var name in all)
|
|
9
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
-
};
|
|
11
|
-
var __copyProps = (to, from, except, desc) => {
|
|
12
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
-
for (let key of __getOwnPropNames(from))
|
|
14
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
16
|
-
}
|
|
17
|
-
return to;
|
|
18
|
-
};
|
|
19
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
20
|
-
|
|
21
|
-
// src/index.ts
|
|
22
|
-
var src_exports = {};
|
|
23
|
-
__export(src_exports, {
|
|
24
|
-
AbstractBlockchainWitness: () => AbstractBlockchainWitness,
|
|
25
|
-
BlockchainAddressSchema: () => BlockchainAddressSchema,
|
|
26
|
-
BlockchainWitnessConfigSchema: () => BlockchainWitnessConfigSchema,
|
|
27
|
-
checkIpfsUrl: () => checkIpfsUrl,
|
|
28
|
-
getProviderFromEnv: () => getProviderFromEnv,
|
|
29
|
-
getProvidersFromEnv: () => getProvidersFromEnv,
|
|
30
|
-
getSharedProviderFromEnv: () => getSharedProviderFromEnv
|
|
31
|
-
});
|
|
32
|
-
module.exports = __toCommonJS(src_exports);
|
|
33
|
-
|
|
34
|
-
// src/lib/checkIpfsUrl.ts
|
|
35
|
-
var import_assert = require("@xylabs/assert");
|
|
36
|
-
var allowIpfsIoRepair = true;
|
|
37
|
-
var checkIpfsUrl = /* @__PURE__ */ __name((urlToCheck, ipfsGateway) => {
|
|
38
|
-
try {
|
|
39
|
-
const url = new URL(urlToCheck);
|
|
40
|
-
let protocol = url.protocol;
|
|
41
|
-
let host = url.host;
|
|
42
|
-
let path = url.pathname;
|
|
43
|
-
const query = url.search;
|
|
44
|
-
if (protocol === "ipfs:") {
|
|
45
|
-
protocol = "https:";
|
|
46
|
-
host = (0, import_assert.assertEx)(ipfsGateway, () => "No ipfsGateway provided");
|
|
47
|
-
path = url.host === "ipfs" ? `ipfs${path}` : `ipfs/${url.host}${path}`;
|
|
48
|
-
const root = `${protocol}//${host}/${path}`;
|
|
49
|
-
return query?.length > 0 ? `${root}?${query}` : root;
|
|
50
|
-
} else if (allowIpfsIoRepair && protocol === "https" && host === "ipfs.io") {
|
|
51
|
-
protocol = "https:";
|
|
52
|
-
host = (0, import_assert.assertEx)(ipfsGateway, () => "No ipfsGateway provided");
|
|
53
|
-
const pathParts = path.split("/");
|
|
54
|
-
if (pathParts[0] === "ipfs") {
|
|
55
|
-
pathParts.shift();
|
|
56
|
-
}
|
|
57
|
-
path = pathParts.join("/");
|
|
58
|
-
const root = `${protocol}//${host}/${path}`;
|
|
59
|
-
return query?.length > 0 ? `${root}?${query}` : root;
|
|
60
|
-
} else {
|
|
61
|
-
return urlToCheck;
|
|
62
|
-
}
|
|
63
|
-
} catch {
|
|
64
|
-
return urlToCheck;
|
|
65
|
-
}
|
|
66
|
-
}, "checkIpfsUrl");
|
|
67
|
-
|
|
68
|
-
// src/lib/getProviderFromEnv.ts
|
|
69
|
-
var import_assert2 = require("@xylabs/assert");
|
|
70
|
-
var import_ethers = require("ethers");
|
|
71
|
-
var createInfuraRpc = /* @__PURE__ */ __name((chainId) => {
|
|
72
|
-
return process.env.INFURA_PROJECT_ID && process.env.INFURA_PROJECT_SECRET ? new import_ethers.InfuraProvider(chainId, process.env.INFURA_PROJECT_ID) : void 0;
|
|
73
|
-
}, "createInfuraRpc");
|
|
74
|
-
var createInfuraWss = /* @__PURE__ */ __name((chainId) => {
|
|
75
|
-
return process.env.INFURA_PROJECT_ID ? new import_ethers.InfuraWebSocketProvider(chainId, process.env.INFURA_PROJECT_ID) : void 0;
|
|
76
|
-
}, "createInfuraWss");
|
|
77
|
-
var createQuicknodeWss = /* @__PURE__ */ __name((chainId) => {
|
|
78
|
-
const quickNodeWSSUri = process.env.QUICKNODE_WSS_URI;
|
|
79
|
-
return quickNodeWSSUri ? new import_ethers.WebSocketProvider(quickNodeWSSUri, chainId) : void 0;
|
|
80
|
-
}, "createQuicknodeWss");
|
|
81
|
-
var createQuicknodeRpc = /* @__PURE__ */ __name((chainId) => {
|
|
82
|
-
const quickNodeHttpsUri = process.env.QUICKNODE_HTTPS_URI;
|
|
83
|
-
return quickNodeHttpsUri ? new import_ethers.JsonRpcProvider(quickNodeHttpsUri, chainId) : void 0;
|
|
84
|
-
}, "createQuicknodeRpc");
|
|
85
|
-
var getProviderFromEnv = /* @__PURE__ */ __name((chainId = 1, { providerSource = "infura", providerType = "rpc" } = {}) => {
|
|
86
|
-
let provider = void 0;
|
|
87
|
-
const quicknodeCases = /* @__PURE__ */ __name(() => {
|
|
88
|
-
switch (providerType) {
|
|
89
|
-
case "rpc": {
|
|
90
|
-
provider = createQuicknodeRpc(chainId);
|
|
91
|
-
break;
|
|
92
|
-
}
|
|
93
|
-
case "wss": {
|
|
94
|
-
provider = createQuicknodeWss(chainId);
|
|
95
|
-
break;
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
}, "quicknodeCases");
|
|
99
|
-
const infuraCases = /* @__PURE__ */ __name(() => {
|
|
100
|
-
switch (providerType) {
|
|
101
|
-
case "wss": {
|
|
102
|
-
provider = createInfuraWss(chainId);
|
|
103
|
-
break;
|
|
104
|
-
}
|
|
105
|
-
case "rpc": {
|
|
106
|
-
provider = createInfuraRpc(chainId);
|
|
107
|
-
break;
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
}, "infuraCases");
|
|
111
|
-
switch (providerSource) {
|
|
112
|
-
case "quicknode": {
|
|
113
|
-
quicknodeCases();
|
|
114
|
-
break;
|
|
115
|
-
}
|
|
116
|
-
default:
|
|
117
|
-
case "infura": {
|
|
118
|
-
infuraCases();
|
|
119
|
-
break;
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
if (!provider) {
|
|
123
|
-
provider = createInfuraWss(chainId) ?? createInfuraRpc(chainId) ?? createQuicknodeRpc(chainId);
|
|
124
|
-
}
|
|
125
|
-
return (0, import_assert2.assertEx)(provider, () => `Unable to create provider [${chainId}]: ${providerSource}|${providerType}`);
|
|
126
|
-
}, "getProviderFromEnv");
|
|
127
|
-
var providers = {};
|
|
128
|
-
var getSharedProviderFromEnv = /* @__PURE__ */ __name((chainId = 1, options) => {
|
|
129
|
-
const key = `${chainId}:${options ? JSON.stringify(options) : "default"}`;
|
|
130
|
-
providers[key] = providers[key] ?? getProviderFromEnv(chainId, options);
|
|
131
|
-
return providers[key];
|
|
132
|
-
}, "getSharedProviderFromEnv");
|
|
133
|
-
var getProvidersFromEnv = /* @__PURE__ */ __name((count = 1, chainId = 1, options = {}) => {
|
|
134
|
-
const result = [];
|
|
135
|
-
for (let i = 0; i < count; i++) {
|
|
136
|
-
result.push(getProviderFromEnv(chainId, options));
|
|
137
|
-
}
|
|
138
|
-
return result;
|
|
139
|
-
}, "getProvidersFromEnv");
|
|
140
|
-
|
|
141
|
-
// src/model.ts
|
|
142
|
-
var BlockchainAddressSchema = "network.xyo.blockchain.address";
|
|
143
|
-
|
|
144
|
-
// src/Witness.ts
|
|
145
|
-
var import_abstract_witness = require("@xyo-network/abstract-witness");
|
|
146
|
-
var BlockchainWitnessConfigSchema = "network.xyo.blockchain.witness";
|
|
147
|
-
var AbstractBlockchainWitness = class extends import_abstract_witness.AbstractWitness {
|
|
148
|
-
static {
|
|
149
|
-
__name(this, "AbstractBlockchainWitness");
|
|
150
|
-
}
|
|
151
|
-
_providers = void 0;
|
|
152
|
-
async getProvider(cache = false, error) {
|
|
153
|
-
const providers2 = await this.getProviders(cache);
|
|
154
|
-
if (providers2.length === 0) {
|
|
155
|
-
if (error) {
|
|
156
|
-
throw new Error(typeof error === "string" ? error : "No providers available");
|
|
157
|
-
}
|
|
158
|
-
return void 0;
|
|
159
|
-
}
|
|
160
|
-
return providers2[Date.now() % providers2.length];
|
|
161
|
-
}
|
|
162
|
-
async getProviders(cache = false) {
|
|
163
|
-
const cachedProviders = cache ? this._providers : void 0;
|
|
164
|
-
this._providers = cachedProviders ?? await this.params.providers();
|
|
165
|
-
return this._providers;
|
|
166
|
-
}
|
|
167
|
-
};
|
|
168
|
-
//# sourceMappingURL=index.cjs.map
|