genlayer-js 0.14.2 → 0.15.1

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/CHANGELOG.md CHANGED
@@ -1,5 +1,19 @@
1
1
 
2
2
 
3
+ ## 0.15.1 (2025-09-02)
4
+
5
+
6
+ ### Bug Fixes
7
+
8
+ * **client:** disable viem transport retries (retryCount=0) to avoid duplicate requests ([#110](https://github.com/genlayerlabs/genlayer-js/issues/110)) ([dc2d623](https://github.com/genlayerlabs/genlayer-js/commit/dc2d623bb0a2bf96416e1590ddbcbf78adf9f9a7))
9
+
10
+ ## 0.15.0 (2025-08-18)
11
+
12
+
13
+ ### Features
14
+
15
+ * add custom provider support for wallet framework integration ([#105](https://github.com/genlayerlabs/genlayer-js/issues/105)) ([9fdaf6f](https://github.com/genlayerlabs/genlayer-js/commit/9fdaf6f7b52c58cabe8aee48e31317757be7637b))
16
+
3
17
  ## 0.14.2 (2025-08-14)
4
18
 
5
19
  ## 0.14.1 (2025-08-13)
package/dist/index.cjs CHANGED
@@ -1127,9 +1127,13 @@ var getCustomTransportConfig = (config) => {
1127
1127
  async request({ method, params = [] }) {
1128
1128
  if (method.startsWith("eth_") && isAddress) {
1129
1129
  try {
1130
- return await _optionalChain([window, 'access', _54 => _54.ethereum, 'optionalAccess', _55 => _55.request, 'call', _56 => _56({ method, params })]);
1130
+ const provider = config.provider || window.ethereum;
1131
+ if (!provider) {
1132
+ throw new Error("No wallet provider available");
1133
+ }
1134
+ return await provider.request({ method, params });
1131
1135
  } catch (err) {
1132
- console.warn(`Error using window.ethereum for method ${method}:`, err);
1136
+ console.warn(`Error using provider for method ${method}:`, err);
1133
1137
  throw err;
1134
1138
  }
1135
1139
  } else {
@@ -1167,7 +1171,7 @@ var createClient = (config = { chain: _chunkZKBMABRAcjs.localnet }) => {
1167
1171
  if (config.endpoint) {
1168
1172
  chainConfig.rpcUrls.default.http = [config.endpoint];
1169
1173
  }
1170
- const customTransport = _viem.custom.call(void 0, getCustomTransportConfig(config));
1174
+ const customTransport = _viem.custom.call(void 0, getCustomTransportConfig(config), { retryCount: 0, retryDelay: 0 });
1171
1175
  const publicClient = createPublicClient(chainConfig, customTransport).extend(
1172
1176
  _viem.publicActions
1173
1177
  );
package/dist/index.d.cts CHANGED
@@ -30,6 +30,7 @@ interface ClientConfig {
30
30
  };
31
31
  endpoint?: string;
32
32
  account?: Account | Address;
33
+ provider?: EthereumProvider;
33
34
  }
34
35
  declare const createClient: (config?: ClientConfig) => GenLayerClient<GenLayerChain>;
35
36
 
package/dist/index.d.ts CHANGED
@@ -30,6 +30,7 @@ interface ClientConfig {
30
30
  };
31
31
  endpoint?: string;
32
32
  account?: Account | Address;
33
+ provider?: EthereumProvider;
33
34
  }
34
35
  declare const createClient: (config?: ClientConfig) => GenLayerClient<GenLayerChain>;
35
36
 
package/dist/index.js CHANGED
@@ -1127,9 +1127,13 @@ var getCustomTransportConfig = (config) => {
1127
1127
  async request({ method, params = [] }) {
1128
1128
  if (method.startsWith("eth_") && isAddress) {
1129
1129
  try {
1130
- return await window.ethereum?.request({ method, params });
1130
+ const provider = config.provider || window.ethereum;
1131
+ if (!provider) {
1132
+ throw new Error("No wallet provider available");
1133
+ }
1134
+ return await provider.request({ method, params });
1131
1135
  } catch (err) {
1132
- console.warn(`Error using window.ethereum for method ${method}:`, err);
1136
+ console.warn(`Error using provider for method ${method}:`, err);
1133
1137
  throw err;
1134
1138
  }
1135
1139
  } else {
@@ -1167,7 +1171,7 @@ var createClient = (config = { chain: localnet }) => {
1167
1171
  if (config.endpoint) {
1168
1172
  chainConfig.rpcUrls.default.http = [config.endpoint];
1169
1173
  }
1170
- const customTransport = custom(getCustomTransportConfig(config));
1174
+ const customTransport = custom(getCustomTransportConfig(config), { retryCount: 0, retryDelay: 0 });
1171
1175
  const publicClient = createPublicClient(chainConfig, customTransport).extend(
1172
1176
  publicActions
1173
1177
  );
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "genlayer-js",
3
3
  "type": "module",
4
- "version": "0.14.2",
4
+ "version": "0.15.1",
5
5
  "description": "GenLayer JavaScript SDK",
6
6
  "main": "dist/index.js",
7
7
  "types": "dist/index.d.ts",
@@ -29,6 +29,7 @@ interface ClientConfig {
29
29
  };
30
30
  endpoint?: string; // Custom RPC endpoint
31
31
  account?: Account | Address;
32
+ provider?: EthereumProvider; // Custom provider for wallet framework integration
32
33
  }
33
34
 
34
35
  const getCustomTransportConfig = (config: ClientConfig) => {
@@ -38,9 +39,13 @@ const getCustomTransportConfig = (config: ClientConfig) => {
38
39
  async request({method, params = []}: {method: string; params: any[]}) {
39
40
  if (method.startsWith("eth_") && isAddress) {
40
41
  try {
41
- return await window.ethereum?.request({method, params});
42
+ const provider = config.provider || window.ethereum;
43
+ if (!provider) {
44
+ throw new Error('No wallet provider available');
45
+ }
46
+ return await provider.request({method, params});
42
47
  } catch (err) {
43
- console.warn(`Error using window.ethereum for method ${method}:`, err);
48
+ console.warn(`Error using provider for method ${method}:`, err);
44
49
  throw err;
45
50
  }
46
51
  } else {
@@ -84,7 +89,7 @@ export const createClient = (config: ClientConfig = {chain: localnet}): GenLayer
84
89
  chainConfig.rpcUrls.default.http = [config.endpoint];
85
90
  }
86
91
 
87
- const customTransport = custom(getCustomTransportConfig(config));
92
+ const customTransport = custom(getCustomTransportConfig(config), {retryCount: 0, retryDelay: 0});
88
93
  const publicClient = createPublicClient(chainConfig as GenLayerChain, customTransport).extend(
89
94
  publicActions,
90
95
  );
package/src/global.d.ts CHANGED
@@ -1,7 +1,9 @@
1
1
  // global.d.ts
2
+ interface EthereumProvider {
3
+ isMetaMask?: boolean;
4
+ request: (args: {method: string; params?: any}) => Promise<any>;
5
+ }
6
+
2
7
  interface Window {
3
- ethereum?: {
4
- isMetaMask?: boolean;
5
- request: any
6
- };
8
+ ethereum?: EthereumProvider;
7
9
  }