@vleap/warps-wallet-coinbase 1.0.0-beta.6 → 1.0.0-beta.8

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.js CHANGED
@@ -136,7 +136,7 @@ var _CoinbaseWalletProvider = class _CoinbaseWalletProvider {
136
136
  async signTransaction(tx) {
137
137
  try {
138
138
  const account = await this.getAccount();
139
- if (this.chain.name === "solana") {
139
+ if (this.chain.name === import_warps.WarpChainName.Solana) {
140
140
  const result = await this.client.solana.signTransaction({
141
141
  address: account.id,
142
142
  transaction: tx
@@ -167,7 +167,7 @@ var _CoinbaseWalletProvider = class _CoinbaseWalletProvider {
167
167
  async signMessage(message) {
168
168
  try {
169
169
  const account = await this.getAccount();
170
- const result = this.chain.name === "solana" ? await this.client.solana.signMessage({ address: account.id, message }) : await this.client.evm.signMessage({ address: account.id, message });
170
+ const result = this.chain.name === import_warps.WarpChainName.Solana ? await this.client.solana.signMessage({ address: account.id, message }) : await this.client.evm.signMessage({ address: account.id, message });
171
171
  if ("signedMessage" in result && result.signedMessage) {
172
172
  return String(result.signedMessage);
173
173
  }
@@ -202,7 +202,7 @@ var _CoinbaseWalletProvider = class _CoinbaseWalletProvider {
202
202
  async export() {
203
203
  try {
204
204
  const address = this.getWalletAddress();
205
- const privateKey = this.chain.name === "solana" ? await this.client.solana.exportAccount({ address }) : await this.client.evm.exportAccount({ address });
205
+ const privateKey = this.chain.name === import_warps.WarpChainName.Solana ? await this.client.solana.exportAccount({ address }) : await this.client.evm.exportAccount({ address });
206
206
  return {
207
207
  provider: _CoinbaseWalletProvider.PROVIDER_NAME,
208
208
  address,
@@ -215,7 +215,7 @@ var _CoinbaseWalletProvider = class _CoinbaseWalletProvider {
215
215
  async generate() {
216
216
  try {
217
217
  const name = this.getAccountName();
218
- const account = this.chain.name === "solana" ? await this.client.solana.createAccount({ name }) : await this.client.evm.createAccount({ name });
218
+ const account = this.chain.name === import_warps.WarpChainName.Solana ? await this.client.solana.createAccount({ name }) : await this.client.evm.createAccount({ name });
219
219
  const walletDetails = {
220
220
  provider: _CoinbaseWalletProvider.PROVIDER_NAME,
221
221
  address: account.address
@@ -240,14 +240,14 @@ var _CoinbaseWalletProvider = class _CoinbaseWalletProvider {
240
240
  async getAccount() {
241
241
  if (this.cachedAccount) return this.cachedAccount;
242
242
  const address = this.getWalletAddress();
243
- const account = this.chain.name === "solana" ? await this.client.solana.getAccount({ address }) : await this.client.evm.getAccount({ address });
243
+ const account = this.chain.name === import_warps.WarpChainName.Solana ? await this.client.solana.getAccount({ address }) : await this.client.evm.getAccount({ address });
244
244
  const publicKey = this.extractPublicKey(account);
245
245
  this.cachedAccount = {
246
246
  id: account.address,
247
247
  address: account.address,
248
248
  ...publicKey && { publicKey }
249
249
  };
250
- if (this.chain.name !== "solana" && "signTransaction" in account) {
250
+ if (this.chain.name !== import_warps.WarpChainName.Solana && "signTransaction" in account) {
251
251
  this.cachedEvmAccount = { signTransaction: account.signTransaction };
252
252
  }
253
253
  return this.cachedAccount;
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/index.ts","../src/CoinbaseWalletProvider.ts","../src/helpers/evm.ts","../src/helpers.ts"],"sourcesContent":["export * from './CoinbaseWalletProvider'\nexport * from './helpers'\nexport * from './types'\n","import { CdpClient } from '@coinbase/cdp-sdk'\nimport {\n getWarpWalletAddressFromConfig,\n setWarpWalletInConfig,\n WalletProvider,\n WarpAdapterGenericTransaction,\n WarpChainInfo,\n WarpClientConfig,\n WarpWalletDetails,\n WarpWalletProvider,\n} from '@vleap/warps'\nimport { formatTransactionForCoinbase } from './helpers/evm'\nimport { CoinbaseProviderConfig } from './types'\n\nexport class CoinbaseWalletProvider implements WalletProvider {\n static readonly PROVIDER_NAME: WarpWalletProvider = 'coinbase'\n private readonly client: CdpClient\n private cachedAccount: { id: string; address: string; publicKey?: string } | null = null\n private cachedEvmAccount: { signTransaction: (tx: unknown) => Promise<unknown> } | null = null\n\n constructor(\n private readonly config: WarpClientConfig,\n private readonly chain: WarpChainInfo,\n private readonly coinbaseConfig: CoinbaseProviderConfig\n ) {\n this.client = new CdpClient({\n apiKeyId: coinbaseConfig.apiKeyId,\n apiKeySecret: coinbaseConfig.apiKeySecret,\n walletSecret: coinbaseConfig.walletSecret,\n ...(coinbaseConfig.apiUrl && { apiUrl: coinbaseConfig.apiUrl }),\n })\n }\n\n async getAddress(): Promise<string | null> {\n try {\n return (await this.getAccount()).address\n } catch (error) {\n console.error('CoinbaseWalletProvider: Failed to get address', error)\n return null\n }\n }\n\n async getPublicKey(): Promise<string | null> {\n try {\n return (await this.getAccount()).publicKey ?? null\n } catch (error) {\n console.error('CoinbaseWalletProvider: Failed to get public key', error)\n return null\n }\n }\n\n async signTransaction(tx: WarpAdapterGenericTransaction): Promise<WarpAdapterGenericTransaction> {\n try {\n const account = await this.getAccount()\n\n if (this.chain.name === 'solana') {\n const result = await this.client.solana.signTransaction({\n address: account.id,\n transaction: tx as never,\n })\n\n if ('signedTransaction' in result && result.signedTransaction) {\n return { ...(tx as Record<string, unknown>), signature: String(result.signedTransaction) }\n }\n throw new Error('Coinbase API did not return signed transaction')\n }\n\n if (!this.cachedEvmAccount) {\n const address = this.getWalletAddress()\n const evmAccount = await this.client.evm.getAccount({ address: address as `0x${string}` })\n if (!('signTransaction' in evmAccount))\n throw new Error('CoinbaseWalletProvider: Account object missing signTransaction method. This may be a SDK version issue.')\n this.cachedEvmAccount = { signTransaction: evmAccount.signTransaction as (tx: unknown) => Promise<unknown> }\n }\n\n const formattedTx = formatTransactionForCoinbase(tx, this.chain.chainId)\n const signedTx = await this.cachedEvmAccount.signTransaction(formattedTx)\n return { ...(tx as Record<string, unknown>), signature: signedTx }\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error)\n if (errorMessage.includes('signTransaction is not a function')) {\n throw new Error('CoinbaseWalletProvider: Account object missing signTransaction method. This may be a SDK version issue.')\n }\n throw new Error(`CoinbaseWalletProvider: Failed to sign transaction: ${error}`)\n }\n }\n\n async signMessage(message: string): Promise<string> {\n try {\n const account = await this.getAccount()\n const result =\n this.chain.name === 'solana'\n ? await this.client.solana.signMessage({ address: account.id, message })\n : await this.client.evm.signMessage({ address: account.id as `0x${string}`, message })\n\n if ('signedMessage' in result && result.signedMessage) {\n return String(result.signedMessage)\n }\n\n throw new Error('Coinbase API did not return signed message')\n } catch (error) {\n throw new Error(`CoinbaseWalletProvider: Failed to sign message: ${error}`)\n }\n }\n\n async importFromMnemonic(mnemonic: string): Promise<WarpWalletDetails> {\n throw new Error(\n 'CoinbaseWalletProvider: importFromMnemonic() is not supported. Use generate() to create a new account via Coinbase API.'\n )\n }\n\n async importFromPrivateKey(privateKey: string): Promise<WarpWalletDetails> {\n try {\n const name = this.getAccountName()\n const account =\n this.chain.name === 'solana'\n ? await this.client.solana.importAccount({ privateKey, ...(name && { name }) })\n : await this.client.evm.importAccount({\n privateKey: (privateKey.startsWith('0x') ? privateKey : `0x${privateKey}`) as `0x${string}`,\n ...(name && { name }),\n })\n\n const walletDetails: WarpWalletDetails = {\n provider: CoinbaseWalletProvider.PROVIDER_NAME,\n address: account.address,\n privateKey,\n }\n\n setWarpWalletInConfig(this.config, this.chain.name, walletDetails)\n\n return walletDetails\n } catch (error) {\n throw new Error(`CoinbaseWalletProvider: Failed to import account from private key: ${error}`)\n }\n }\n\n async export(): Promise<WarpWalletDetails> {\n try {\n const address = this.getWalletAddress()\n const privateKey =\n this.chain.name === 'solana'\n ? await this.client.solana.exportAccount({ address })\n : await this.client.evm.exportAccount({ address: address as `0x${string}` })\n\n return {\n provider: CoinbaseWalletProvider.PROVIDER_NAME,\n address,\n privateKey,\n }\n } catch (error) {\n throw new Error(`CoinbaseWalletProvider: Failed to export account: ${error}`)\n }\n }\n\n async generate(): Promise<WarpWalletDetails> {\n try {\n const name = this.getAccountName()\n const account =\n this.chain.name === 'solana' ? await this.client.solana.createAccount({ name }) : await this.client.evm.createAccount({ name })\n\n const walletDetails: WarpWalletDetails = {\n provider: CoinbaseWalletProvider.PROVIDER_NAME,\n address: account.address,\n }\n\n setWarpWalletInConfig(this.config, this.chain.name, walletDetails)\n\n return walletDetails\n } catch (error) {\n throw new Error(`CoinbaseWalletProvider: Failed to generate account: ${error}`)\n }\n }\n\n private getAccountName(): string | undefined {\n return this.config.user?.id ? `${this.config.user.id}-${this.chain.name}` : undefined\n }\n\n private getWalletAddress(): string {\n const address = getWarpWalletAddressFromConfig(this.config, this.chain.name)\n if (!address) throw new Error(`CoinbaseWalletProvider: Wallet address not found in config for chain ${this.chain.name}`)\n return address\n }\n\n private extractPublicKey(account: { address: string; publicKey?: unknown }): string | undefined {\n return account.publicKey as string | undefined\n }\n\n private async getAccount(): Promise<{ id: string; address: string; publicKey?: string }> {\n if (this.cachedAccount) return this.cachedAccount\n\n const address = this.getWalletAddress()\n const account =\n this.chain.name === 'solana'\n ? await this.client.solana.getAccount({ address })\n : await this.client.evm.getAccount({ address: address as `0x${string}` })\n\n const publicKey = this.extractPublicKey(account)\n this.cachedAccount = {\n id: account.address,\n address: account.address,\n ...(publicKey && { publicKey }),\n }\n\n if (this.chain.name !== 'solana' && 'signTransaction' in account) {\n this.cachedEvmAccount = { signTransaction: account.signTransaction as (tx: unknown) => Promise<unknown> }\n }\n\n return this.cachedAccount\n }\n}\n","import { WarpAdapterGenericTransaction } from '@vleap/warps'\n\nconst formatBigInt = (value: bigint | string | number | undefined): string | undefined => {\n if (value === undefined || value === null) return undefined\n if (typeof value === 'bigint') {\n const hex = value.toString(16)\n return `0x${hex}`\n }\n if (typeof value === 'string' && value.startsWith('0x')) {\n const parsed = BigInt(value)\n return `0x${parsed.toString(16)}`\n }\n const parsed = BigInt(value)\n return `0x${parsed.toString(16)}`\n}\n\nconst parseBigInt = (value: bigint | string | number | undefined): bigint | undefined => {\n if (value === undefined || value === null) return undefined\n if (typeof value === 'bigint') return value\n return BigInt(value)\n}\n\nconst normalizePriorityFee = (maxFee: bigint, maxPriorityFee: bigint): bigint => {\n if (maxFee <= 0n) return 1n\n if (maxPriorityFee <= maxFee) return maxPriorityFee\n const safeFee = maxFee / 10n\n return safeFee < 1n ? 1n : safeFee\n}\n\nexport const formatTransactionForCoinbase = (tx: WarpAdapterGenericTransaction, chainId: number | string): WarpAdapterGenericTransaction => {\n const MIN_FEE = 1000000000n\n\n let maxFee: bigint\n let maxPriorityFee: bigint\n\n if (tx.maxFeePerGas !== undefined && tx.maxPriorityFeePerGas !== undefined) {\n maxFee = parseBigInt(tx.maxFeePerGas)!\n maxPriorityFee = parseBigInt(tx.maxPriorityFeePerGas)!\n if (maxFee < MIN_FEE) maxFee = MIN_FEE\n maxPriorityFee = normalizePriorityFee(maxFee, maxPriorityFee)\n } else if (tx.gasPrice !== undefined) {\n const gasPrice = parseBigInt(tx.gasPrice)!\n maxFee = gasPrice < MIN_FEE ? MIN_FEE : gasPrice\n maxPriorityFee = normalizePriorityFee(maxFee, (maxFee * 9n) / 10n)\n } else {\n maxFee = MIN_FEE\n maxPriorityFee = MIN_FEE / 10n\n }\n\n if (maxPriorityFee >= maxFee) maxPriorityFee = maxFee / 10n\n if (maxPriorityFee < 1n) maxPriorityFee = 1n\n\n const finalMaxFee = maxFee\n let finalMaxPriorityFee = maxPriorityFee\n\n const MIN_PRIORITY_FEE = 100000000n\n if (finalMaxFee >= MIN_PRIORITY_FEE * 10n && finalMaxPriorityFee < MIN_PRIORITY_FEE) {\n finalMaxPriorityFee = MIN_PRIORITY_FEE\n }\n\n if (finalMaxPriorityFee >= finalMaxFee) {\n finalMaxPriorityFee = finalMaxFee / 10n\n }\n\n if (finalMaxPriorityFee < 1n) {\n finalMaxPriorityFee = 1n\n }\n\n const formatted: any = {\n to: tx.to,\n value: formatBigInt(tx.value) || '0x0',\n data: tx.data || '0x',\n chainId: typeof tx.chainId === 'number' ? tx.chainId : parseInt(String(tx.chainId || chainId)),\n maxFeePerGas: formatBigInt(finalMaxFee)!,\n maxPriorityFeePerGas: formatBigInt(finalMaxPriorityFee)!,\n }\n\n if (tx.from) formatted.from = tx.from\n if (tx.gasLimit) formatted.gas = formatBigInt(tx.gasLimit)\n if (tx.nonce !== undefined) formatted.nonce = typeof tx.nonce === 'number' ? `0x${tx.nonce.toString(16)}` : formatBigInt(tx.nonce)\n if (tx.type) formatted.type = tx.type\n if (tx.accessList) formatted.accessList = tx.accessList\n\n delete formatted.gasPrice\n\n return formatted\n}\n","import { WalletProviderFactory, WarpChainInfo, WarpClientConfig } from '@vleap/warps'\nimport { CoinbaseWalletProvider } from './CoinbaseWalletProvider'\nimport { CoinbaseProviderConfig } from './types'\n\nexport const createCoinbaseWalletProvider = (\n coinbaseConfig: CoinbaseProviderConfig\n): WalletProviderFactory => {\n return (config: WarpClientConfig, chain: WarpChainInfo) =>\n new CoinbaseWalletProvider(config, chain, coinbaseConfig)\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA,qBAA0B;AAC1B,mBASO;;;ACRP,IAAM,eAAe,CAAC,UAAoE;AACxF,MAAI,UAAU,UAAa,UAAU,KAAM,QAAO;AAClD,MAAI,OAAO,UAAU,UAAU;AAC7B,UAAM,MAAM,MAAM,SAAS,EAAE;AAC7B,WAAO,KAAK,GAAG;AAAA,EACjB;AACA,MAAI,OAAO,UAAU,YAAY,MAAM,WAAW,IAAI,GAAG;AACvD,UAAMA,UAAS,OAAO,KAAK;AAC3B,WAAO,KAAKA,QAAO,SAAS,EAAE,CAAC;AAAA,EACjC;AACA,QAAM,SAAS,OAAO,KAAK;AAC3B,SAAO,KAAK,OAAO,SAAS,EAAE,CAAC;AACjC;AAEA,IAAM,cAAc,CAAC,UAAoE;AACvF,MAAI,UAAU,UAAa,UAAU,KAAM,QAAO;AAClD,MAAI,OAAO,UAAU,SAAU,QAAO;AACtC,SAAO,OAAO,KAAK;AACrB;AAEA,IAAM,uBAAuB,CAAC,QAAgB,mBAAmC;AAC/E,MAAI,UAAU,GAAI,QAAO;AACzB,MAAI,kBAAkB,OAAQ,QAAO;AACrC,QAAM,UAAU,SAAS;AACzB,SAAO,UAAU,KAAK,KAAK;AAC7B;AAEO,IAAM,+BAA+B,CAAC,IAAmC,YAA4D;AAC1I,QAAM,UAAU;AAEhB,MAAI;AACJ,MAAI;AAEJ,MAAI,GAAG,iBAAiB,UAAa,GAAG,yBAAyB,QAAW;AAC1E,aAAS,YAAY,GAAG,YAAY;AACpC,qBAAiB,YAAY,GAAG,oBAAoB;AACpD,QAAI,SAAS,QAAS,UAAS;AAC/B,qBAAiB,qBAAqB,QAAQ,cAAc;AAAA,EAC9D,WAAW,GAAG,aAAa,QAAW;AACpC,UAAM,WAAW,YAAY,GAAG,QAAQ;AACxC,aAAS,WAAW,UAAU,UAAU;AACxC,qBAAiB,qBAAqB,QAAS,SAAS,KAAM,GAAG;AAAA,EACnE,OAAO;AACL,aAAS;AACT,qBAAiB,UAAU;AAAA,EAC7B;AAEA,MAAI,kBAAkB,OAAQ,kBAAiB,SAAS;AACxD,MAAI,iBAAiB,GAAI,kBAAiB;AAE1C,QAAM,cAAc;AACpB,MAAI,sBAAsB;AAE1B,QAAM,mBAAmB;AACzB,MAAI,eAAe,mBAAmB,OAAO,sBAAsB,kBAAkB;AACnF,0BAAsB;AAAA,EACxB;AAEA,MAAI,uBAAuB,aAAa;AACtC,0BAAsB,cAAc;AAAA,EACtC;AAEA,MAAI,sBAAsB,IAAI;AAC5B,0BAAsB;AAAA,EACxB;AAEA,QAAM,YAAiB;AAAA,IACrB,IAAI,GAAG;AAAA,IACP,OAAO,aAAa,GAAG,KAAK,KAAK;AAAA,IACjC,MAAM,GAAG,QAAQ;AAAA,IACjB,SAAS,OAAO,GAAG,YAAY,WAAW,GAAG,UAAU,SAAS,OAAO,GAAG,WAAW,OAAO,CAAC;AAAA,IAC7F,cAAc,aAAa,WAAW;AAAA,IACtC,sBAAsB,aAAa,mBAAmB;AAAA,EACxD;AAEA,MAAI,GAAG,KAAM,WAAU,OAAO,GAAG;AACjC,MAAI,GAAG,SAAU,WAAU,MAAM,aAAa,GAAG,QAAQ;AACzD,MAAI,GAAG,UAAU,OAAW,WAAU,QAAQ,OAAO,GAAG,UAAU,WAAW,KAAK,GAAG,MAAM,SAAS,EAAE,CAAC,KAAK,aAAa,GAAG,KAAK;AACjI,MAAI,GAAG,KAAM,WAAU,OAAO,GAAG;AACjC,MAAI,GAAG,WAAY,WAAU,aAAa,GAAG;AAE7C,SAAO,UAAU;AAEjB,SAAO;AACT;;;ADxEO,IAAM,0BAAN,MAAM,wBAAiD;AAAA,EAM5D,YACmB,QACA,OACA,gBACjB;AAHiB;AACA;AACA;AANnB,SAAQ,gBAA4E;AACpF,SAAQ,mBAAkF;AAOxF,SAAK,SAAS,IAAI,yBAAU;AAAA,MAC1B,UAAU,eAAe;AAAA,MACzB,cAAc,eAAe;AAAA,MAC7B,cAAc,eAAe;AAAA,MAC7B,GAAI,eAAe,UAAU,EAAE,QAAQ,eAAe,OAAO;AAAA,IAC/D,CAAC;AAAA,EACH;AAAA,EAEA,MAAM,aAAqC;AACzC,QAAI;AACF,cAAQ,MAAM,KAAK,WAAW,GAAG;AAAA,IACnC,SAAS,OAAO;AACd,cAAQ,MAAM,iDAAiD,KAAK;AACpE,aAAO;AAAA,IACT;AAAA,EACF;AAAA,EAEA,MAAM,eAAuC;AAC3C,QAAI;AACF,cAAQ,MAAM,KAAK,WAAW,GAAG,aAAa;AAAA,IAChD,SAAS,OAAO;AACd,cAAQ,MAAM,oDAAoD,KAAK;AACvE,aAAO;AAAA,IACT;AAAA,EACF;AAAA,EAEA,MAAM,gBAAgB,IAA2E;AAC/F,QAAI;AACF,YAAM,UAAU,MAAM,KAAK,WAAW;AAEtC,UAAI,KAAK,MAAM,SAAS,UAAU;AAChC,cAAM,SAAS,MAAM,KAAK,OAAO,OAAO,gBAAgB;AAAA,UACtD,SAAS,QAAQ;AAAA,UACjB,aAAa;AAAA,QACf,CAAC;AAED,YAAI,uBAAuB,UAAU,OAAO,mBAAmB;AAC7D,iBAAO,EAAE,GAAI,IAAgC,WAAW,OAAO,OAAO,iBAAiB,EAAE;AAAA,QAC3F;AACA,cAAM,IAAI,MAAM,gDAAgD;AAAA,MAClE;AAEA,UAAI,CAAC,KAAK,kBAAkB;AAC1B,cAAM,UAAU,KAAK,iBAAiB;AACtC,cAAM,aAAa,MAAM,KAAK,OAAO,IAAI,WAAW,EAAE,QAAkC,CAAC;AACzF,YAAI,EAAE,qBAAqB;AACzB,gBAAM,IAAI,MAAM,yGAAyG;AAC3H,aAAK,mBAAmB,EAAE,iBAAiB,WAAW,gBAAqD;AAAA,MAC7G;AAEA,YAAM,cAAc,6BAA6B,IAAI,KAAK,MAAM,OAAO;AACvE,YAAM,WAAW,MAAM,KAAK,iBAAiB,gBAAgB,WAAW;AACxE,aAAO,EAAE,GAAI,IAAgC,WAAW,SAAS;AAAA,IACnE,SAAS,OAAO;AACd,YAAM,eAAe,iBAAiB,QAAQ,MAAM,UAAU,OAAO,KAAK;AAC1E,UAAI,aAAa,SAAS,mCAAmC,GAAG;AAC9D,cAAM,IAAI,MAAM,yGAAyG;AAAA,MAC3H;AACA,YAAM,IAAI,MAAM,uDAAuD,KAAK,EAAE;AAAA,IAChF;AAAA,EACF;AAAA,EAEA,MAAM,YAAY,SAAkC;AAClD,QAAI;AACF,YAAM,UAAU,MAAM,KAAK,WAAW;AACtC,YAAM,SACJ,KAAK,MAAM,SAAS,WAChB,MAAM,KAAK,OAAO,OAAO,YAAY,EAAE,SAAS,QAAQ,IAAI,QAAQ,CAAC,IACrE,MAAM,KAAK,OAAO,IAAI,YAAY,EAAE,SAAS,QAAQ,IAAqB,QAAQ,CAAC;AAEzF,UAAI,mBAAmB,UAAU,OAAO,eAAe;AACrD,eAAO,OAAO,OAAO,aAAa;AAAA,MACpC;AAEA,YAAM,IAAI,MAAM,4CAA4C;AAAA,IAC9D,SAAS,OAAO;AACd,YAAM,IAAI,MAAM,mDAAmD,KAAK,EAAE;AAAA,IAC5E;AAAA,EACF;AAAA,EAEA,MAAM,mBAAmB,UAA8C;AACrE,UAAM,IAAI;AAAA,MACR;AAAA,IACF;AAAA,EACF;AAAA,EAEA,MAAM,qBAAqB,YAAgD;AACzE,QAAI;AACF,YAAM,OAAO,KAAK,eAAe;AACjC,YAAM,UACJ,KAAK,MAAM,SAAS,WAChB,MAAM,KAAK,OAAO,OAAO,cAAc,EAAE,YAAY,GAAI,QAAQ,EAAE,KAAK,EAAG,CAAC,IAC5E,MAAM,KAAK,OAAO,IAAI,cAAc;AAAA,QAClC,YAAa,WAAW,WAAW,IAAI,IAAI,aAAa,KAAK,UAAU;AAAA,QACvE,GAAI,QAAQ,EAAE,KAAK;AAAA,MACrB,CAAC;AAEP,YAAM,gBAAmC;AAAA,QACvC,UAAU,wBAAuB;AAAA,QACjC,SAAS,QAAQ;AAAA,QACjB;AAAA,MACF;AAEA,8CAAsB,KAAK,QAAQ,KAAK,MAAM,MAAM,aAAa;AAEjE,aAAO;AAAA,IACT,SAAS,OAAO;AACd,YAAM,IAAI,MAAM,sEAAsE,KAAK,EAAE;AAAA,IAC/F;AAAA,EACF;AAAA,EAEA,MAAM,SAAqC;AACzC,QAAI;AACF,YAAM,UAAU,KAAK,iBAAiB;AACtC,YAAM,aACJ,KAAK,MAAM,SAAS,WAChB,MAAM,KAAK,OAAO,OAAO,cAAc,EAAE,QAAQ,CAAC,IAClD,MAAM,KAAK,OAAO,IAAI,cAAc,EAAE,QAAkC,CAAC;AAE/E,aAAO;AAAA,QACL,UAAU,wBAAuB;AAAA,QACjC;AAAA,QACA;AAAA,MACF;AAAA,IACF,SAAS,OAAO;AACd,YAAM,IAAI,MAAM,qDAAqD,KAAK,EAAE;AAAA,IAC9E;AAAA,EACF;AAAA,EAEA,MAAM,WAAuC;AAC3C,QAAI;AACF,YAAM,OAAO,KAAK,eAAe;AACjC,YAAM,UACJ,KAAK,MAAM,SAAS,WAAW,MAAM,KAAK,OAAO,OAAO,cAAc,EAAE,KAAK,CAAC,IAAI,MAAM,KAAK,OAAO,IAAI,cAAc,EAAE,KAAK,CAAC;AAEhI,YAAM,gBAAmC;AAAA,QACvC,UAAU,wBAAuB;AAAA,QACjC,SAAS,QAAQ;AAAA,MACnB;AAEA,8CAAsB,KAAK,QAAQ,KAAK,MAAM,MAAM,aAAa;AAEjE,aAAO;AAAA,IACT,SAAS,OAAO;AACd,YAAM,IAAI,MAAM,uDAAuD,KAAK,EAAE;AAAA,IAChF;AAAA,EACF;AAAA,EAEQ,iBAAqC;AAC3C,WAAO,KAAK,OAAO,MAAM,KAAK,GAAG,KAAK,OAAO,KAAK,EAAE,IAAI,KAAK,MAAM,IAAI,KAAK;AAAA,EAC9E;AAAA,EAEQ,mBAA2B;AACjC,UAAM,cAAU,6CAA+B,KAAK,QAAQ,KAAK,MAAM,IAAI;AAC3E,QAAI,CAAC,QAAS,OAAM,IAAI,MAAM,wEAAwE,KAAK,MAAM,IAAI,EAAE;AACvH,WAAO;AAAA,EACT;AAAA,EAEQ,iBAAiB,SAAuE;AAC9F,WAAO,QAAQ;AAAA,EACjB;AAAA,EAEA,MAAc,aAA2E;AACvF,QAAI,KAAK,cAAe,QAAO,KAAK;AAEpC,UAAM,UAAU,KAAK,iBAAiB;AACtC,UAAM,UACJ,KAAK,MAAM,SAAS,WAChB,MAAM,KAAK,OAAO,OAAO,WAAW,EAAE,QAAQ,CAAC,IAC/C,MAAM,KAAK,OAAO,IAAI,WAAW,EAAE,QAAkC,CAAC;AAE5E,UAAM,YAAY,KAAK,iBAAiB,OAAO;AAC/C,SAAK,gBAAgB;AAAA,MACnB,IAAI,QAAQ;AAAA,MACZ,SAAS,QAAQ;AAAA,MACjB,GAAI,aAAa,EAAE,UAAU;AAAA,IAC/B;AAEA,QAAI,KAAK,MAAM,SAAS,YAAY,qBAAqB,SAAS;AAChE,WAAK,mBAAmB,EAAE,iBAAiB,QAAQ,gBAAqD;AAAA,IAC1G;AAEA,WAAO,KAAK;AAAA,EACd;AACF;AAnMa,wBACK,gBAAoC;AAD/C,IAAM,yBAAN;;;AEVA,IAAM,+BAA+B,CAC1C,mBAC0B;AAC1B,SAAO,CAAC,QAA0B,UAChC,IAAI,uBAAuB,QAAQ,OAAO,cAAc;AAC5D;","names":["parsed"]}
1
+ {"version":3,"sources":["../src/index.ts","../src/CoinbaseWalletProvider.ts","../src/helpers/evm.ts","../src/helpers.ts"],"sourcesContent":["export * from './CoinbaseWalletProvider'\nexport * from './helpers'\nexport * from './types'\n","import { CdpClient } from '@coinbase/cdp-sdk'\nimport {\n getWarpWalletAddressFromConfig,\n setWarpWalletInConfig,\n WalletProvider,\n WarpAdapterGenericTransaction,\n WarpChainInfo,\n WarpChainName,\n WarpClientConfig,\n WarpWalletDetails,\n WarpWalletProvider,\n} from '@vleap/warps'\nimport { formatTransactionForCoinbase } from './helpers/evm'\nimport { CoinbaseProviderConfig } from './types'\n\nexport class CoinbaseWalletProvider implements WalletProvider {\n static readonly PROVIDER_NAME: WarpWalletProvider = 'coinbase'\n private readonly client: CdpClient\n private cachedAccount: { id: string; address: string; publicKey?: string } | null = null\n private cachedEvmAccount: { signTransaction: (tx: unknown) => Promise<unknown> } | null = null\n\n constructor(\n private readonly config: WarpClientConfig,\n private readonly chain: WarpChainInfo,\n private readonly coinbaseConfig: CoinbaseProviderConfig\n ) {\n this.client = new CdpClient({\n apiKeyId: coinbaseConfig.apiKeyId,\n apiKeySecret: coinbaseConfig.apiKeySecret,\n walletSecret: coinbaseConfig.walletSecret,\n ...(coinbaseConfig.apiUrl && { apiUrl: coinbaseConfig.apiUrl }),\n })\n }\n\n async getAddress(): Promise<string | null> {\n try {\n return (await this.getAccount()).address\n } catch (error) {\n console.error('CoinbaseWalletProvider: Failed to get address', error)\n return null\n }\n }\n\n async getPublicKey(): Promise<string | null> {\n try {\n return (await this.getAccount()).publicKey ?? null\n } catch (error) {\n console.error('CoinbaseWalletProvider: Failed to get public key', error)\n return null\n }\n }\n\n async signTransaction(tx: WarpAdapterGenericTransaction): Promise<WarpAdapterGenericTransaction> {\n try {\n const account = await this.getAccount()\n\n if (this.chain.name === WarpChainName.Solana) {\n const result = await this.client.solana.signTransaction({\n address: account.id,\n transaction: tx as never,\n })\n\n if ('signedTransaction' in result && result.signedTransaction) {\n return { ...(tx as Record<string, unknown>), signature: String(result.signedTransaction) }\n }\n throw new Error('Coinbase API did not return signed transaction')\n }\n\n if (!this.cachedEvmAccount) {\n const address = this.getWalletAddress()\n const evmAccount = await this.client.evm.getAccount({ address: address as `0x${string}` })\n if (!('signTransaction' in evmAccount))\n throw new Error('CoinbaseWalletProvider: Account object missing signTransaction method. This may be a SDK version issue.')\n this.cachedEvmAccount = { signTransaction: evmAccount.signTransaction as (tx: unknown) => Promise<unknown> }\n }\n\n const formattedTx = formatTransactionForCoinbase(tx, this.chain.chainId)\n const signedTx = await this.cachedEvmAccount.signTransaction(formattedTx)\n return { ...(tx as Record<string, unknown>), signature: signedTx }\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error)\n if (errorMessage.includes('signTransaction is not a function')) {\n throw new Error('CoinbaseWalletProvider: Account object missing signTransaction method. This may be a SDK version issue.')\n }\n throw new Error(`CoinbaseWalletProvider: Failed to sign transaction: ${error}`)\n }\n }\n\n async signMessage(message: string): Promise<string> {\n try {\n const account = await this.getAccount()\n const result =\n this.chain.name === WarpChainName.Solana\n ? await this.client.solana.signMessage({ address: account.id, message })\n : await this.client.evm.signMessage({ address: account.id as `0x${string}`, message })\n\n if ('signedMessage' in result && result.signedMessage) {\n return String(result.signedMessage)\n }\n\n throw new Error('Coinbase API did not return signed message')\n } catch (error) {\n throw new Error(`CoinbaseWalletProvider: Failed to sign message: ${error}`)\n }\n }\n\n async importFromMnemonic(mnemonic: string): Promise<WarpWalletDetails> {\n throw new Error(\n 'CoinbaseWalletProvider: importFromMnemonic() is not supported. Use generate() to create a new account via Coinbase API.'\n )\n }\n\n async importFromPrivateKey(privateKey: string): Promise<WarpWalletDetails> {\n try {\n const name = this.getAccountName()\n const account =\n this.chain.name === 'solana'\n ? await this.client.solana.importAccount({ privateKey, ...(name && { name }) })\n : await this.client.evm.importAccount({\n privateKey: (privateKey.startsWith('0x') ? privateKey : `0x${privateKey}`) as `0x${string}`,\n ...(name && { name }),\n })\n\n const walletDetails: WarpWalletDetails = {\n provider: CoinbaseWalletProvider.PROVIDER_NAME,\n address: account.address,\n privateKey,\n }\n\n setWarpWalletInConfig(this.config, this.chain.name, walletDetails)\n\n return walletDetails\n } catch (error) {\n throw new Error(`CoinbaseWalletProvider: Failed to import account from private key: ${error}`)\n }\n }\n\n async export(): Promise<WarpWalletDetails> {\n try {\n const address = this.getWalletAddress()\n const privateKey =\n this.chain.name === WarpChainName.Solana\n ? await this.client.solana.exportAccount({ address })\n : await this.client.evm.exportAccount({ address: address as `0x${string}` })\n\n return {\n provider: CoinbaseWalletProvider.PROVIDER_NAME,\n address,\n privateKey,\n }\n } catch (error) {\n throw new Error(`CoinbaseWalletProvider: Failed to export account: ${error}`)\n }\n }\n\n async generate(): Promise<WarpWalletDetails> {\n try {\n const name = this.getAccountName()\n const account =\n this.chain.name === WarpChainName.Solana\n ? await this.client.solana.createAccount({ name })\n : await this.client.evm.createAccount({ name })\n\n const walletDetails: WarpWalletDetails = {\n provider: CoinbaseWalletProvider.PROVIDER_NAME,\n address: account.address,\n }\n\n setWarpWalletInConfig(this.config, this.chain.name, walletDetails)\n\n return walletDetails\n } catch (error) {\n throw new Error(`CoinbaseWalletProvider: Failed to generate account: ${error}`)\n }\n }\n\n private getAccountName(): string | undefined {\n return this.config.user?.id ? `${this.config.user.id}-${this.chain.name}` : undefined\n }\n\n private getWalletAddress(): string {\n const address = getWarpWalletAddressFromConfig(this.config, this.chain.name)\n if (!address) throw new Error(`CoinbaseWalletProvider: Wallet address not found in config for chain ${this.chain.name}`)\n return address\n }\n\n private extractPublicKey(account: { address: string; publicKey?: unknown }): string | undefined {\n return account.publicKey as string | undefined\n }\n\n private async getAccount(): Promise<{ id: string; address: string; publicKey?: string }> {\n if (this.cachedAccount) return this.cachedAccount\n\n const address = this.getWalletAddress()\n const account =\n this.chain.name === WarpChainName.Solana\n ? await this.client.solana.getAccount({ address })\n : await this.client.evm.getAccount({ address: address as `0x${string}` })\n\n const publicKey = this.extractPublicKey(account)\n this.cachedAccount = {\n id: account.address,\n address: account.address,\n ...(publicKey && { publicKey }),\n }\n\n if (this.chain.name !== WarpChainName.Solana && 'signTransaction' in account) {\n this.cachedEvmAccount = { signTransaction: account.signTransaction as (tx: unknown) => Promise<unknown> }\n }\n\n return this.cachedAccount\n }\n}\n","import { WarpAdapterGenericTransaction } from '@vleap/warps'\n\nconst formatBigInt = (value: bigint | string | number | undefined): string | undefined => {\n if (value === undefined || value === null) return undefined\n if (typeof value === 'bigint') {\n const hex = value.toString(16)\n return `0x${hex}`\n }\n if (typeof value === 'string' && value.startsWith('0x')) {\n const parsed = BigInt(value)\n return `0x${parsed.toString(16)}`\n }\n const parsed = BigInt(value)\n return `0x${parsed.toString(16)}`\n}\n\nconst parseBigInt = (value: bigint | string | number | undefined): bigint | undefined => {\n if (value === undefined || value === null) return undefined\n if (typeof value === 'bigint') return value\n return BigInt(value)\n}\n\nconst normalizePriorityFee = (maxFee: bigint, maxPriorityFee: bigint): bigint => {\n if (maxFee <= 0n) return 1n\n if (maxPriorityFee <= maxFee) return maxPriorityFee\n const safeFee = maxFee / 10n\n return safeFee < 1n ? 1n : safeFee\n}\n\nexport const formatTransactionForCoinbase = (tx: WarpAdapterGenericTransaction, chainId: number | string): WarpAdapterGenericTransaction => {\n const MIN_FEE = 1000000000n\n\n let maxFee: bigint\n let maxPriorityFee: bigint\n\n if (tx.maxFeePerGas !== undefined && tx.maxPriorityFeePerGas !== undefined) {\n maxFee = parseBigInt(tx.maxFeePerGas)!\n maxPriorityFee = parseBigInt(tx.maxPriorityFeePerGas)!\n if (maxFee < MIN_FEE) maxFee = MIN_FEE\n maxPriorityFee = normalizePriorityFee(maxFee, maxPriorityFee)\n } else if (tx.gasPrice !== undefined) {\n const gasPrice = parseBigInt(tx.gasPrice)!\n maxFee = gasPrice < MIN_FEE ? MIN_FEE : gasPrice\n maxPriorityFee = normalizePriorityFee(maxFee, (maxFee * 9n) / 10n)\n } else {\n maxFee = MIN_FEE\n maxPriorityFee = MIN_FEE / 10n\n }\n\n if (maxPriorityFee >= maxFee) maxPriorityFee = maxFee / 10n\n if (maxPriorityFee < 1n) maxPriorityFee = 1n\n\n const finalMaxFee = maxFee\n let finalMaxPriorityFee = maxPriorityFee\n\n const MIN_PRIORITY_FEE = 100000000n\n if (finalMaxFee >= MIN_PRIORITY_FEE * 10n && finalMaxPriorityFee < MIN_PRIORITY_FEE) {\n finalMaxPriorityFee = MIN_PRIORITY_FEE\n }\n\n if (finalMaxPriorityFee >= finalMaxFee) {\n finalMaxPriorityFee = finalMaxFee / 10n\n }\n\n if (finalMaxPriorityFee < 1n) {\n finalMaxPriorityFee = 1n\n }\n\n const formatted: any = {\n to: tx.to,\n value: formatBigInt(tx.value) || '0x0',\n data: tx.data || '0x',\n chainId: typeof tx.chainId === 'number' ? tx.chainId : parseInt(String(tx.chainId || chainId)),\n maxFeePerGas: formatBigInt(finalMaxFee)!,\n maxPriorityFeePerGas: formatBigInt(finalMaxPriorityFee)!,\n }\n\n if (tx.from) formatted.from = tx.from\n if (tx.gasLimit) formatted.gas = formatBigInt(tx.gasLimit)\n if (tx.nonce !== undefined) formatted.nonce = typeof tx.nonce === 'number' ? `0x${tx.nonce.toString(16)}` : formatBigInt(tx.nonce)\n if (tx.type) formatted.type = tx.type\n if (tx.accessList) formatted.accessList = tx.accessList\n\n delete formatted.gasPrice\n\n return formatted\n}\n","import { WalletProviderFactory, WarpChainInfo, WarpClientConfig } from '@vleap/warps'\nimport { CoinbaseWalletProvider } from './CoinbaseWalletProvider'\nimport { CoinbaseProviderConfig } from './types'\n\nexport const createCoinbaseWalletProvider = (\n coinbaseConfig: CoinbaseProviderConfig\n): WalletProviderFactory => {\n return (config: WarpClientConfig, chain: WarpChainInfo) =>\n new CoinbaseWalletProvider(config, chain, coinbaseConfig)\n}\n"],"mappings":"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","names":["parsed"]}
package/dist/index.mjs CHANGED
@@ -2,7 +2,8 @@
2
2
  import { CdpClient } from "@coinbase/cdp-sdk";
3
3
  import {
4
4
  getWarpWalletAddressFromConfig,
5
- setWarpWalletInConfig
5
+ setWarpWalletInConfig,
6
+ WarpChainName
6
7
  } from "@vleap/warps";
7
8
 
8
9
  // src/helpers/evm.ts
@@ -112,7 +113,7 @@ var _CoinbaseWalletProvider = class _CoinbaseWalletProvider {
112
113
  async signTransaction(tx) {
113
114
  try {
114
115
  const account = await this.getAccount();
115
- if (this.chain.name === "solana") {
116
+ if (this.chain.name === WarpChainName.Solana) {
116
117
  const result = await this.client.solana.signTransaction({
117
118
  address: account.id,
118
119
  transaction: tx
@@ -143,7 +144,7 @@ var _CoinbaseWalletProvider = class _CoinbaseWalletProvider {
143
144
  async signMessage(message) {
144
145
  try {
145
146
  const account = await this.getAccount();
146
- const result = this.chain.name === "solana" ? await this.client.solana.signMessage({ address: account.id, message }) : await this.client.evm.signMessage({ address: account.id, message });
147
+ const result = this.chain.name === WarpChainName.Solana ? await this.client.solana.signMessage({ address: account.id, message }) : await this.client.evm.signMessage({ address: account.id, message });
147
148
  if ("signedMessage" in result && result.signedMessage) {
148
149
  return String(result.signedMessage);
149
150
  }
@@ -178,7 +179,7 @@ var _CoinbaseWalletProvider = class _CoinbaseWalletProvider {
178
179
  async export() {
179
180
  try {
180
181
  const address = this.getWalletAddress();
181
- const privateKey = this.chain.name === "solana" ? await this.client.solana.exportAccount({ address }) : await this.client.evm.exportAccount({ address });
182
+ const privateKey = this.chain.name === WarpChainName.Solana ? await this.client.solana.exportAccount({ address }) : await this.client.evm.exportAccount({ address });
182
183
  return {
183
184
  provider: _CoinbaseWalletProvider.PROVIDER_NAME,
184
185
  address,
@@ -191,7 +192,7 @@ var _CoinbaseWalletProvider = class _CoinbaseWalletProvider {
191
192
  async generate() {
192
193
  try {
193
194
  const name = this.getAccountName();
194
- const account = this.chain.name === "solana" ? await this.client.solana.createAccount({ name }) : await this.client.evm.createAccount({ name });
195
+ const account = this.chain.name === WarpChainName.Solana ? await this.client.solana.createAccount({ name }) : await this.client.evm.createAccount({ name });
195
196
  const walletDetails = {
196
197
  provider: _CoinbaseWalletProvider.PROVIDER_NAME,
197
198
  address: account.address
@@ -216,14 +217,14 @@ var _CoinbaseWalletProvider = class _CoinbaseWalletProvider {
216
217
  async getAccount() {
217
218
  if (this.cachedAccount) return this.cachedAccount;
218
219
  const address = this.getWalletAddress();
219
- const account = this.chain.name === "solana" ? await this.client.solana.getAccount({ address }) : await this.client.evm.getAccount({ address });
220
+ const account = this.chain.name === WarpChainName.Solana ? await this.client.solana.getAccount({ address }) : await this.client.evm.getAccount({ address });
220
221
  const publicKey = this.extractPublicKey(account);
221
222
  this.cachedAccount = {
222
223
  id: account.address,
223
224
  address: account.address,
224
225
  ...publicKey && { publicKey }
225
226
  };
226
- if (this.chain.name !== "solana" && "signTransaction" in account) {
227
+ if (this.chain.name !== WarpChainName.Solana && "signTransaction" in account) {
227
228
  this.cachedEvmAccount = { signTransaction: account.signTransaction };
228
229
  }
229
230
  return this.cachedAccount;
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/CoinbaseWalletProvider.ts","../src/helpers/evm.ts","../src/helpers.ts"],"sourcesContent":["import { CdpClient } from '@coinbase/cdp-sdk'\nimport {\n getWarpWalletAddressFromConfig,\n setWarpWalletInConfig,\n WalletProvider,\n WarpAdapterGenericTransaction,\n WarpChainInfo,\n WarpClientConfig,\n WarpWalletDetails,\n WarpWalletProvider,\n} from '@vleap/warps'\nimport { formatTransactionForCoinbase } from './helpers/evm'\nimport { CoinbaseProviderConfig } from './types'\n\nexport class CoinbaseWalletProvider implements WalletProvider {\n static readonly PROVIDER_NAME: WarpWalletProvider = 'coinbase'\n private readonly client: CdpClient\n private cachedAccount: { id: string; address: string; publicKey?: string } | null = null\n private cachedEvmAccount: { signTransaction: (tx: unknown) => Promise<unknown> } | null = null\n\n constructor(\n private readonly config: WarpClientConfig,\n private readonly chain: WarpChainInfo,\n private readonly coinbaseConfig: CoinbaseProviderConfig\n ) {\n this.client = new CdpClient({\n apiKeyId: coinbaseConfig.apiKeyId,\n apiKeySecret: coinbaseConfig.apiKeySecret,\n walletSecret: coinbaseConfig.walletSecret,\n ...(coinbaseConfig.apiUrl && { apiUrl: coinbaseConfig.apiUrl }),\n })\n }\n\n async getAddress(): Promise<string | null> {\n try {\n return (await this.getAccount()).address\n } catch (error) {\n console.error('CoinbaseWalletProvider: Failed to get address', error)\n return null\n }\n }\n\n async getPublicKey(): Promise<string | null> {\n try {\n return (await this.getAccount()).publicKey ?? null\n } catch (error) {\n console.error('CoinbaseWalletProvider: Failed to get public key', error)\n return null\n }\n }\n\n async signTransaction(tx: WarpAdapterGenericTransaction): Promise<WarpAdapterGenericTransaction> {\n try {\n const account = await this.getAccount()\n\n if (this.chain.name === 'solana') {\n const result = await this.client.solana.signTransaction({\n address: account.id,\n transaction: tx as never,\n })\n\n if ('signedTransaction' in result && result.signedTransaction) {\n return { ...(tx as Record<string, unknown>), signature: String(result.signedTransaction) }\n }\n throw new Error('Coinbase API did not return signed transaction')\n }\n\n if (!this.cachedEvmAccount) {\n const address = this.getWalletAddress()\n const evmAccount = await this.client.evm.getAccount({ address: address as `0x${string}` })\n if (!('signTransaction' in evmAccount))\n throw new Error('CoinbaseWalletProvider: Account object missing signTransaction method. This may be a SDK version issue.')\n this.cachedEvmAccount = { signTransaction: evmAccount.signTransaction as (tx: unknown) => Promise<unknown> }\n }\n\n const formattedTx = formatTransactionForCoinbase(tx, this.chain.chainId)\n const signedTx = await this.cachedEvmAccount.signTransaction(formattedTx)\n return { ...(tx as Record<string, unknown>), signature: signedTx }\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error)\n if (errorMessage.includes('signTransaction is not a function')) {\n throw new Error('CoinbaseWalletProvider: Account object missing signTransaction method. This may be a SDK version issue.')\n }\n throw new Error(`CoinbaseWalletProvider: Failed to sign transaction: ${error}`)\n }\n }\n\n async signMessage(message: string): Promise<string> {\n try {\n const account = await this.getAccount()\n const result =\n this.chain.name === 'solana'\n ? await this.client.solana.signMessage({ address: account.id, message })\n : await this.client.evm.signMessage({ address: account.id as `0x${string}`, message })\n\n if ('signedMessage' in result && result.signedMessage) {\n return String(result.signedMessage)\n }\n\n throw new Error('Coinbase API did not return signed message')\n } catch (error) {\n throw new Error(`CoinbaseWalletProvider: Failed to sign message: ${error}`)\n }\n }\n\n async importFromMnemonic(mnemonic: string): Promise<WarpWalletDetails> {\n throw new Error(\n 'CoinbaseWalletProvider: importFromMnemonic() is not supported. Use generate() to create a new account via Coinbase API.'\n )\n }\n\n async importFromPrivateKey(privateKey: string): Promise<WarpWalletDetails> {\n try {\n const name = this.getAccountName()\n const account =\n this.chain.name === 'solana'\n ? await this.client.solana.importAccount({ privateKey, ...(name && { name }) })\n : await this.client.evm.importAccount({\n privateKey: (privateKey.startsWith('0x') ? privateKey : `0x${privateKey}`) as `0x${string}`,\n ...(name && { name }),\n })\n\n const walletDetails: WarpWalletDetails = {\n provider: CoinbaseWalletProvider.PROVIDER_NAME,\n address: account.address,\n privateKey,\n }\n\n setWarpWalletInConfig(this.config, this.chain.name, walletDetails)\n\n return walletDetails\n } catch (error) {\n throw new Error(`CoinbaseWalletProvider: Failed to import account from private key: ${error}`)\n }\n }\n\n async export(): Promise<WarpWalletDetails> {\n try {\n const address = this.getWalletAddress()\n const privateKey =\n this.chain.name === 'solana'\n ? await this.client.solana.exportAccount({ address })\n : await this.client.evm.exportAccount({ address: address as `0x${string}` })\n\n return {\n provider: CoinbaseWalletProvider.PROVIDER_NAME,\n address,\n privateKey,\n }\n } catch (error) {\n throw new Error(`CoinbaseWalletProvider: Failed to export account: ${error}`)\n }\n }\n\n async generate(): Promise<WarpWalletDetails> {\n try {\n const name = this.getAccountName()\n const account =\n this.chain.name === 'solana' ? await this.client.solana.createAccount({ name }) : await this.client.evm.createAccount({ name })\n\n const walletDetails: WarpWalletDetails = {\n provider: CoinbaseWalletProvider.PROVIDER_NAME,\n address: account.address,\n }\n\n setWarpWalletInConfig(this.config, this.chain.name, walletDetails)\n\n return walletDetails\n } catch (error) {\n throw new Error(`CoinbaseWalletProvider: Failed to generate account: ${error}`)\n }\n }\n\n private getAccountName(): string | undefined {\n return this.config.user?.id ? `${this.config.user.id}-${this.chain.name}` : undefined\n }\n\n private getWalletAddress(): string {\n const address = getWarpWalletAddressFromConfig(this.config, this.chain.name)\n if (!address) throw new Error(`CoinbaseWalletProvider: Wallet address not found in config for chain ${this.chain.name}`)\n return address\n }\n\n private extractPublicKey(account: { address: string; publicKey?: unknown }): string | undefined {\n return account.publicKey as string | undefined\n }\n\n private async getAccount(): Promise<{ id: string; address: string; publicKey?: string }> {\n if (this.cachedAccount) return this.cachedAccount\n\n const address = this.getWalletAddress()\n const account =\n this.chain.name === 'solana'\n ? await this.client.solana.getAccount({ address })\n : await this.client.evm.getAccount({ address: address as `0x${string}` })\n\n const publicKey = this.extractPublicKey(account)\n this.cachedAccount = {\n id: account.address,\n address: account.address,\n ...(publicKey && { publicKey }),\n }\n\n if (this.chain.name !== 'solana' && 'signTransaction' in account) {\n this.cachedEvmAccount = { signTransaction: account.signTransaction as (tx: unknown) => Promise<unknown> }\n }\n\n return this.cachedAccount\n }\n}\n","import { WarpAdapterGenericTransaction } from '@vleap/warps'\n\nconst formatBigInt = (value: bigint | string | number | undefined): string | undefined => {\n if (value === undefined || value === null) return undefined\n if (typeof value === 'bigint') {\n const hex = value.toString(16)\n return `0x${hex}`\n }\n if (typeof value === 'string' && value.startsWith('0x')) {\n const parsed = BigInt(value)\n return `0x${parsed.toString(16)}`\n }\n const parsed = BigInt(value)\n return `0x${parsed.toString(16)}`\n}\n\nconst parseBigInt = (value: bigint | string | number | undefined): bigint | undefined => {\n if (value === undefined || value === null) return undefined\n if (typeof value === 'bigint') return value\n return BigInt(value)\n}\n\nconst normalizePriorityFee = (maxFee: bigint, maxPriorityFee: bigint): bigint => {\n if (maxFee <= 0n) return 1n\n if (maxPriorityFee <= maxFee) return maxPriorityFee\n const safeFee = maxFee / 10n\n return safeFee < 1n ? 1n : safeFee\n}\n\nexport const formatTransactionForCoinbase = (tx: WarpAdapterGenericTransaction, chainId: number | string): WarpAdapterGenericTransaction => {\n const MIN_FEE = 1000000000n\n\n let maxFee: bigint\n let maxPriorityFee: bigint\n\n if (tx.maxFeePerGas !== undefined && tx.maxPriorityFeePerGas !== undefined) {\n maxFee = parseBigInt(tx.maxFeePerGas)!\n maxPriorityFee = parseBigInt(tx.maxPriorityFeePerGas)!\n if (maxFee < MIN_FEE) maxFee = MIN_FEE\n maxPriorityFee = normalizePriorityFee(maxFee, maxPriorityFee)\n } else if (tx.gasPrice !== undefined) {\n const gasPrice = parseBigInt(tx.gasPrice)!\n maxFee = gasPrice < MIN_FEE ? MIN_FEE : gasPrice\n maxPriorityFee = normalizePriorityFee(maxFee, (maxFee * 9n) / 10n)\n } else {\n maxFee = MIN_FEE\n maxPriorityFee = MIN_FEE / 10n\n }\n\n if (maxPriorityFee >= maxFee) maxPriorityFee = maxFee / 10n\n if (maxPriorityFee < 1n) maxPriorityFee = 1n\n\n const finalMaxFee = maxFee\n let finalMaxPriorityFee = maxPriorityFee\n\n const MIN_PRIORITY_FEE = 100000000n\n if (finalMaxFee >= MIN_PRIORITY_FEE * 10n && finalMaxPriorityFee < MIN_PRIORITY_FEE) {\n finalMaxPriorityFee = MIN_PRIORITY_FEE\n }\n\n if (finalMaxPriorityFee >= finalMaxFee) {\n finalMaxPriorityFee = finalMaxFee / 10n\n }\n\n if (finalMaxPriorityFee < 1n) {\n finalMaxPriorityFee = 1n\n }\n\n const formatted: any = {\n to: tx.to,\n value: formatBigInt(tx.value) || '0x0',\n data: tx.data || '0x',\n chainId: typeof tx.chainId === 'number' ? tx.chainId : parseInt(String(tx.chainId || chainId)),\n maxFeePerGas: formatBigInt(finalMaxFee)!,\n maxPriorityFeePerGas: formatBigInt(finalMaxPriorityFee)!,\n }\n\n if (tx.from) formatted.from = tx.from\n if (tx.gasLimit) formatted.gas = formatBigInt(tx.gasLimit)\n if (tx.nonce !== undefined) formatted.nonce = typeof tx.nonce === 'number' ? `0x${tx.nonce.toString(16)}` : formatBigInt(tx.nonce)\n if (tx.type) formatted.type = tx.type\n if (tx.accessList) formatted.accessList = tx.accessList\n\n delete formatted.gasPrice\n\n return formatted\n}\n","import { WalletProviderFactory, WarpChainInfo, WarpClientConfig } from '@vleap/warps'\nimport { CoinbaseWalletProvider } from './CoinbaseWalletProvider'\nimport { CoinbaseProviderConfig } from './types'\n\nexport const createCoinbaseWalletProvider = (\n coinbaseConfig: CoinbaseProviderConfig\n): WalletProviderFactory => {\n return (config: WarpClientConfig, chain: WarpChainInfo) =>\n new CoinbaseWalletProvider(config, chain, coinbaseConfig)\n}\n"],"mappings":"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","names":["parsed"]}
1
+ {"version":3,"sources":["../src/CoinbaseWalletProvider.ts","../src/helpers/evm.ts","../src/helpers.ts"],"sourcesContent":["import { CdpClient } from '@coinbase/cdp-sdk'\nimport {\n getWarpWalletAddressFromConfig,\n setWarpWalletInConfig,\n WalletProvider,\n WarpAdapterGenericTransaction,\n WarpChainInfo,\n WarpChainName,\n WarpClientConfig,\n WarpWalletDetails,\n WarpWalletProvider,\n} from '@vleap/warps'\nimport { formatTransactionForCoinbase } from './helpers/evm'\nimport { CoinbaseProviderConfig } from './types'\n\nexport class CoinbaseWalletProvider implements WalletProvider {\n static readonly PROVIDER_NAME: WarpWalletProvider = 'coinbase'\n private readonly client: CdpClient\n private cachedAccount: { id: string; address: string; publicKey?: string } | null = null\n private cachedEvmAccount: { signTransaction: (tx: unknown) => Promise<unknown> } | null = null\n\n constructor(\n private readonly config: WarpClientConfig,\n private readonly chain: WarpChainInfo,\n private readonly coinbaseConfig: CoinbaseProviderConfig\n ) {\n this.client = new CdpClient({\n apiKeyId: coinbaseConfig.apiKeyId,\n apiKeySecret: coinbaseConfig.apiKeySecret,\n walletSecret: coinbaseConfig.walletSecret,\n ...(coinbaseConfig.apiUrl && { apiUrl: coinbaseConfig.apiUrl }),\n })\n }\n\n async getAddress(): Promise<string | null> {\n try {\n return (await this.getAccount()).address\n } catch (error) {\n console.error('CoinbaseWalletProvider: Failed to get address', error)\n return null\n }\n }\n\n async getPublicKey(): Promise<string | null> {\n try {\n return (await this.getAccount()).publicKey ?? null\n } catch (error) {\n console.error('CoinbaseWalletProvider: Failed to get public key', error)\n return null\n }\n }\n\n async signTransaction(tx: WarpAdapterGenericTransaction): Promise<WarpAdapterGenericTransaction> {\n try {\n const account = await this.getAccount()\n\n if (this.chain.name === WarpChainName.Solana) {\n const result = await this.client.solana.signTransaction({\n address: account.id,\n transaction: tx as never,\n })\n\n if ('signedTransaction' in result && result.signedTransaction) {\n return { ...(tx as Record<string, unknown>), signature: String(result.signedTransaction) }\n }\n throw new Error('Coinbase API did not return signed transaction')\n }\n\n if (!this.cachedEvmAccount) {\n const address = this.getWalletAddress()\n const evmAccount = await this.client.evm.getAccount({ address: address as `0x${string}` })\n if (!('signTransaction' in evmAccount))\n throw new Error('CoinbaseWalletProvider: Account object missing signTransaction method. This may be a SDK version issue.')\n this.cachedEvmAccount = { signTransaction: evmAccount.signTransaction as (tx: unknown) => Promise<unknown> }\n }\n\n const formattedTx = formatTransactionForCoinbase(tx, this.chain.chainId)\n const signedTx = await this.cachedEvmAccount.signTransaction(formattedTx)\n return { ...(tx as Record<string, unknown>), signature: signedTx }\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error)\n if (errorMessage.includes('signTransaction is not a function')) {\n throw new Error('CoinbaseWalletProvider: Account object missing signTransaction method. This may be a SDK version issue.')\n }\n throw new Error(`CoinbaseWalletProvider: Failed to sign transaction: ${error}`)\n }\n }\n\n async signMessage(message: string): Promise<string> {\n try {\n const account = await this.getAccount()\n const result =\n this.chain.name === WarpChainName.Solana\n ? await this.client.solana.signMessage({ address: account.id, message })\n : await this.client.evm.signMessage({ address: account.id as `0x${string}`, message })\n\n if ('signedMessage' in result && result.signedMessage) {\n return String(result.signedMessage)\n }\n\n throw new Error('Coinbase API did not return signed message')\n } catch (error) {\n throw new Error(`CoinbaseWalletProvider: Failed to sign message: ${error}`)\n }\n }\n\n async importFromMnemonic(mnemonic: string): Promise<WarpWalletDetails> {\n throw new Error(\n 'CoinbaseWalletProvider: importFromMnemonic() is not supported. Use generate() to create a new account via Coinbase API.'\n )\n }\n\n async importFromPrivateKey(privateKey: string): Promise<WarpWalletDetails> {\n try {\n const name = this.getAccountName()\n const account =\n this.chain.name === 'solana'\n ? await this.client.solana.importAccount({ privateKey, ...(name && { name }) })\n : await this.client.evm.importAccount({\n privateKey: (privateKey.startsWith('0x') ? privateKey : `0x${privateKey}`) as `0x${string}`,\n ...(name && { name }),\n })\n\n const walletDetails: WarpWalletDetails = {\n provider: CoinbaseWalletProvider.PROVIDER_NAME,\n address: account.address,\n privateKey,\n }\n\n setWarpWalletInConfig(this.config, this.chain.name, walletDetails)\n\n return walletDetails\n } catch (error) {\n throw new Error(`CoinbaseWalletProvider: Failed to import account from private key: ${error}`)\n }\n }\n\n async export(): Promise<WarpWalletDetails> {\n try {\n const address = this.getWalletAddress()\n const privateKey =\n this.chain.name === WarpChainName.Solana\n ? await this.client.solana.exportAccount({ address })\n : await this.client.evm.exportAccount({ address: address as `0x${string}` })\n\n return {\n provider: CoinbaseWalletProvider.PROVIDER_NAME,\n address,\n privateKey,\n }\n } catch (error) {\n throw new Error(`CoinbaseWalletProvider: Failed to export account: ${error}`)\n }\n }\n\n async generate(): Promise<WarpWalletDetails> {\n try {\n const name = this.getAccountName()\n const account =\n this.chain.name === WarpChainName.Solana\n ? await this.client.solana.createAccount({ name })\n : await this.client.evm.createAccount({ name })\n\n const walletDetails: WarpWalletDetails = {\n provider: CoinbaseWalletProvider.PROVIDER_NAME,\n address: account.address,\n }\n\n setWarpWalletInConfig(this.config, this.chain.name, walletDetails)\n\n return walletDetails\n } catch (error) {\n throw new Error(`CoinbaseWalletProvider: Failed to generate account: ${error}`)\n }\n }\n\n private getAccountName(): string | undefined {\n return this.config.user?.id ? `${this.config.user.id}-${this.chain.name}` : undefined\n }\n\n private getWalletAddress(): string {\n const address = getWarpWalletAddressFromConfig(this.config, this.chain.name)\n if (!address) throw new Error(`CoinbaseWalletProvider: Wallet address not found in config for chain ${this.chain.name}`)\n return address\n }\n\n private extractPublicKey(account: { address: string; publicKey?: unknown }): string | undefined {\n return account.publicKey as string | undefined\n }\n\n private async getAccount(): Promise<{ id: string; address: string; publicKey?: string }> {\n if (this.cachedAccount) return this.cachedAccount\n\n const address = this.getWalletAddress()\n const account =\n this.chain.name === WarpChainName.Solana\n ? await this.client.solana.getAccount({ address })\n : await this.client.evm.getAccount({ address: address as `0x${string}` })\n\n const publicKey = this.extractPublicKey(account)\n this.cachedAccount = {\n id: account.address,\n address: account.address,\n ...(publicKey && { publicKey }),\n }\n\n if (this.chain.name !== WarpChainName.Solana && 'signTransaction' in account) {\n this.cachedEvmAccount = { signTransaction: account.signTransaction as (tx: unknown) => Promise<unknown> }\n }\n\n return this.cachedAccount\n }\n}\n","import { WarpAdapterGenericTransaction } from '@vleap/warps'\n\nconst formatBigInt = (value: bigint | string | number | undefined): string | undefined => {\n if (value === undefined || value === null) return undefined\n if (typeof value === 'bigint') {\n const hex = value.toString(16)\n return `0x${hex}`\n }\n if (typeof value === 'string' && value.startsWith('0x')) {\n const parsed = BigInt(value)\n return `0x${parsed.toString(16)}`\n }\n const parsed = BigInt(value)\n return `0x${parsed.toString(16)}`\n}\n\nconst parseBigInt = (value: bigint | string | number | undefined): bigint | undefined => {\n if (value === undefined || value === null) return undefined\n if (typeof value === 'bigint') return value\n return BigInt(value)\n}\n\nconst normalizePriorityFee = (maxFee: bigint, maxPriorityFee: bigint): bigint => {\n if (maxFee <= 0n) return 1n\n if (maxPriorityFee <= maxFee) return maxPriorityFee\n const safeFee = maxFee / 10n\n return safeFee < 1n ? 1n : safeFee\n}\n\nexport const formatTransactionForCoinbase = (tx: WarpAdapterGenericTransaction, chainId: number | string): WarpAdapterGenericTransaction => {\n const MIN_FEE = 1000000000n\n\n let maxFee: bigint\n let maxPriorityFee: bigint\n\n if (tx.maxFeePerGas !== undefined && tx.maxPriorityFeePerGas !== undefined) {\n maxFee = parseBigInt(tx.maxFeePerGas)!\n maxPriorityFee = parseBigInt(tx.maxPriorityFeePerGas)!\n if (maxFee < MIN_FEE) maxFee = MIN_FEE\n maxPriorityFee = normalizePriorityFee(maxFee, maxPriorityFee)\n } else if (tx.gasPrice !== undefined) {\n const gasPrice = parseBigInt(tx.gasPrice)!\n maxFee = gasPrice < MIN_FEE ? MIN_FEE : gasPrice\n maxPriorityFee = normalizePriorityFee(maxFee, (maxFee * 9n) / 10n)\n } else {\n maxFee = MIN_FEE\n maxPriorityFee = MIN_FEE / 10n\n }\n\n if (maxPriorityFee >= maxFee) maxPriorityFee = maxFee / 10n\n if (maxPriorityFee < 1n) maxPriorityFee = 1n\n\n const finalMaxFee = maxFee\n let finalMaxPriorityFee = maxPriorityFee\n\n const MIN_PRIORITY_FEE = 100000000n\n if (finalMaxFee >= MIN_PRIORITY_FEE * 10n && finalMaxPriorityFee < MIN_PRIORITY_FEE) {\n finalMaxPriorityFee = MIN_PRIORITY_FEE\n }\n\n if (finalMaxPriorityFee >= finalMaxFee) {\n finalMaxPriorityFee = finalMaxFee / 10n\n }\n\n if (finalMaxPriorityFee < 1n) {\n finalMaxPriorityFee = 1n\n }\n\n const formatted: any = {\n to: tx.to,\n value: formatBigInt(tx.value) || '0x0',\n data: tx.data || '0x',\n chainId: typeof tx.chainId === 'number' ? tx.chainId : parseInt(String(tx.chainId || chainId)),\n maxFeePerGas: formatBigInt(finalMaxFee)!,\n maxPriorityFeePerGas: formatBigInt(finalMaxPriorityFee)!,\n }\n\n if (tx.from) formatted.from = tx.from\n if (tx.gasLimit) formatted.gas = formatBigInt(tx.gasLimit)\n if (tx.nonce !== undefined) formatted.nonce = typeof tx.nonce === 'number' ? `0x${tx.nonce.toString(16)}` : formatBigInt(tx.nonce)\n if (tx.type) formatted.type = tx.type\n if (tx.accessList) formatted.accessList = tx.accessList\n\n delete formatted.gasPrice\n\n return formatted\n}\n","import { WalletProviderFactory, WarpChainInfo, WarpClientConfig } from '@vleap/warps'\nimport { CoinbaseWalletProvider } from './CoinbaseWalletProvider'\nimport { CoinbaseProviderConfig } from './types'\n\nexport const createCoinbaseWalletProvider = (\n coinbaseConfig: CoinbaseProviderConfig\n): WalletProviderFactory => {\n return (config: WarpClientConfig, chain: WarpChainInfo) =>\n new CoinbaseWalletProvider(config, chain, coinbaseConfig)\n}\n"],"mappings":"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","names":["parsed"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@vleap/warps-wallet-coinbase",
3
- "version": "1.0.0-beta.6",
3
+ "version": "1.0.0-beta.8",
4
4
  "description": "Coinbase Server Wallet v2 provider for multiple chains",
5
5
  "type": "module",
6
6
  "types": "./dist/index.d.ts",
@@ -36,9 +36,9 @@
36
36
  },
37
37
  "dependencies": {
38
38
  "@coinbase/cdp-sdk": "^1.0.0",
39
- "@vleap/warps": "^3.0.0-beta.187"
39
+ "@vleap/warps": "^3.0.0-beta.189"
40
40
  },
41
41
  "peerDependencies": {
42
- "@vleap/warps": "^3.0.0-beta.187"
42
+ "@vleap/warps": "^3.0.0-beta.189"
43
43
  }
44
44
  }