@dcentralab/d402-client 0.3.9 → 0.3.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.d.mts CHANGED
@@ -636,6 +636,7 @@ interface WithdrawalRequest {
636
636
  token: Address;
637
637
  amount: bigint;
638
638
  requestedAt: bigint;
639
+ unlockTime: bigint;
639
640
  executed: boolean;
640
641
  }
641
642
 
@@ -762,6 +763,45 @@ declare function getWalletsByOwner(params: {
762
763
  network?: SupportedNetwork;
763
764
  rpcUrl?: string;
764
765
  }): Promise<Address[]>;
766
+ /**
767
+ * Get wallet info for debugging - includes owner, operator, and settlement layer addresses.
768
+ *
769
+ * @param params - Query parameters
770
+ * @param params.publicClient - Viem PublicClient
771
+ * @param params.walletAddress - IATPWallet contract address
772
+ * @param params.network - Network to query
773
+ * @returns Wallet info object
774
+ */
775
+ declare function getWalletInfo(params: {
776
+ publicClient: PublicClient;
777
+ walletAddress: Address;
778
+ network?: SupportedNetwork;
779
+ }): Promise<{
780
+ owner: Address;
781
+ operator: Address;
782
+ settlementLayer: Address;
783
+ }>;
784
+ /**
785
+ * Get EIP-712 domain info for an IATPWallet - used for debugging signature issues.
786
+ *
787
+ * Reads the eip712Domain function from the wallet contract.
788
+ *
789
+ * @param params - Query parameters
790
+ * @param params.publicClient - Viem PublicClient
791
+ * @param params.walletAddress - IATPWallet contract address
792
+ * @param params.network - Network to query
793
+ * @returns EIP-712 domain info
794
+ */
795
+ declare function getWalletEIP712Domain(params: {
796
+ publicClient: PublicClient;
797
+ walletAddress: Address;
798
+ network?: SupportedNetwork;
799
+ }): Promise<{
800
+ name: string;
801
+ version: string;
802
+ chainId: bigint;
803
+ verifyingContract: Address;
804
+ }>;
765
805
 
766
806
  /**
767
807
  * IATPWallet withdrawal functions
@@ -1336,4 +1376,4 @@ declare class UnsupportedNetworkError extends PaymentError {
1336
1376
  constructor(network: string);
1337
1377
  }
1338
1378
 
1339
- export { ContractName, D402Client, type D402ClientConfig, type D402Response, type EIP712Domain, Invalid402ResponseError, type JsonRpcPayload, type McpToolResult, MissingRequestConfigError, type ParsedMcpResponse, PaymentAlreadyAttemptedError, PaymentAmountExceededError, type PaymentAuthorization, PaymentError, type PaymentRequirement, type PaymentSelector, type PaymentSelectorOptions, PaymentVerificationError, type SignedPayment, type SupportedNetwork, UnsupportedNetworkError, UnsupportedSchemeError, type WalletCreationResult, type WithdrawalRequest, buildMcpHeaders, buildToolCallPayload, createIATPWallet, createPaymentSelector, decodePayment, decodePaymentResponse, encodePayment, executeWithdrawal, extractToolResult, findMatchingPaymentRequirement, formatMoney, generateNonce, getAvailableBalance, getChain, getChainId, getContractAbi, getContractAddress, getContractConfig, getCurrentTimestamp, getLockedBalanceForProvider, getUnlockedBalanceForProvider, getUsdcAddress, getWalletsByOwner, getWithdrawalRequest, initMcpSession, isValidAddress, normalizeAddress, parseAllPaymentRequirements, parseMcpResponse, parseMoney, parsePaymentRequirement, requestWithdrawal, selectPaymentRequirement, signD402Payment, sortPaymentRequirements, usdToUsdc, withdrawAllAvailableEpochs };
1379
+ export { ContractName, D402Client, type D402ClientConfig, type D402Response, type EIP712Domain, Invalid402ResponseError, type JsonRpcPayload, type McpToolResult, MissingRequestConfigError, type ParsedMcpResponse, PaymentAlreadyAttemptedError, PaymentAmountExceededError, type PaymentAuthorization, PaymentError, type PaymentRequirement, type PaymentSelector, type PaymentSelectorOptions, PaymentVerificationError, type SignedPayment, type SupportedNetwork, UnsupportedNetworkError, UnsupportedSchemeError, type WalletCreationResult, type WithdrawalRequest, buildMcpHeaders, buildToolCallPayload, createIATPWallet, createPaymentSelector, decodePayment, decodePaymentResponse, encodePayment, executeWithdrawal, extractToolResult, findMatchingPaymentRequirement, formatMoney, generateNonce, getAvailableBalance, getChain, getChainId, getContractAbi, getContractAddress, getContractConfig, getCurrentTimestamp, getLockedBalanceForProvider, getUnlockedBalanceForProvider, getUsdcAddress, getWalletEIP712Domain, getWalletInfo, getWalletsByOwner, getWithdrawalRequest, initMcpSession, isValidAddress, normalizeAddress, parseAllPaymentRequirements, parseMcpResponse, parseMoney, parsePaymentRequirement, requestWithdrawal, selectPaymentRequirement, signD402Payment, sortPaymentRequirements, usdToUsdc, withdrawAllAvailableEpochs };
package/dist/index.d.ts CHANGED
@@ -636,6 +636,7 @@ interface WithdrawalRequest {
636
636
  token: Address;
637
637
  amount: bigint;
638
638
  requestedAt: bigint;
639
+ unlockTime: bigint;
639
640
  executed: boolean;
640
641
  }
641
642
 
@@ -762,6 +763,45 @@ declare function getWalletsByOwner(params: {
762
763
  network?: SupportedNetwork;
763
764
  rpcUrl?: string;
764
765
  }): Promise<Address[]>;
766
+ /**
767
+ * Get wallet info for debugging - includes owner, operator, and settlement layer addresses.
768
+ *
769
+ * @param params - Query parameters
770
+ * @param params.publicClient - Viem PublicClient
771
+ * @param params.walletAddress - IATPWallet contract address
772
+ * @param params.network - Network to query
773
+ * @returns Wallet info object
774
+ */
775
+ declare function getWalletInfo(params: {
776
+ publicClient: PublicClient;
777
+ walletAddress: Address;
778
+ network?: SupportedNetwork;
779
+ }): Promise<{
780
+ owner: Address;
781
+ operator: Address;
782
+ settlementLayer: Address;
783
+ }>;
784
+ /**
785
+ * Get EIP-712 domain info for an IATPWallet - used for debugging signature issues.
786
+ *
787
+ * Reads the eip712Domain function from the wallet contract.
788
+ *
789
+ * @param params - Query parameters
790
+ * @param params.publicClient - Viem PublicClient
791
+ * @param params.walletAddress - IATPWallet contract address
792
+ * @param params.network - Network to query
793
+ * @returns EIP-712 domain info
794
+ */
795
+ declare function getWalletEIP712Domain(params: {
796
+ publicClient: PublicClient;
797
+ walletAddress: Address;
798
+ network?: SupportedNetwork;
799
+ }): Promise<{
800
+ name: string;
801
+ version: string;
802
+ chainId: bigint;
803
+ verifyingContract: Address;
804
+ }>;
765
805
 
766
806
  /**
767
807
  * IATPWallet withdrawal functions
@@ -1336,4 +1376,4 @@ declare class UnsupportedNetworkError extends PaymentError {
1336
1376
  constructor(network: string);
1337
1377
  }
1338
1378
 
1339
- export { ContractName, D402Client, type D402ClientConfig, type D402Response, type EIP712Domain, Invalid402ResponseError, type JsonRpcPayload, type McpToolResult, MissingRequestConfigError, type ParsedMcpResponse, PaymentAlreadyAttemptedError, PaymentAmountExceededError, type PaymentAuthorization, PaymentError, type PaymentRequirement, type PaymentSelector, type PaymentSelectorOptions, PaymentVerificationError, type SignedPayment, type SupportedNetwork, UnsupportedNetworkError, UnsupportedSchemeError, type WalletCreationResult, type WithdrawalRequest, buildMcpHeaders, buildToolCallPayload, createIATPWallet, createPaymentSelector, decodePayment, decodePaymentResponse, encodePayment, executeWithdrawal, extractToolResult, findMatchingPaymentRequirement, formatMoney, generateNonce, getAvailableBalance, getChain, getChainId, getContractAbi, getContractAddress, getContractConfig, getCurrentTimestamp, getLockedBalanceForProvider, getUnlockedBalanceForProvider, getUsdcAddress, getWalletsByOwner, getWithdrawalRequest, initMcpSession, isValidAddress, normalizeAddress, parseAllPaymentRequirements, parseMcpResponse, parseMoney, parsePaymentRequirement, requestWithdrawal, selectPaymentRequirement, signD402Payment, sortPaymentRequirements, usdToUsdc, withdrawAllAvailableEpochs };
1379
+ export { ContractName, D402Client, type D402ClientConfig, type D402Response, type EIP712Domain, Invalid402ResponseError, type JsonRpcPayload, type McpToolResult, MissingRequestConfigError, type ParsedMcpResponse, PaymentAlreadyAttemptedError, PaymentAmountExceededError, type PaymentAuthorization, PaymentError, type PaymentRequirement, type PaymentSelector, type PaymentSelectorOptions, PaymentVerificationError, type SignedPayment, type SupportedNetwork, UnsupportedNetworkError, UnsupportedSchemeError, type WalletCreationResult, type WithdrawalRequest, buildMcpHeaders, buildToolCallPayload, createIATPWallet, createPaymentSelector, decodePayment, decodePaymentResponse, encodePayment, executeWithdrawal, extractToolResult, findMatchingPaymentRequirement, formatMoney, generateNonce, getAvailableBalance, getChain, getChainId, getContractAbi, getContractAddress, getContractConfig, getCurrentTimestamp, getLockedBalanceForProvider, getUnlockedBalanceForProvider, getUsdcAddress, getWalletEIP712Domain, getWalletInfo, getWalletsByOwner, getWithdrawalRequest, initMcpSession, isValidAddress, normalizeAddress, parseAllPaymentRequirements, parseMcpResponse, parseMoney, parsePaymentRequirement, requestWithdrawal, selectPaymentRequirement, signD402Payment, sortPaymentRequirements, usdToUsdc, withdrawAllAvailableEpochs };
package/dist/index.js CHANGED
@@ -10482,6 +10482,42 @@ async function createIATPWallet(params) {
10482
10482
  };
10483
10483
  }
10484
10484
  init_utils();
10485
+
10486
+ // src/core/debug.ts
10487
+ var DEBUG_ENABLED = false;
10488
+ if (typeof window !== "undefined" && typeof localStorage !== "undefined") {
10489
+ try {
10490
+ DEBUG_ENABLED = localStorage.getItem("D402_DEBUG") === "true";
10491
+ } catch {
10492
+ }
10493
+ } else if (typeof process !== "undefined" && process.env) {
10494
+ DEBUG_ENABLED = process.env.D402_DEBUG === "true";
10495
+ }
10496
+ function debugGroup(category, title) {
10497
+ if (!DEBUG_ENABLED) {
10498
+ return {
10499
+ log: () => {
10500
+ },
10501
+ end: () => {
10502
+ }
10503
+ };
10504
+ }
10505
+ console.group(`[D402 ${category}] ${title}`);
10506
+ return {
10507
+ log: (msg, data) => {
10508
+ if (data !== void 0) {
10509
+ console.log(msg, data);
10510
+ } else {
10511
+ console.log(msg);
10512
+ }
10513
+ },
10514
+ end: () => {
10515
+ console.groupEnd();
10516
+ }
10517
+ };
10518
+ }
10519
+
10520
+ // src/wallet/queries.ts
10485
10521
  async function getAvailableBalance(params) {
10486
10522
  const { publicClient, walletAddress, tokenAddress, network = "sepolia" } = params;
10487
10523
  const walletAbi = getContractAbi("IATPWallet" /* IATP_WALLET */, network);
@@ -10516,6 +10552,84 @@ async function getWalletsByOwner(params) {
10516
10552
  });
10517
10553
  return wallets;
10518
10554
  }
10555
+ async function getWalletInfo(params) {
10556
+ const { publicClient, walletAddress, network = "sepolia" } = params;
10557
+ const walletAbi = getContractAbi("IATPWallet" /* IATP_WALLET */, network);
10558
+ if (!walletAbi) {
10559
+ throw new Error(`IATPWallet ABI not found for network: ${network}`);
10560
+ }
10561
+ const group = debugGroup("WALLET", `getWalletInfo ${walletAddress.slice(0, 10)}...`);
10562
+ try {
10563
+ const owner = await publicClient.readContract({
10564
+ address: walletAddress,
10565
+ abi: walletAbi,
10566
+ functionName: "owner",
10567
+ args: []
10568
+ });
10569
+ const operator = await publicClient.readContract({
10570
+ address: walletAddress,
10571
+ abi: walletAbi,
10572
+ functionName: "operatorAddress",
10573
+ args: []
10574
+ });
10575
+ const settlementLayer = await publicClient.readContract({
10576
+ address: walletAddress,
10577
+ abi: walletAbi,
10578
+ functionName: "settlementLayer",
10579
+ args: []
10580
+ });
10581
+ const result = { owner, operator, settlementLayer };
10582
+ group.log("=== WALLET INFO ===");
10583
+ group.log("Wallet Address:", walletAddress);
10584
+ group.log("Owner:", owner);
10585
+ group.log("Operator:", operator);
10586
+ group.log("Settlement Layer:", settlementLayer);
10587
+ group.end();
10588
+ return result;
10589
+ } catch (error) {
10590
+ group.log("Error querying wallet info:", error);
10591
+ group.end();
10592
+ throw error;
10593
+ }
10594
+ }
10595
+ async function getWalletEIP712Domain(params) {
10596
+ const { publicClient, walletAddress, network = "sepolia" } = params;
10597
+ const walletAbi = getContractAbi("IATPWallet" /* IATP_WALLET */, network);
10598
+ if (!walletAbi) {
10599
+ throw new Error(`IATPWallet ABI not found for network: ${network}`);
10600
+ }
10601
+ const group = debugGroup("WALLET", `getWalletEIP712Domain ${walletAddress.slice(0, 10)}...`);
10602
+ try {
10603
+ const result = await publicClient.readContract({
10604
+ address: walletAddress,
10605
+ abi: walletAbi,
10606
+ functionName: "eip712Domain",
10607
+ args: []
10608
+ });
10609
+ const domain = {
10610
+ name: result[1],
10611
+ version: result[2],
10612
+ chainId: result[3],
10613
+ verifyingContract: result[4]
10614
+ };
10615
+ group.log("=== EIP-712 DOMAIN FROM CONTRACT ===");
10616
+ group.log("Name:", domain.name);
10617
+ group.log("Version:", domain.version);
10618
+ group.log("Chain ID:", domain.chainId.toString());
10619
+ group.log("Verifying Contract:", domain.verifyingContract);
10620
+ group.end();
10621
+ return domain;
10622
+ } catch (error) {
10623
+ group.log("Error querying EIP-712 domain (may not be supported):", error);
10624
+ group.end();
10625
+ return {
10626
+ name: "IATPWallet",
10627
+ version: "1",
10628
+ chainId: BigInt(network === "sepolia" ? 11155111 : 42161),
10629
+ verifyingContract: walletAddress
10630
+ };
10631
+ }
10632
+ }
10519
10633
 
10520
10634
  // src/wallet/withdrawals.ts
10521
10635
  async function getWithdrawalRequest(params) {
@@ -10966,6 +11080,8 @@ exports.getCurrentTimestamp = getCurrentTimestamp;
10966
11080
  exports.getLockedBalanceForProvider = getLockedBalanceForProvider;
10967
11081
  exports.getUnlockedBalanceForProvider = getUnlockedBalanceForProvider;
10968
11082
  exports.getUsdcAddress = getUsdcAddress;
11083
+ exports.getWalletEIP712Domain = getWalletEIP712Domain;
11084
+ exports.getWalletInfo = getWalletInfo;
10969
11085
  exports.getWalletsByOwner = getWalletsByOwner;
10970
11086
  exports.getWithdrawalRequest = getWithdrawalRequest;
10971
11087
  exports.initMcpSession = initMcpSession;