@crossmint/client-sdk-smart-wallet 0.1.2 → 0.1.4
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.cjs +4 -1
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +254 -119
- package/dist/index.d.ts +254 -119
- package/dist/index.js +4 -1
- package/dist/index.js.map +1 -1
- package/package.json +5 -13
- package/src/SmartWalletSDK.test.ts +12 -13
- package/src/SmartWalletSDK.ts +33 -26
- package/src/api/APIErrorService.ts +10 -7
- package/src/api/BaseCrossmintService.ts +3 -4
- package/src/api/CrossmintWalletService.test.ts +9 -9
- package/src/api/CrossmintWalletService.ts +39 -16
- package/src/blockchain/chains.ts +25 -2
- package/src/blockchain/transfer.ts +1 -1
- package/src/blockchain/wallets/EVMSmartWallet.ts +49 -42
- package/src/blockchain/wallets/account/config.ts +60 -0
- package/src/blockchain/wallets/account/creator.ts +36 -0
- package/src/blockchain/wallets/account/eoa.ts +50 -0
- package/src/blockchain/wallets/{passkey.ts → account/passkey.ts} +32 -32
- package/src/blockchain/wallets/account/signer.ts +44 -0
- package/src/blockchain/wallets/account/strategy.ts +5 -0
- package/src/blockchain/wallets/clientDecorator.ts +6 -6
- package/src/blockchain/wallets/paymaster.ts +12 -15
- package/src/blockchain/wallets/service.ts +38 -143
- package/src/error/index.ts +25 -117
- package/src/error/processor.ts +5 -6
- package/src/index.ts +16 -12
- package/src/services/logging/ConsoleProvider.ts +3 -12
- package/src/services/logging/DatadogProvider.ts +1 -1
- package/src/types/internal.ts +41 -20
- package/src/types/{Config.ts → params.ts} +0 -5
- package/src/types/schema.ts +63 -0
- package/src/types/service.ts +31 -0
- package/src/utils/api.ts +39 -0
- package/src/utils/constants.ts +2 -0
- package/src/utils/log.ts +1 -109
- package/src/utils/signer.ts +14 -16
- package/src/blockchain/wallets/eoa.ts +0 -49
- package/src/types/API.ts +0 -40
- package/src/utils/log.test.ts +0 -76
- /package/src/types/{Tokens.ts → token.ts} +0 -0
package/dist/index.cjs
CHANGED
|
@@ -1,2 +1,5 @@
|
|
|
1
|
-
"use strict";var q=Object.defineProperty,ue=Object.defineProperties,ye=Object.getOwnPropertyDescriptor,fe=Object.getOwnPropertyDescriptors,Ee=Object.getOwnPropertyNames,bt=Object.getOwnPropertySymbols;var vt=Object.prototype.hasOwnProperty,Se=Object.prototype.propertyIsEnumerable;var Dt=(r,t,e)=>t in r?q(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,d=(r,t)=>{for(var e in t||(t={}))vt.call(t,e)&&Dt(r,e,t[e]);if(bt)for(var e of bt(t))Se.call(t,e)&&Dt(r,e,t[e]);return r},S=(r,t)=>ue(r,fe(t));var ge=(r,t)=>{for(var e in t)q(r,e,{get:t[e],enumerable:!0})},Pe=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of Ee(t))!vt.call(r,a)&&a!==e&&q(r,a,{get:()=>t[a],enumerable:!(n=ye(t,a))||n.enumerable});return r};var he=r=>Pe(q({},"__esModule",{value:!0}),r);var i=(r,t,e)=>new Promise((n,a)=>{var o=u=>{try{l(e.next(u))}catch(p){a(p)}},s=u=>{try{l(e.throw(u))}catch(p){a(p)}},l=u=>u.done?n(u.value):Promise.resolve(u.value).then(o,s);l((e=e.apply(r,t)).next())});var Me={};ge(Me,{AdminAlreadyUsedError:()=>$,AdminMismatchError:()=>h,Chain:()=>gt.EVMBlockchainIncludingTestnet,ConfigError:()=>K,CrossmintServiceError:()=>E,EVMSmartWallet:()=>F,JWTDecryptionError:()=>k,JWTExpiredError:()=>v,JWTIdentifierError:()=>N,JWTInvalidError:()=>x,NonCustodialWalletsNotEnabledError:()=>B,NotAuthorizedError:()=>T,OutOfCreditsError:()=>U,PasskeyIncompatibleAuthenticatorError:()=>L,PasskeyMismatchError:()=>D,PasskeyPromptError:()=>V,PasskeyRegistrationError:()=>M,SmartWalletSDK:()=>St,SmartWalletSDKError:()=>c,TransferError:()=>b,UserWalletAlreadyCreatedError:()=>A,blockchainToChainId:()=>gt.blockchainToChainId});module.exports=he(Me);var gt=require("@crossmint/common-sdk-base");function X(){return typeof window!="undefined"}function Z(){return process.env.NODE_ENV==="test"?!1:window.location.origin.includes("localhost")}function Q(r,t){return(r==null?void 0:r.toLowerCase())===(t==null?void 0:t.toLowerCase())}var Pt=!1,tt=class{logInfo(t,e){Pt&&console.log(t,e)}logError(t,e){Pt&&console.error(t,e)}logWarn(t,e){Pt&&console.warn(t,e)}};var xt="ZeroDev";var kt="pub035be8a594b35be1887b6ba76c4029ca",Nt="http://localhost:3000/api",Vt="https://staging.crossmint.com/api",Mt="https://www.crossmint.com/api",P="SCW_SDK",Lt="0.1.0",ht="2024-06-09",Ut="https://rpc.zerodev.app/api/v2/bundler/",Kt="https://rpc.zerodev.app/api/v2/paymaster/";var et=require("@datadog/browser-logs");var W=class{logInfo(t,e){Rt(t,"info",e)}logError(t,e){Rt(t,"error",e)}logWarn(t,e){Rt(t,"warn",e)}};function Rt(r,t,e){let n=e?S(d({},e),{service:P}):{service:P};Re(),et.datadogLogs.logger[t](r,n)}function Re(){et.datadogLogs.getInternalContext()==null&&et.datadogLogs.init({clientToken:kt,site:"datadoghq.com",forwardErrorsToLogs:!1,sampleRate:100})}function Te(){return X()&&Z()?new tt:new W}var{logInfo:rt,logWarn:qe,logError:C}=Te();var G=require("viem");var y={NOT_AUTHORIZED:"smart-wallet:not-authorized",TRANSFER:"smart-wallet:transfer.error",CROSSMINT_SERVICE:"smart-wallet:crossmint-service.error",ERROR_JWT_EXPIRED:"smart-wallet:not-authorized.jwt-expired",ERROR_JWT_INVALID:"smart-wallet:not-authorized.jwt-invalid",ERROR_JWT_DECRYPTION:"smart-wallet:not-authorized.jwt-decryption",ERROR_JWT_IDENTIFIER:"smart-wallet:not-authorized.jwt-identifier",ERROR_USER_WALLET_ALREADY_CREATED:"smart-wallet:user-wallet-already-created.error",ERROR_OUT_OF_CREDITS:"smart-wallet:out-of-credits.error",ERROR_WALLET_CONFIG:"smart-wallet:wallet-config.error",ERROR_ADMIN_MISMATCH:"smart-wallet:wallet-config.admin-mismatch",ERROR_PASSKEY_MISMATCH:"smart-wallet:wallet-config.passkey-mismatch",ERROR_PASSKEY_PROMPT:"smart-wallet:passkey.prompt",ERROR_PASSKEY_INCOMPATIBLE_AUTHENTICATOR:"smart-wallet.passkey.incompatible-authenticator",ERROR_PASSKEY_REGISTRATION:"smart-wallet:passkey.registration",ERROR_ADMIN_SIGNER_ALREADY_USED:"smart-wallet:wallet-config.admin-signer-already-used",ERROR_PROJECT_NONCUSTODIAL_WALLETS_NOT_ENABLED:"smart-wallet:wallet-config.non-custodial-wallets-not-enabled",UNCATEGORIZED:"smart-wallet:uncategorized"},c=class extends Error{constructor(t,e,n=y.UNCATEGORIZED){super(t),this.details=e,this.code=n}},b=class extends c{constructor(t){super(t,void 0,y.TRANSFER)}},E=class extends c{constructor(t,e){super(t,void 0,y.CROSSMINT_SERVICE),this.status=e}},h=class extends c{constructor(t,e,n){super(t,y.ERROR_ADMIN_MISMATCH),this.required=e,this.used=n}},D=class extends c{constructor(t,e,n){super(t,y.ERROR_PASSKEY_MISMATCH),this.required=e,this.used=n}},T=class extends c{constructor(t){super(t,void 0,y.NOT_AUTHORIZED)}},v=class extends T{constructor(e){super(`JWT provided expired at timestamp ${e}`);this.code=y.ERROR_JWT_EXPIRED;this.expiredAt=e.toISOString()}},x=class extends T{constructor(){super("Invalid JWT provided");this.code=y.ERROR_JWT_INVALID}},k=class extends T{constructor(){super("Error decrypting JWT");this.code=y.ERROR_JWT_DECRYPTION}},N=class extends T{constructor(e){super(`Missing required identifier '${e}' in the JWT`);this.code=y.ERROR_JWT_IDENTIFIER;this.identifierKey=e}},A=class extends c{constructor(e){super(`The user with userId ${e.toString()} already has a wallet created for this project`);this.code=y.ERROR_USER_WALLET_ALREADY_CREATED}},V=class extends c{constructor(t){super(`Prompt was either cancelled or timed out for passkey ${t}`,void 0,y.ERROR_PASSKEY_PROMPT),this.passkeyName=t}},M=class extends c{constructor(t){super(`Registration for passkey ${t} failed, either the registration took too long, or passkey signature vaildation failed.`,void 0,y.ERROR_PASSKEY_REGISTRATION),this.passkeyName=t}},L=class extends c{constructor(t){super(`User selected authenticator for passkey ${t} is not compatible with Crossmint's Smart Wallets.`,void 0,y.ERROR_PASSKEY_INCOMPATIBLE_AUTHENTICATOR),this.passkeyName=t}},U=class extends c{constructor(t){super("You've run out of Crossmint API credits. Visit https://docs.crossmint.com/docs/errors for more information",void 0,y.ERROR_OUT_OF_CREDITS)}},K=class extends c{constructor(t){super(t,void 0,y.ERROR_WALLET_CONFIG)}},$=class extends K{constructor(){super("This signer was already used to create another wallet. Please use a different signer.");this.code=y.ERROR_ADMIN_SIGNER_ALREADY_USED}},B=class extends K{constructor(){super("Non-custodial wallets are not enabled for this project");this.code=y.ERROR_PROJECT_NONCUSTODIAL_WALLETS_NOT_ENABLED}};var $t=require("uuid");var w=class{constructor(t,e={},n=(0,$t.v4)()){this.extraInfo=e;this.logIdempotencyKey=n;return new Proxy(this,{get:(a,o,s)=>{let l=a[o],u=`[${P} - ${t} - ${String(o)}]`;return typeof l=="function"?(...p)=>{this.logInput(p,u);let m=l.apply(a,p);return m instanceof Promise?m.then(f=>(this.logOutput(f,u),f)).catch(f=>{throw this.logError(f,u),f}):(this.logOutput(m,u),m)}:Reflect.get(a,o,s)}})}logInput(t,e){Y(`${e} input - ${g(t)} - extra_info - ${g(this.extraInfo)} - log_idempotency_key - ${this.logIdempotencyKey}`,S(d({args:t},this.extraInfo),{logIdempotencyKey:this.logIdempotencyKey}))}logOutput(t,e){Y(`${e} output - ${g(t)} - extra_info - ${g(this.extraInfo)} - log_idempotency_key - ${this.logIdempotencyKey}`,S(d({res:t},this.extraInfo),{logIdempotencyKey:this.logIdempotencyKey}))}logError(t,e){C(`${e} threw_error - ${t} - extra_info - ${g(this.extraInfo)} - log_idempotency_key - ${this.logIdempotencyKey}`,d({err:t},this.extraInfo))}logPerformance(t,e){return _(t,e,this.extraInfo)}};function _(r,t,e){return i(this,null,function*(){let n=new Date().getTime(),a=yield t(),o=new Date().getTime()-n,s=d({durationInMs:o},e);return Y(`[${P} - ${r} - TIME] - ${g(s)}`,{args:s}),a})}function Bt(r,t){return function(...e){let n=`[${P} - function: ${t}]`;Y(`${n} input: ${g(e)}`,{args:e});try{let a=r.apply(this,e);return a instanceof Promise?a.then(o=>(Y(`${n} output: ${g(o)}`,{res:o}),o)).catch(o=>{throw C(`${n} threw_error: ${g(o)}`,{err:o}),o}):(Y(`${n} output: ${g(a)}`,{res:a}),a)}catch(a){throw C(`${n} threw_error: ${g(a)}`,{err:a}),a}}}function g(r){try{return r!=null?JSON.stringify(r,null,2):r}catch(t){return Ae(r)}}function Ae(r){let t={};for(let e in r)Object.prototype.hasOwnProperty.call(r,e)&&typeof r[e]!="object"&&typeof r[e]!="function"&&(t[e]=r[e]);return JSON.stringify(t,null,2)}function Y(r,t){if(Z()){console.log(r);return}rt(r,t)}function Yt(r){var e;let t=r instanceof Error?r:{message:"Unknown error",name:"Unknown error"};if(!(t instanceof Error)&&((e=t.constructor)==null?void 0:e.name)!=="SyntheticBaseEvent")throw C("ERROR_TO_JSON_FAILED",{error:t}),new Error("[errorToJSON] err is not instanceof Error nor SyntheticBaseEvent");return JSON.parse(JSON.stringify(t,Object.getOwnPropertyNames(t)))}var nt=require("viem");var Ft=[{inputs:[{internalType:"string",name:"uri_",type:"string"}],stateMutability:"nonpayable",type:"constructor"},{anonymous:!1,inputs:[{indexed:!0,internalType:"address",name:"account",type:"address"},{indexed:!0,internalType:"address",name:"operator",type:"address"},{indexed:!1,internalType:"bool",name:"approved",type:"bool"}],name:"ApprovalForAll",type:"event"},{anonymous:!1,inputs:[{indexed:!0,internalType:"address",name:"operator",type:"address"},{indexed:!0,internalType:"address",name:"from",type:"address"},{indexed:!0,internalType:"address",name:"to",type:"address"},{indexed:!1,internalType:"uint256[]",name:"ids",type:"uint256[]"},{indexed:!1,internalType:"uint256[]",name:"values",type:"uint256[]"}],name:"TransferBatch",type:"event"},{anonymous:!1,inputs:[{indexed:!0,internalType:"address",name:"operator",type:"address"},{indexed:!0,internalType:"address",name:"from",type:"address"},{indexed:!0,internalType:"address",name:"to",type:"address"},{indexed:!1,internalType:"uint256",name:"id",type:"uint256"},{indexed:!1,internalType:"uint256",name:"value",type:"uint256"}],name:"TransferSingle",type:"event"},{anonymous:!1,inputs:[{indexed:!1,internalType:"string",name:"value",type:"string"},{indexed:!0,internalType:"uint256",name:"id",type:"uint256"}],name:"URI",type:"event"},{inputs:[{internalType:"address",name:"account",type:"address"},{internalType:"uint256",name:"id",type:"uint256"}],name:"balanceOf",outputs:[{internalType:"uint256",name:"",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"address[]",name:"accounts",type:"address[]"},{internalType:"uint256[]",name:"ids",type:"uint256[]"}],name:"balanceOfBatch",outputs:[{internalType:"uint256[]",name:"",type:"uint256[]"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"address",name:"account",type:"address"},{internalType:"address",name:"operator",type:"address"}],name:"isApprovedForAll",outputs:[{internalType:"bool",name:"",type:"bool"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"address",name:"from",type:"address"},{internalType:"address",name:"to",type:"address"},{internalType:"uint256[]",name:"ids",type:"uint256[]"},{internalType:"uint256[]",name:"amounts",type:"uint256[]"},{internalType:"bytes",name:"data",type:"bytes"}],name:"safeBatchTransferFrom",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"address",name:"from",type:"address"},{internalType:"address",name:"to",type:"address"},{internalType:"uint256",name:"id",type:"uint256"},{internalType:"uint256",name:"amount",type:"uint256"},{internalType:"bytes",name:"data",type:"bytes"}],name:"safeTransferFrom",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"address",name:"operator",type:"address"},{internalType:"bool",name:"approved",type:"bool"}],name:"setApprovalForAll",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"bytes4",name:"interfaceId",type:"bytes4"}],name:"supportsInterface",outputs:[{internalType:"bool",name:"",type:"bool"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"uint256",name:"",type:"uint256"}],name:"uri",outputs:[{internalType:"string",name:"",type:"string"}],stateMutability:"view",type:"function"}];function Jt({contract:r,config:t,from:e,to:n}){switch(t.token.type){case"ft":return{account:e,address:r,abi:nt.erc20Abi,functionName:"transfer",args:[n,t.amount]};case"sft":return{account:e,address:r,abi:Ft,functionName:"safeTransferFrom",args:[e.address,n,t.token.tokenId,t.quantity,"0x00"],tokenId:t.token.tokenId};case"nft":return{account:e,address:r,abi:nt.erc721Abi,functionName:"safeTransferFrom",args:[e.address,n,t.token.tokenId],tokenId:t.token.tokenId}}}var F=class extends w{constructor(e,n,a,o){super("EVMSmartWallet",{chain:o,address:n.account.address});this.crossmintService=e;this.accountClient=n;this.chain=o,this.client={wallet:n,public:a}}get address(){return this.accountClient.account.address}transferToken(e,n){return i(this,null,function*(){return this.logPerformance("TRANSFER",()=>i(this,null,function*(){if(this.chain!==n.token.chain)throw new Error(`Chain mismatch: Expected ${n.token.chain}, but got ${this.chain}. Ensure you are interacting with the correct blockchain.`);if(!(0,G.isAddress)(e))throw new Error(`Invalid recipient address: '${e}' is not a valid EVM address.`);if(!(0,G.isAddress)(n.token.contractAddress))throw new Error(`Invalid contract address: '${n.token.contractAddress}' is not a valid EVM address.`);let a=Jt({contract:n.token.contractAddress,to:e,from:this.accountClient.account,config:n});try{let o=this.accountClient.extend(G.publicActions),{request:s}=yield o.simulateContract(a);return yield o.writeContract(s)}catch(o){C("[TRANSFER] - ERROR_TRANSFERRING_TOKEN",{service:P,error:Yt(o),tokenId:a.tokenId,contractAddress:n.token.contractAddress,chain:n.token.chain});let s=a.tokenId==null?"":`:${a.tokenId}}`;throw new b(`Error transferring token ${n.token.contractAddress}${s}`)}}))})}nfts(){return i(this,null,function*(){return this.crossmintService.fetchNFTs(this.address,this.chain)})}};var pe=require("viem"),me=require("@crossmint/common-sdk-base");var Gt=require("@crossmint/common-sdk-base");var at=class{constructor(t={ERROR_JWT_INVALID:()=>new x,ERROR_JWT_DECRYPTION:()=>new k,ERROR_JWT_EXPIRED:({expiredAt:e})=>new v(new Date(e)),ERROR_JWT_IDENTIFIER:({identifierKey:e})=>new N(e),ERROR_USER_WALLET_ALREADY_CREATED:({userId:e})=>new A(e),ERROR_ADMIN_SIGNER_ALREADY_USED:()=>new $,ERROR_PROJECT_NONCUSTODIAL_WALLETS_NOT_ENABLED:()=>new B}){this.errors=t}throwErrorFromResponse(n){return i(this,arguments,function*({response:t,onServerErrorMessage:e}){if(!t.ok){if(t.status>=500)throw new E(e,t.status);if(t.status===402)throw new U;try{let a=yield t.json(),o=a.code;if(o!=null&&this.errors[o]!=null)throw this.errors[o](a);if(a.message!=null)throw new E(a.message,t.status)}catch(a){if(a instanceof c)throw a;console.error("Error parsing response",a)}throw new E(yield t.text(),t.status)}})}};var H=class H extends w{constructor(t){super("BaseCrossmintService");let e=(0,Gt.validateAPIKey)(t);if(!e.isValid)throw new Error("API key invalid");this.crossmintAPIHeaders={accept:"application/json","content-type":"application/json","x-api-key":t},this.crossmintBaseUrl=this.getUrlFromEnv(e.environment),this.apiErrorService=new at}fetchCrossmintAPI(o){return i(this,arguments,function*(t,e={method:"GET"},n,a){return _("FETCH_CROSSMINT_API",()=>i(this,null,function*(){let s=`${this.crossmintBaseUrl}/${t}`,{body:l,method:u}=e,p;try{p=yield fetch(s,{body:l,method:u,headers:d(d({},this.crossmintAPIHeaders),a!=null&&{Authorization:`Bearer ${a}`})})}catch(m){throw new E(`Error fetching Crossmint API: ${m}`)}return p.ok||(yield this.apiErrorService.throwErrorFromResponse({response:p,onServerErrorMessage:n})),yield p.json()}),{endpoint:t})})}getUrlFromEnv(t){let e=H.urlMap[t];if(!e)throw console.log(" CrossmintService.urlMap: ",H.urlMap),new Error(`URL not found for environment: ${t}`);return e}};H.urlMap={development:Nt,staging:Vt,production:Mt};var ot=H;var st=class extends ot{idempotentCreateSmartWallet(t,e){return i(this,null,function*(){return this.fetchCrossmintAPI(`${ht}/sdk/smart-wallet`,{method:"PUT",body:JSON.stringify(e)},"Error creating abstract wallet. Please contact support",t.jwt)})}getSmartWalletConfig(t,e){return i(this,null,function*(){return this.fetchCrossmintAPI(`${ht}/sdk/smart-wallet/config?chain=${e}`,{method:"GET"},"Error getting smart wallet version configuration. Please contact support",t.jwt)})}fetchNFTs(t,e){return i(this,null,function*(){return this.fetchCrossmintAPI(`v1-alpha1/wallets/${e}:${t}/nfts`,{method:"GET"},`Error fetching NFTs for wallet: ${t}`)})}getPasskeyServerUrl(){return this.crossmintBaseUrl+"/internal/passkeys"}};function it(r){return!1}var At=require("viem");var Ie=["sendTransaction","writeContract","sendUserOperation"],Ce=["signMessage","signTypedData"];function Tt(r){return Ie.includes(r)}function _e(r){return Ce.includes(r)}var lt=class{constructor(t){this.errorProcessor=t}decorate({crossmintChain:t,smartAccountClient:e}){return new Proxy(e,{get:(n,a,o)=>{let s=Reflect.get(n,a,o);return typeof s!="function"||typeof a!="string"||!(_e(a)||Tt(a))?s:(...l)=>_(`CrossmintSmartWallet.${a}`,()=>this.execute(n,a,s,l,t))}})}execute(t,e,n,a,o){return i(this,null,function*(){try{rt(`[CrossmintSmartWallet.${e}] - params: ${(0,At.stringify)(a)}`);let s=Tt(e)?this.processTxnArgs(e,o,a):a;return yield n.call(t,...s)}catch(s){let l=Tt(e)?"signing":"sending transaction";throw this.errorProcessor.map(s,new c(`Error ${l}: ${s.message}`,(0,At.stringify)(s)))}})}processTxnArgs(t,e,n){if(t==="sendUserOperation"){let[{userOperation:o,middleware:s,account:l}]=n;return[{middleware:s,account:l,userOperation:this.addGelatoBundlerProperties(e,o)},...n.slice(1)]}let[a]=n;return[this.addGelatoBundlerProperties(e,a),...n.slice(1)]}addGelatoBundlerProperties(t,e){return it(t)?S(d({},e),{maxFeePerGas:"0x0",maxPriorityFeePerGas:"0x0"}):e}};function ct(r){return{pubKeyX:r.pubKeyX,pubKeyY:r.pubKeyY,passkeyName:r.passkeyName,type:"passkeys"}}var le=require("@zerodev/sdk"),yt=require("permissionless"),O=require("viem"),ce=require("@crossmint/common-sdk-base");var wt=["0.3.1","0.3.0","0.2.4"];function Ht(r){return wt.includes(r)}var It=["v0.6","v0.7"];function jt(r){return It.includes(r)}var I=require("viem/chains"),R=require("@crossmint/common-sdk-base");var zt={BASE_SEPOLIA:R.BlockchainIncludingTestnet.BASE_SEPOLIA,POLYGON_AMOY:R.BlockchainIncludingTestnet.POLYGON_AMOY},Br=(0,R.objectValues)(zt),qt={BASE:R.BlockchainIncludingTestnet.BASE,POLYGON:R.BlockchainIncludingTestnet.POLYGON},Yr=(0,R.objectValues)(qt),Oe=d(d({},zt),qt),Fr=(0,R.objectValues)(Oe),Ct={polygon:"5c9f4865-ca8e-44bb-9b9e-3810b2b46f9f","polygon-amoy":"3deef404-ca06-4a5d-9a58-907c99e7ef00","base-sepolia":"5a127978-6473-4784-9dfb-f74395b220a6",base:"e8b3020f-4dde-4176-8a7d-be8102527a5c"},pt={polygon:I.polygon,"polygon-amoy":I.polygonAmoy,base:I.base,"base-sepolia":I.baseSepolia},_t=r=>Ut+Ct[r];var Xt=require("permissionless");var Zt=Bt(t=>i(void 0,[t],function*({walletParams:r}){if(We(r.signer))return yield(0,Xt.providerToSmartAccountSigner)(r.signer);if(be(r.signer))return r.signer.account;{let e=r.signer;throw new c(`The signer type ${e.type} is not supported`)}}),"createOwnerSigner");function We(r){return r&&typeof r.request=="function"}function be(r){return r&&r.type==="VIEM_ACCOUNT"}var Qt=require("@zerodev/ecdsa-validator"),te=require("@zerodev/sdk");var mt=class{get(u,p){return i(this,arguments,function*({chain:t,publicClient:e,entryPoint:n,walletParams:a,kernelVersion:o,user:s},l){let m=yield Zt({chain:t,walletParams:a});if(l!=null&&!Q(m.address,l.eoaAddress))throw new h(`User '${s.id}' has an existing wallet with an eoa signer '${l.eoaAddress}', this does not match input eoa signer '${m.address}'.`,l,{type:"eoa",eoaAddress:l.eoaAddress});let f=yield(0,Qt.signerToEcdsaValidator)(e,{signer:m,entryPoint:n.address,kernelVersion:o});return{account:yield(0,te.createKernelAccount)(e,{plugins:{sudo:f},index:BigInt(0),entryPoint:n.address,kernelVersion:o}),signerData:{eoaAddress:m.address,type:"eoa"}}})}};var J=require("@zerodev/passkey-validator"),ee=require("@zerodev/sdk"),re=require("@zerodev/webauthn-key");function ne(r){return r.walletParams.signer.type==="PASSKEY"}var dt=class{constructor(t){this.crossmintService=t}get(l,u){return i(this,arguments,function*({user:t,publicClient:e,walletParams:n,entryPoint:a,kernelVersion:o},s){var m;let p=(m=n.signer.passkeyName)!=null?m:t.id;if(s!=null&&s.passkeyName!==p)throw new D(`User '${t.id}' has an existing wallet created with a passkey named '${s.passkeyName}', this does match input passkey name '${p}'.`,ct(s));try{let f=yield this.getPasskey(t,p,s),j=J.PasskeyValidatorContractVersion.V0_0_2,z=s==null?j:s.validatorContractVersion,Wt=yield(0,J.toPasskeyValidator)(e,{webAuthnKey:f,entryPoint:a.address,validatorContractVersion:z,kernelVersion:o}),de=yield(0,ee.createKernelAccount)(e,{plugins:{sudo:Wt},entryPoint:a.address,kernelVersion:o});return{signerData:this.getSignerData(Wt,z,p),account:this.decorate(de,p)}}catch(f){throw this.mapError(f,p)}})}getPasskey(t,e,n){return i(this,null,function*(){return n!=null?{pubX:BigInt(n.pubKeyX),pubY:BigInt(n.pubKeyY),authenticatorId:n.authenticatorId,authenticatorIdHash:n.authenticatorIdHash}:(0,re.toWebAuthnKey)({passkeyName:e,passkeyServerUrl:this.crossmintService.getPasskeyServerUrl(),mode:J.WebAuthnMode.Register,passkeyServerHeaders:this.createPasskeysServerHeaders(t)})})}getSignerData(t,e,n){return S(d({},xe(t.getSerializedData())),{passkeyName:n,validatorContractVersion:e,domain:window.location.hostname,type:"passkeys"})}createPasskeysServerHeaders(t){return{"x-api-key":this.crossmintService.crossmintAPIHeaders["x-api-key"],Authorization:`Bearer ${t.jwt}`}}mapError(t,e){return t.code===0&&t.name==="DataError"?new L(e):t.message==="Registration not verified"?new M(e):t.code==="ERROR_PASSTHROUGH_SEE_CAUSE_PROPERTY"&&t.name==="NotAllowedError"?new V(e):t}decorate(t,e){return new Proxy(t,{get:(n,a,o)=>{let s=Reflect.get(n,a,o);return typeof s!="function"||typeof a!="string"||!ve(a)?s:(...l)=>i(this,null,function*(){try{return yield s.call(n,...l)}catch(u){throw this.mapError(u,e)}})}})}},De=["signMessage","signTypedData","signUserOperation","signTransaction"];function ve(r){return De.includes(r)}var xe=r=>{let t=ke(r),e=new TextDecoder().decode(t);return JSON.parse(e)};function ke(r){let t=atob(r);return Uint8Array.from(t,e=>e.codePointAt(0))}var ae=require("@zerodev/sdk"),oe=require("viem");function se(r){return!it(r)}var Ne=r=>Kt+Ct[r];function ie({entryPoint:r,chain:t}){return{middleware:{sponsorUserOperation:n=>i(this,[n],function*({userOperation:e}){return(0,ae.createZeroDevPaymasterClient)({chain:pt[t],transport:(0,oe.http)(Ne(t)),entryPoint:r}).sponsorUserOperation({userOperation:e,entryPoint:r})})}}}var ut=class{constructor(t,e,n=new Ot(new mt,new dt(t))){this.crossmintWalletService=t;this.clientDecorator=e;this.accountFactory=n}getOrCreate(t,e,n){return i(this,null,function*(){let{entryPoint:a,kernelVersion:o,existingSignerConfig:s,smartContractWalletAddress:l,userId:u}=yield this.fetchConfig(t,e),p=(0,O.createPublicClient)({transport:(0,O.http)(_t(e))}),{account:m,signerData:f}=yield this.accountFactory.get({chain:e,walletParams:n,publicClient:p,user:S(d({},t),{id:u}),entryPoint:a,kernelVersion:o},s);if(l!=null&&!Q(l,m.address))throw new A(u);s==null&&(yield this.crossmintWalletService.idempotentCreateSmartWallet(t,{type:xt,smartContractWalletAddress:m.address,signerData:f,version:0,baseLayer:"evm",chainId:(0,ce.blockchainToChainId)(e),entryPointVersion:a.version,kernelVersion:o}));let j=(0,le.createKernelAccountClient)(d({account:m,chain:pt[e],entryPoint:m.entryPoint,bundlerTransport:(0,O.http)(_t(e))},se(e)&&ie({entryPoint:m.entryPoint,chain:e}))),z=this.clientDecorator.decorate({crossmintChain:e,smartAccountClient:j});return new F(this.crossmintWalletService,z,p,e)})}fetchConfig(t,e){return i(this,null,function*(){let{entryPointVersion:n,kernelVersion:a,signers:o,smartContractWalletAddress:s,userId:l}=yield this.crossmintWalletService.getSmartWalletConfig(t,e);if(!Ht(a))throw new c(`Unsupported kernel version. Supported versions: ${wt.join(", ")}. Version used: ${a}, Please contact support`);if(!jt(n))throw new c(`Unsupported entry point version. Supported versions: ${It.join(", ")}. Version used: ${n}. Please contact support`);if(n==="v0.7"&&a.startsWith("0.2")||n==="v0.6"&&a.startsWith("0.3"))throw new c(`Unsupported combination: entryPoint ${n} and kernel version ${a}. Please contact support`);return{entryPoint:{version:n,address:n==="v0.6"?yt.ENTRYPOINT_ADDRESS_V06:yt.ENTRYPOINT_ADDRESS_V07},kernelVersion:a,userId:l,existingSignerConfig:this.getSigner(o),smartContractWalletAddress:s!=null?(0,O.getAddress)(s):void 0}})}getSigner(t){if(t.length!==0){if(t.length>1)throw new E("Invalid wallet signer configuration. Please contact support");return t[0].signerData}}},Ot=class{constructor(t,e){this.eoa=t;this.passkey=e}get(t,e){if(ne(t)){if(e!=null&&(e==null?void 0:e.type)!=="passkeys")throw new h(`Cannot create wallet with passkey signer for user '${t.user.id}', they have an existing wallet with eoa signer '${e.eoaAddress}.'`,e);return this.passkey.get(t,e)}if(e!=null&&(e==null?void 0:e.type)!=="eoa")throw new h(`Cannot create wallet with eoa signer for user '${t.user.id}', they already have a wallet with a passkey named '${e.passkeyName}' as it's signer.`,ct(e));return this.eoa.get(t,e)}};var Et=require("viem");var ft=class{constructor(t){this.logger=t}map(t,e){return this.record(t),t instanceof c||t instanceof Et.BaseError?t:e}record(t){let e=t instanceof Error?t.message:String(t);this.logger.logError(`Smart Wallet SDK Error: ${e}`,{stack:t instanceof Error?t.stack:void 0,name:t instanceof Error?t.name:"UnknownError",details:(0,Et.stringify)(t),domain:window.location.hostname,sdk_version:Lt})}};var St=class r extends w{constructor(e,n){super("SmartWalletSDK");this.smartWalletService=e;this.errorProcessor=n}static init({clientApiKey:e}){if(!X())throw new c("Smart Wallet SDK should only be used client side.");if(!(0,me.validateAPIKey)(e).isValid)throw new Error("API key invalid");let a=new st(e),o=new ft(new W);return new r(new ut(a,new lt(o)),o)}getOrCreateWallet(o,s){return i(this,arguments,function*(e,n,a={signer:{type:"PASSKEY"}}){return _("GET_OR_CREATE_WALLET",()=>i(this,null,function*(){try{return yield this.smartWalletService.getOrCreate(e,n,a)}catch(l){throw this.errorProcessor.map(l,new c(`Wallet creation failed: ${l.message}.`,(0,pe.stringify)(l)))}}),{user:e,chain:n})})}};0&&(module.exports={AdminAlreadyUsedError,AdminMismatchError,Chain,ConfigError,CrossmintServiceError,EVMSmartWallet,JWTDecryptionError,JWTExpiredError,JWTIdentifierError,JWTInvalidError,NonCustodialWalletsNotEnabledError,NotAuthorizedError,OutOfCreditsError,PasskeyIncompatibleAuthenticatorError,PasskeyMismatchError,PasskeyPromptError,PasskeyRegistrationError,SmartWalletSDK,SmartWalletSDKError,TransferError,UserWalletAlreadyCreatedError,blockchainToChainId});
|
|
1
|
+
"use strict";var me=Object.defineProperty;var nt=Object.getOwnPropertyDescriptor;var at=Object.getOwnPropertyNames;var ot=Object.prototype.hasOwnProperty;var st=(r,e)=>{for(var t in e)me(r,t,{get:e[t],enumerable:!0})},it=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let a of at(e))!ot.call(r,a)&&a!==t&&me(r,a,{get:()=>e[a],enumerable:!(n=nt(e,a))||n.enumerable});return r};var lt=r=>it(me({},"__esModule",{value:!0}),r);var Wt={};st(Wt,{AdminAlreadyUsedError:()=>x,AdminMismatchError:()=>P,Chain:()=>ce.EVMBlockchainIncludingTestnet,ConfigError:()=>C,CrossmintSDKError:()=>m.CrossmintSDKError,CrossmintServiceError:()=>m.CrossmintServiceError,EVMSmartWallet:()=>b,JWTDecryptionError:()=>m.JWTDecryptionError,JWTExpiredError:()=>m.JWTExpiredError,JWTIdentifierError:()=>m.JWTIdentifierError,JWTInvalidError:()=>m.JWTInvalidError,NotAuthorizedError:()=>m.NotAuthorizedError,PasskeyIncompatibleAuthenticatorError:()=>v,PasskeyMismatchError:()=>R,PasskeyPromptError:()=>I,PasskeyRegistrationError:()=>O,SmartWalletError:()=>l,SmartWalletErrorCode:()=>m.SmartWalletErrorCode,SmartWalletSDK:()=>le,SmartWalletsNotEnabledError:()=>W,TransferError:()=>m.TransferError,UserWalletAlreadyCreatedError:()=>h,blockchainToChainId:()=>ce.blockchainToChainId});module.exports=lt(Wt);var ce=require("@crossmint/common-sdk-base");var N=require("viem"),ve=require("@crossmint/client-sdk-base");function L(){return typeof window<"u"}function Ee(){return process.env.NODE_ENV==="test"?!1:window.location.origin.includes("localhost")}function $(r,e){return r?.toLowerCase()===e?.toLowerCase()}var K=class{logInfo(e,t){console.log(e,t)}logError(e,t){console.error(e,t)}logWarn(e,t){console.warn(e,t)}};var F=require("@datadog/browser-logs");var Pe="ZeroDev";var he="pub035be8a594b35be1887b6ba76c4029ca",Ce="http://localhost:3000/api",Te="https://staging.crossmint.com/api",Ae="https://www.crossmint.com/api",T="SCW_SDK",we="0.1.0",B="2024-06-09",be="https://rpc.zerodev.app/api/v2/bundler/";var de=["0.3.1","0.3.0","0.2.4"],ue=["v0.6","v0.7"];var A=class{logInfo(e,t){ye(e,"info",t)}logError(e,t){ye(e,"error",t)}logWarn(e,t){ye(e,"warn",t)}};function ye(r,e,t){let n=t?{...t,service:T}:{service:T};ct(),F.datadogLogs.logger[e](r,n)}function ct(){F.datadogLogs.getInternalContext()==null&&F.datadogLogs.init({clientToken:he,site:"datadoghq.com",forwardErrorsToLogs:!1,sampleRate:100})}function pt(){return L()&&Ee()?new K:new A}var{logInfo:w,logWarn:Ft,logError:Y}=pt();async function E(r,e,t){let n=new Date().getTime(),a=await e(),o={durationInMs:new Date().getTime()-n,...t};return w(`[${T} - ${r} - TIME] - ${mt(o)}`,{args:o}),a}function mt(r){try{return r!=null?JSON.stringify(r,null,2):r}catch{return dt(r)}}function dt(r){let e={};for(let t in r)Object.prototype.hasOwnProperty.call(r,t)&&typeof r[t]!="object"&&typeof r[t]!="function"&&(e[t]=r[t]);return JSON.stringify(e,null,2)}function Re(r){let e=r instanceof Error?r:{message:"Unknown error",name:"Unknown error"};if(!(e instanceof Error)&&e.constructor?.name!=="SyntheticBaseEvent")throw Y("ERROR_TO_JSON_FAILED",{error:e}),new Error("[errorToJSON] err is not instanceof Error nor SyntheticBaseEvent");return JSON.parse(JSON.stringify(e,Object.getOwnPropertyNames(e)))}var j=require("viem");var Ie=[{inputs:[{internalType:"string",name:"uri_",type:"string"}],stateMutability:"nonpayable",type:"constructor"},{anonymous:!1,inputs:[{indexed:!0,internalType:"address",name:"account",type:"address"},{indexed:!0,internalType:"address",name:"operator",type:"address"},{indexed:!1,internalType:"bool",name:"approved",type:"bool"}],name:"ApprovalForAll",type:"event"},{anonymous:!1,inputs:[{indexed:!0,internalType:"address",name:"operator",type:"address"},{indexed:!0,internalType:"address",name:"from",type:"address"},{indexed:!0,internalType:"address",name:"to",type:"address"},{indexed:!1,internalType:"uint256[]",name:"ids",type:"uint256[]"},{indexed:!1,internalType:"uint256[]",name:"values",type:"uint256[]"}],name:"TransferBatch",type:"event"},{anonymous:!1,inputs:[{indexed:!0,internalType:"address",name:"operator",type:"address"},{indexed:!0,internalType:"address",name:"from",type:"address"},{indexed:!0,internalType:"address",name:"to",type:"address"},{indexed:!1,internalType:"uint256",name:"id",type:"uint256"},{indexed:!1,internalType:"uint256",name:"value",type:"uint256"}],name:"TransferSingle",type:"event"},{anonymous:!1,inputs:[{indexed:!1,internalType:"string",name:"value",type:"string"},{indexed:!0,internalType:"uint256",name:"id",type:"uint256"}],name:"URI",type:"event"},{inputs:[{internalType:"address",name:"account",type:"address"},{internalType:"uint256",name:"id",type:"uint256"}],name:"balanceOf",outputs:[{internalType:"uint256",name:"",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"address[]",name:"accounts",type:"address[]"},{internalType:"uint256[]",name:"ids",type:"uint256[]"}],name:"balanceOfBatch",outputs:[{internalType:"uint256[]",name:"",type:"uint256[]"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"address",name:"account",type:"address"},{internalType:"address",name:"operator",type:"address"}],name:"isApprovedForAll",outputs:[{internalType:"bool",name:"",type:"bool"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"address",name:"from",type:"address"},{internalType:"address",name:"to",type:"address"},{internalType:"uint256[]",name:"ids",type:"uint256[]"},{internalType:"uint256[]",name:"amounts",type:"uint256[]"},{internalType:"bytes",name:"data",type:"bytes"}],name:"safeBatchTransferFrom",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"address",name:"from",type:"address"},{internalType:"address",name:"to",type:"address"},{internalType:"uint256",name:"id",type:"uint256"},{internalType:"uint256",name:"amount",type:"uint256"},{internalType:"bytes",name:"data",type:"bytes"}],name:"safeTransferFrom",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"address",name:"operator",type:"address"},{internalType:"bool",name:"approved",type:"bool"}],name:"setApprovalForAll",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"bytes4",name:"interfaceId",type:"bytes4"}],name:"supportsInterface",outputs:[{internalType:"bool",name:"",type:"bool"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"uint256",name:"",type:"uint256"}],name:"uri",outputs:[{internalType:"string",name:"",type:"string"}],stateMutability:"view",type:"function"}];function Oe({contract:r,config:e,from:t,to:n}){switch(e.token.type){case"ft":return{account:t,address:r,abi:j.erc20Abi,functionName:"transfer",args:[n,e.amount]};case"sft":return{account:t,address:r,abi:Ie,functionName:"safeTransferFrom",args:[t.address,n,e.token.tokenId,e.quantity,"0x00"],tokenId:e.token.tokenId};case"nft":return{account:t,address:r,abi:j.erc721Abi,functionName:"safeTransferFrom",args:[t.address,n,e.token.tokenId],tokenId:e.token.tokenId}}}var b=class{constructor(e,t,n,a){this.crossmintService=e;this.accountClient=t;this.chain=a,this.client={wallet:t,public:n}}get address(){return this.accountClient.account.address}async transferToken(e,t){return E("TRANSFER",async()=>{if(this.chain!==t.token.chain)throw new Error(`Chain mismatch: Expected ${t.token.chain}, but got ${this.chain}. Ensure you are interacting with the correct blockchain.`);if(!(0,N.isAddress)(e))throw new Error(`Invalid recipient address: '${e}' is not a valid EVM address.`);if(!(0,N.isAddress)(t.token.contractAddress))throw new Error(`Invalid contract address: '${t.token.contractAddress}' is not a valid EVM address.`);let n=Oe({contract:t.token.contractAddress,to:e,from:this.accountClient.account,config:t});try{let a=this.accountClient.extend(N.publicActions),{request:s}=await a.simulateContract(n),o=await a.writeContract(s);return w(`[TRANSFER] - Transaction hash from transfer: ${o}`),o}catch(a){Y("[TRANSFER] - ERROR_TRANSFERRING_TOKEN",{service:T,error:Re(a),tokenId:n.tokenId,contractAddress:t.token.contractAddress,chain:t.token.chain});let s=n.tokenId==null?"":`:${n.tokenId}}`;throw new ve.TransferError(`Error transferring token ${t.token.contractAddress}${s}`)}},{toAddress:e,config:t})}async nfts(){return this.crossmintService.fetchNFTs(this.address,this.chain)}};var y=require("@crossmint/client-sdk-base"),l=class extends y.CrossmintSDKError{constructor(e,t,n=y.SmartWalletErrorCode.UNCATEGORIZED){super(e,n,t)}},P=class extends l{constructor(e,t,n){super(e,y.SmartWalletErrorCode.ADMIN_MISMATCH),this.required=t,this.used=n}},R=class extends l{constructor(e,t,n){super(e,y.SmartWalletErrorCode.PASSKEY_MISMATCH),this.required=t,this.used=n}},h=class extends l{constructor(t){super(`The user with userId ${t.toString()} already has a wallet created for this project`);this.code=y.SmartWalletErrorCode.USER_WALLET_ALREADY_CREATED}},I=class extends l{constructor(e){super(`Prompt was either cancelled or timed out for passkey ${e}`,void 0,y.SmartWalletErrorCode.PASSKEY_PROMPT),this.passkeyName=e}},O=class extends l{constructor(e){super(`Registration for passkey ${e} failed, either the registration took too long, or passkey signature vaildation failed.`,void 0,y.SmartWalletErrorCode.PASSKEY_REGISTRATION),this.passkeyName=e}},v=class extends l{constructor(e){super(`User selected authenticator for passkey ${e} is not compatible with Crossmint's Smart Wallets.`,void 0,y.SmartWalletErrorCode.PASSKEY_INCOMPATIBLE_AUTHENTICATOR),this.passkeyName=e}},C=class extends l{constructor(e){super(e,void 0,y.SmartWalletErrorCode.WALLET_CONFIG)}},x=class extends C{constructor(){super("This signer was already used to create another wallet. Please use a different signer.");this.code=y.SmartWalletErrorCode.ADMIN_SIGNER_ALREADY_USED}},W=class extends C{constructor(){super("Smart wallets are not enabled for this project. They can be enabled on the project settings page in the developer console.");this.code=y.SmartWalletErrorCode.SMART_WALLETS_NOT_ENABLED}};var m=require("@crossmint/client-sdk-base");var et=require("viem"),tt=require("@crossmint/common-sdk-base");var Ue=require("@crossmint/client-sdk-base"),Ve=require("@crossmint/common-sdk-base");var xe=require("@crossmint/client-sdk-base"),We=require("@crossmint/common-sdk-base");var u=require("@crossmint/client-sdk-base");var G=class{constructor(e={ERROR_JWT_INVALID:()=>new u.JWTInvalidError,ERROR_JWT_DECRYPTION:()=>new u.JWTDecryptionError,ERROR_JWT_EXPIRED:({expiredAt:t})=>new u.JWTExpiredError(new Date(t)),ERROR_JWT_IDENTIFIER:({identifierKey:t})=>new u.JWTIdentifierError(t),ERROR_USER_WALLET_ALREADY_CREATED:({userId:t})=>new h(t),ERROR_ADMIN_SIGNER_ALREADY_USED:()=>new x,ERROR_PROJECT_NONCUSTODIAL_WALLETS_NOT_ENABLED:()=>new W}){this.errors=e}async throwErrorFromResponse({response:e,onServerErrorMessage:t}){if(!e.ok){if(e.status>=500)throw new u.CrossmintServiceError(t,e.status);if(e.status===402)throw new u.OutOfCreditsError;try{let n=await e.json(),a=n.code;if(a!=null&&this.errors[a]!=null)throw this.errors[a](n);if(n.message!=null)throw new u.CrossmintServiceError(n.message,e.status)}catch(n){if(n instanceof l)throw n;console.error("Error parsing response",n)}throw new u.CrossmintServiceError(await e.text(),e.status)}}};var M=class M{constructor(e){let t=(0,We.validateAPIKey)(e);if(!t.isValid)throw new Error("API key invalid");this.crossmintAPIHeaders={accept:"application/json","content-type":"application/json","x-api-key":e},this.crossmintBaseUrl=this.getUrlFromEnv(t.environment),this.apiErrorService=new G}async fetchCrossmintAPI(e,t={method:"GET"},n,a){return E("FETCH_CROSSMINT_API",async()=>{let s=`${this.crossmintBaseUrl}/${e}`,{body:o,method:i}=t,c;try{c=await fetch(s,{body:o,method:i,headers:{...this.crossmintAPIHeaders,...a!=null&&{Authorization:`Bearer ${a}`}}})}catch(S){throw new xe.CrossmintServiceError(`Error fetching Crossmint API: ${S}`)}return c.ok||await this.apiErrorService.throwErrorFromResponse({response:c,onServerErrorMessage:n}),await c.json()},{endpoint:e})}getUrlFromEnv(e){let t=M.urlMap[e];if(!t)throw console.log(" CrossmintService.urlMap: ",M.urlMap),new Error(`URL not found for environment: ${e}`);return t}};M.urlMap={development:Ce,staging:Te,production:Ae};var J=M;var ke=require("@zerodev/passkey-validator"),z=require("viem"),p=require("zod");var yt=p.z.custom(r=>(0,z.isHex)(r),{message:"Invalid hex string"}),H=p.z.custom(r=>(0,z.isAddress)(r),{message:"Invalid evm address"}),ft=p.z.object({eoaAddress:H,type:p.z.literal("eoa")}),gt=p.z.object({entryPoint:H,validatorAddress:H,pubKeyX:p.z.string(),pubKeyY:p.z.string(),authenticatorIdHash:yt,authenticatorId:p.z.string()}),St=gt.extend({passkeyName:p.z.string(),validatorContractVersion:p.z.nativeEnum(ke.PasskeyValidatorContractVersion),domain:p.z.string(),type:p.z.literal("passkeys")}),Et=p.z.discriminatedUnion("type",[St,ft]),_e=p.z.object({kernelVersion:p.z.enum(de,{errorMap:(r,e)=>({message:`Unsupported kernel version. Supported versions: ${de.join(", ")}. Version used: ${e.data}. Please contact support`})}),entryPointVersion:p.z.enum(ue,{errorMap:(r,e)=>({message:`Unsupported entry point version. Supported versions: ${ue.join(", ")}. Version used: ${e.data}. Please contact support`})}),userId:p.z.string().min(1),signers:p.z.array(p.z.object({signerData:Et})).min(0).max(1,"Invalid wallet signer configuration. Please contact support"),smartContractWalletAddress:H.optional()});var De=require("viem");function q(r,e){let t=e(r);return t.replace?t.value:Array.isArray(r)?r.map(n=>q(n,e)):r!==null&&typeof r=="object"?Object.fromEntries(Object.entries(r).map(([n,a])=>[n,q(a,e)])):t.value}function Ne(r){return q(r,e=>typeof e=="bigint"?{value:(0,De.toHex)(e),replace:!0}:{value:e,replace:!1})}function Me(r){return q(r,e=>e!=null&&typeof e=="object"&&"__xm_serializedType"in e&&"value"in e&&e.__xm_serializedType==="bigint"&&typeof e.value=="string"?{value:BigInt(e.value),replace:!0}:{value:e,replace:!1})}var X=class extends J{async idempotentCreateSmartWallet(e,t){await this.fetchCrossmintAPI(`${B}/sdk/smart-wallet`,{method:"PUT",body:JSON.stringify(t)},"Error creating abstract wallet. Please contact support",e.jwt)}async sponsorUserOperation(e,t,n,a){let s=(0,Ve.blockchainToChainId)(a),o=await this.fetchCrossmintAPI(`${B}/sdk/paymaster`,{method:"POST",body:JSON.stringify({userOp:Ne(t),entryPoint:n,chainId:s})},"Error sponsoring user operation. Please contact support",e.jwt);return Me(o)}async getSmartWalletConfig(e,t){let n=await this.fetchCrossmintAPI(`${B}/sdk/smart-wallet/config?chain=${t}`,{method:"GET"},"Error getting smart wallet version configuration. Please contact support",e.jwt),a=_e.safeParse(n);if(a.success)return a.data;throw new Ue.CrossmintServiceError(`Invalid smart wallet config, please contact support. Details below:
|
|
2
|
+
${a.error.toString()}`)}async fetchNFTs(e,t){return this.fetchCrossmintAPI(`v1-alpha1/wallets/${t}:${e}/nfts`,{method:"GET"},`Error fetching NFTs for wallet: ${e}`)}getPasskeyServerUrl(){return this.crossmintBaseUrl+"/internal/passkeys"}};var k=class{constructor(e){this.type="passkeys";this.data=e}display(){return{pubKeyX:this.data.pubKeyX,pubKeyY:this.data.pubKeyY,passkeyName:this.data.passkeyName,type:this.type}}},_=class{constructor(e){this.type="eoa";this.data=e}display(){return this.data}};var Z=class{constructor(e){this.crossmintService=e}async get(e,t){let{entryPointVersion:n,kernelVersion:a,signers:s,smartContractWalletAddress:o,userId:i}=await this.crossmintService.getSmartWalletConfig(e,t);if(n==="v0.7"&&a.startsWith("0.2")||n==="v0.6"&&a.startsWith("0.3"))throw new l(`Unsupported combination: entryPoint ${n} and kernel version ${a}. Please contact support`);return{entryPointVersion:n,kernelVersion:a,userId:i,existingSignerConfig:this.getSigner(s.map(c=>c.signerData)),smartContractWalletAddress:o}}getSigner(e){if(e.length===0)return;let t=e[0];if(t.type==="eoa")return new _(t);if(t.type==="passkeys")return new k(t)}};function Le(r){let e="signer"in r.walletParams&&"type"in r.walletParams.signer&&r.walletParams.signer.type==="PASSKEY",t=r.existingSignerConfig==null||r.existingSignerConfig.type==="passkeys";return e&&t}function $e(r){let e="signer"in r.walletParams&&("type"in r.walletParams.signer&&r.walletParams.signer.type==="VIEM_ACCOUNT"||"request"in r.walletParams.signer&&typeof r.walletParams.signer.request=="function"),t=r.existingSignerConfig==null||r.existingSignerConfig.type==="eoa";return e&&t}var Q=class{constructor(e,t){this.eoaStrategy=e;this.passkeyStrategy=t}get(e){if(Le(e))return this.passkeyStrategy.create(e);if($e(e))return this.eoaStrategy.create(e);if(e.existingSignerConfig==null)throw new C(`Unsupported wallet params:
|
|
3
|
+
${e.walletParams}`);let t=e.existingSignerConfig.display();throw new P(`Cannot create wallet with ${e.existingSignerConfig.type} signer for user ${e.user.id}', they already have a wallet with signer:
|
|
4
|
+
'${t}'`,t)}};var Fe=require("@zerodev/ecdsa-validator"),Ye=require("@zerodev/sdk");var Ke=require("permissionless");async function Be({walletParams:r}){if(Pt(r.signer))return await(0,Ke.providerToSmartAccountSigner)(r.signer);if(ht(r.signer))return r.signer.account;{let e=r.signer;throw new l(`The signer type ${e.type} is not supported`)}}function Pt(r){return r&&typeof r.request=="function"}function ht(r){return r&&r.type==="VIEM_ACCOUNT"}var ee=class{async create({chain:e,publicClient:t,entryPoint:n,walletParams:a,kernelVersion:s,user:o,existingSignerConfig:i}){let c=await Be({chain:e,walletParams:a});if(i!=null&&!$(c.address,i.data.eoaAddress))throw new P(`User '${o.id}' has an existing wallet with an eoa signer '${i.data.eoaAddress}', this does not match input eoa signer '${c.address}'.`,i.display(),{type:"eoa",eoaAddress:i.data.eoaAddress});let S=await(0,Fe.signerToEcdsaValidator)(t,{signer:c,entryPoint:n.address,kernelVersion:s});return{account:await(0,Ye.createKernelAccount)(t,{plugins:{sudo:S},index:0n,entryPoint:n.address,kernelVersion:s}),signerConfig:new _({eoaAddress:c.address,type:"eoa"})}}};var D=require("@zerodev/passkey-validator"),je=require("@zerodev/sdk"),Ge=require("@zerodev/webauthn-key");var te=class{constructor(e,t){this.passkeyServerUrl=e;this.apiKey=t}async create({user:e,publicClient:t,walletParams:n,entryPoint:a,kernelVersion:s,existingSignerConfig:o}){let i=n.signer.passkeyName??e.id;if(o!=null&&o.data.passkeyName!==i)throw new R(`User '${e.id}' has an existing wallet created with a passkey named '${o.data.passkeyName}', this does match input passkey name '${i}'.`,o.display());try{let c=await this.getPasskey(e,i,o?.data),S=D.PasskeyValidatorContractVersion.V0_0_2,g=o==null?S:o.data.validatorContractVersion,V=await(0,D.toPasskeyValidator)(t,{webAuthnKey:c,entryPoint:a.address,validatorContractVersion:g,kernelVersion:s}),pe=await(0,je.createKernelAccount)(t,{plugins:{sudo:V},entryPoint:a.address,kernelVersion:s});return{signerConfig:this.getSignerConfig(V,g,i),account:this.decorate(pe,i)}}catch(c){throw this.mapError(c,i)}}async getPasskey(e,t,n){return n!=null?{pubX:BigInt(n.pubKeyX),pubY:BigInt(n.pubKeyY),authenticatorId:n.authenticatorId,authenticatorIdHash:n.authenticatorIdHash}:(0,Ge.toWebAuthnKey)({passkeyName:t,passkeyServerUrl:this.passkeyServerUrl,mode:D.WebAuthnMode.Register,passkeyServerHeaders:this.createPasskeysServerHeaders(e)})}getSignerConfig(e,t,n){return new k({...At(e.getSerializedData()),passkeyName:n,validatorContractVersion:t,domain:window.location.hostname,type:"passkeys"})}createPasskeysServerHeaders(e){return{"x-api-key":this.apiKey,Authorization:`Bearer ${e.jwt}`}}mapError(e,t){return e.code===0&&e.name==="DataError"?new v(t):e.message==="Registration not verified"?new O(t):e.code==="ERROR_PASSTHROUGH_SEE_CAUSE_PROPERTY"&&e.name==="NotAllowedError"?new I(t):e}decorate(e,t){return new Proxy(e,{get:(n,a,s)=>{let o=Reflect.get(n,a,s);return typeof o!="function"||typeof a!="string"||!Tt(a)?o:async(...i)=>{try{return await o.call(n,...i)}catch(c){throw this.mapError(c,t)}}}})}},Ct=["signMessage","signTypedData","signUserOperation","signTransaction"];function Tt(r){return Ct.includes(r)}var At=r=>{let e=wt(r),t=new TextDecoder().decode(e);return JSON.parse(t)};function wt(r){let e=atob(r);return Uint8Array.from(e,t=>t.codePointAt(0))}var ge=require("viem");function re(r){return!1}var bt=["sendTransaction","writeContract","sendUserOperation"],Rt=["signMessage","signTypedData"];function fe(r){return bt.includes(r)}function It(r){return Rt.includes(r)}var ne=class{constructor(e){this.errorProcessor=e}decorate({crossmintChain:e,smartAccountClient:t}){return new Proxy(t,{get:(n,a,s)=>{let o=Reflect.get(n,a,s);return typeof o!="function"||typeof a!="string"||!(It(a)||fe(a))?o:(...i)=>E(`CrossmintSmartWallet.${a}`,()=>this.execute(n,a,o,i,e))}})}async execute(e,t,n,a,s){try{w(`[CrossmintSmartWallet.${t}] - params: ${(0,ge.stringify)(a)}`);let o=fe(t)?this.processTxnArgs(t,s,a):a;return await n.call(e,...o)}catch(o){let i=fe(t)?"signing":"sending transaction";throw this.errorProcessor.map(o,new l(`Error ${i}: ${o.message}`,(0,ge.stringify)(o)))}}processTxnArgs(e,t,n){if(e==="sendUserOperation"){let[{userOperation:s,middleware:o,account:i}]=n;return[{middleware:o,account:i,userOperation:this.addGelatoBundlerProperties(t,s)},...n.slice(1)]}let[a]=n;return[this.addGelatoBundlerProperties(t,a),...n.slice(1)]}addGelatoBundlerProperties(e,t){return re(e)?{...t,maxFeePerGas:"0x0",maxPriorityFeePerGas:"0x0"}:t}};var Ze=require("@zerodev/sdk"),oe=require("permissionless"),U=require("viem"),Qe=require("@crossmint/common-sdk-base");var d=require("viem/chains"),f=require("@crossmint/common-sdk-base");var Je={BASE_SEPOLIA:f.BlockchainIncludingTestnet.BASE_SEPOLIA,POLYGON_AMOY:f.BlockchainIncludingTestnet.POLYGON_AMOY,OPTIMISM_SEPOLIA:f.BlockchainIncludingTestnet.OPTIMISM_SEPOLIA,ARBITRUM_SEPOLIA:f.BlockchainIncludingTestnet.ARBITRUM_SEPOLIA},Hr=(0,f.objectValues)(Je),He={BASE:f.BlockchainIncludingTestnet.BASE,POLYGON:f.BlockchainIncludingTestnet.POLYGON,OPTIMISM:f.BlockchainIncludingTestnet.OPTIMISM,ARBITRUM:f.BlockchainIncludingTestnet.ARBITRUM},zr=(0,f.objectValues)(He),Ot={...Je,...He},qr=(0,f.objectValues)(Ot),vt={polygon:"5c9f4865-ca8e-44bb-9b9e-3810b2b46f9f","polygon-amoy":"3deef404-ca06-4a5d-9a58-907c99e7ef00","base-sepolia":"5a127978-6473-4784-9dfb-f74395b220a6",base:"e8b3020f-4dde-4176-8a7d-be8102527a5c","optimism-sepolia":"f8dd488e-eaed-467d-a5de-0184c160f3b1",optimism:"505950ab-ee07-4a9c-bd16-320ac71a9350",arbitrum:"a965100f-fedf-4e6b-a207-20f5687fcc4f","arbitrum-sepolia":"76c860ca-af77-4fb1-8eac-07825952f6f4"},ze={polygon:d.polygon,"polygon-amoy":d.polygonAmoy,base:d.base,"base-sepolia":d.baseSepolia,optimism:d.optimism,"optimism-sepolia":d.optimismSepolia,arbitrum:d.arbitrum,"arbitrum-sepolia":d.arbitrumSepolia},Se=r=>be+vt[r];function qe(r){return!re(r)}function Xe({entryPoint:r,chain:e,walletService:t,user:n}){return{middleware:{sponsorUserOperation:async({userOperation:a})=>{let{sponsorUserOpParams:s}=await t.sponsorUserOperation(n,a,r,e);return s}}}}var ae=class{constructor(e,t,n,a){this.crossmintService=e;this.accountConfigFacade=t;this.accountCreator=n;this.clientDecorator=a}async getOrCreate(e,t,n){let{entryPointVersion:a,kernelVersion:s,existingSignerConfig:o,smartContractWalletAddress:i,userId:c}=await this.accountConfigFacade.get(e,t),S=(0,U.createPublicClient)({transport:(0,U.http)(Se(t))}),{account:g,signerConfig:V}=await this.accountCreator.get({chain:t,walletParams:n,publicClient:S,user:{...e,id:c},entryPoint:{version:a,address:a==="v0.6"?oe.ENTRYPOINT_ADDRESS_V06:oe.ENTRYPOINT_ADDRESS_V07},kernelVersion:s,existingSignerConfig:o});if(i!=null&&!$(i,g.address))throw new h(c);o==null&&await this.crossmintService.idempotentCreateSmartWallet(e,{type:Pe,smartContractWalletAddress:g.address,signerData:V.data,version:0,baseLayer:"evm",chainId:(0,Qe.blockchainToChainId)(t),entryPointVersion:a,kernelVersion:s});let pe=(0,Ze.createKernelAccountClient)({account:g,chain:ze[t],entryPoint:g.entryPoint,bundlerTransport:(0,U.http)(Se(t)),...qe(t)&&Xe({entryPoint:g.entryPoint,chain:t,walletService:this.crossmintService,user:e})}),rt=this.clientDecorator.decorate({crossmintChain:t,smartAccountClient:pe});return new b(this.crossmintService,rt,S,t)}};var ie=require("viem");var se=class{constructor(e){this.logger=e}map(e,t){return this.record(e),e instanceof l||e instanceof ie.BaseError?e:t}record(e){let t=e instanceof Error?e.message:String(e);this.logger.logError(`Smart Wallet SDK Error: ${t}`,{stack:e instanceof Error?e.stack:void 0,name:e instanceof Error?e.name:"UnknownError",details:(0,ie.stringify)(e),domain:window.location.hostname,sdk_version:we})}};var le=class r{constructor(e,t){this.smartWalletService=e;this.errorProcessor=t}static init({clientApiKey:e}){if(!L())throw new l("Smart Wallet SDK should only be used client side.");if(!(0,tt.validateAPIKey)(e).isValid)throw new Error("API key invalid");let n=new X(e),a=new se(new A),s=new Q(new ee,new te(n.getPasskeyServerUrl(),e)),o=new ae(n,new Z(n),s,new ne(a));return new r(o,a)}async getOrCreateWallet(e,t,n={signer:{type:"PASSKEY"}}){return E("GET_OR_CREATE_WALLET",async()=>{try{return await this.smartWalletService.getOrCreate(e,t,n)}catch(a){throw this.errorProcessor.map(a,new l(`Wallet creation failed: ${a.message}.`,(0,et.stringify)(a)))}})}};0&&(module.exports={AdminAlreadyUsedError,AdminMismatchError,Chain,ConfigError,CrossmintSDKError,CrossmintServiceError,EVMSmartWallet,JWTDecryptionError,JWTExpiredError,JWTIdentifierError,JWTInvalidError,NotAuthorizedError,PasskeyIncompatibleAuthenticatorError,PasskeyMismatchError,PasskeyPromptError,PasskeyRegistrationError,SmartWalletError,SmartWalletErrorCode,SmartWalletSDK,SmartWalletsNotEnabledError,TransferError,UserWalletAlreadyCreatedError,blockchainToChainId});
|
|
2
5
|
//# sourceMappingURL=index.cjs.map
|