@crossmint/client-sdk-smart-wallet 0.1.4 → 0.1.6

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.
Files changed (35) hide show
  1. package/dist/index.cjs +4 -4
  2. package/dist/index.cjs.map +1 -1
  3. package/dist/index.d.cts +53 -70
  4. package/dist/index.d.ts +53 -70
  5. package/dist/index.js +4 -4
  6. package/dist/index.js.map +1 -1
  7. package/package.json +9 -4
  8. package/src/SmartWalletSDK.ts +10 -7
  9. package/src/api/CrossmintWalletService.test.ts +2 -1
  10. package/src/api/CrossmintWalletService.ts +21 -7
  11. package/src/blockchain/wallets/EVMSmartWallet.ts +7 -9
  12. package/src/blockchain/wallets/account/cache.test.ts +67 -0
  13. package/src/blockchain/wallets/account/cache.ts +43 -0
  14. package/src/blockchain/wallets/account/config.test.ts +103 -0
  15. package/src/blockchain/wallets/account/config.ts +71 -15
  16. package/src/blockchain/wallets/account/creator.ts +18 -14
  17. package/src/blockchain/wallets/account/eoa.ts +10 -9
  18. package/src/blockchain/wallets/account/passkey.ts +11 -12
  19. package/src/blockchain/wallets/account/strategy.ts +2 -2
  20. package/src/blockchain/wallets/clientDecorator.ts +4 -5
  21. package/src/blockchain/wallets/service.ts +20 -15
  22. package/src/error/processor.ts +4 -3
  23. package/src/services/index.ts +1 -0
  24. package/src/services/logger.ts +6 -0
  25. package/src/types/internal.ts +29 -23
  26. package/src/utils/constants.ts +0 -4
  27. package/src/utils/helpers.ts +0 -8
  28. package/src/utils/test.ts +24 -0
  29. package/src/api/APIErrorService.ts +0 -78
  30. package/src/api/BaseCrossmintService.ts +0 -81
  31. package/src/services/logging/BrowserLoggerInterface.ts +0 -5
  32. package/src/services/logging/ConsoleProvider.ts +0 -15
  33. package/src/services/logging/DatadogProvider.ts +0 -39
  34. package/src/services/logging/index.ts +0 -16
  35. package/src/utils/log.ts +0 -49
package/dist/index.cjs CHANGED
@@ -1,5 +1,5 @@
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});
1
+ "use strict";var oe=Object.defineProperty;var Ge=Object.getOwnPropertyDescriptor;var Fe=Object.getOwnPropertyNames;var je=Object.prototype.hasOwnProperty;var He=(r,e)=>{for(var t in e)oe(r,t,{get:e[t],enumerable:!0})},ze=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let a of Fe(e))!je.call(r,a)&&a!==t&&oe(r,a,{get:()=>e[a],enumerable:!(n=Ge(e,a))||n.enumerable});return r};var Je=r=>ze(oe({},"__esModule",{value:!0}),r);var ft={};He(ft,{AdminAlreadyUsedError:()=>w,AdminMismatchError:()=>P,Chain:()=>ae.EVMBlockchainIncludingTestnet,ConfigError:()=>h,CrossmintSDKError:()=>c.CrossmintSDKError,CrossmintServiceError:()=>c.CrossmintServiceError,EVMSmartWallet:()=>C,JWTDecryptionError:()=>c.JWTDecryptionError,JWTExpiredError:()=>c.JWTExpiredError,JWTIdentifierError:()=>c.JWTIdentifierError,JWTInvalidError:()=>c.JWTInvalidError,NotAuthorizedError:()=>c.NotAuthorizedError,PasskeyIncompatibleAuthenticatorError:()=>x,PasskeyMismatchError:()=>E,PasskeyPromptError:()=>T,PasskeyRegistrationError:()=>b,SmartWalletError:()=>l,SmartWalletErrorCode:()=>c.SmartWalletErrorCode,SmartWalletSDK:()=>ne,SmartWalletsNotEnabledError:()=>W,TransferError:()=>c.TransferError,UserWalletAlreadyCreatedError:()=>A,blockchainToChainId:()=>ae.blockchainToChainId});module.exports=Je(ft);var ae=require("@crossmint/common-sdk-base");var D=require("viem"),Pe=require("@crossmint/client-sdk-base");var _=require("@crossmint/client-sdk-base");var ue="ZeroDev";var U="SCW_SDK",M="0.1.0",V="2024-06-09",ye="https://rpc.zerodev.app/api/v2/bundler/";var ie=["0.3.1","0.3.0","0.2.4"],le=["v0.6","v0.7"];var S=new _.SDKLogger(U),fe=new _.SDKLogger(U,(0,_.getBrowserLogger)(U,{onlyDatadog:!0}));var L=require("viem");var ge=[{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 Se({contract:r,config:e,from:t,to:n}){switch(e.token.type){case"ft":return{account:t,address:r,abi:L.erc20Abi,functionName:"transfer",args:[n,e.amount]};case"sft":return{account:t,address:r,abi:ge,functionName:"safeTransferFrom",args:[t.address,n,e.token.tokenId,e.quantity,"0x00"],tokenId:e.token.tokenId};case"nft":return{account:t,address:r,abi:L.erc721Abi,functionName:"safeTransferFrom",args:[t.address,n,e.token.tokenId],tokenId:e.token.tokenId}}}var C=class{constructor(e,t,n,a,o=S){this.crossmintService=e;this.accountClient=t;this.logger=o;this.chain=a,this.client={wallet:t,public:n}}get address(){return this.accountClient.account.address}async transferToken(e,t){return this.logger.logPerformance("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,D.isAddress)(e))throw new Error(`Invalid recipient address: '${e}' is not a valid EVM address.`);if(!(0,D.isAddress)(t.token.contractAddress))throw new Error(`Invalid contract address: '${t.token.contractAddress}' is not a valid EVM address.`);let n=Se({contract:t.token.contractAddress,to:e,from:this.accountClient.account,config:t});try{let a=this.accountClient.extend(D.publicActions),{request:o}=await a.simulateContract(n),s=await a.writeContract(o);return this.logger.log(`[TRANSFER] - Transaction hash from transfer: ${s}`),s}catch(a){this.logger.error("[TRANSFER] - ERROR_TRANSFERRING_TOKEN",{error:a instanceof Error?a.message:JSON.stringify(a),tokenId:n.tokenId,contractAddress:t.token.contractAddress,chain:t.token.chain});let o=n.tokenId==null?"":`:${n.tokenId}}`;throw new Pe.TransferError(`Error transferring token ${t.token.contractAddress}${o}`)}},{toAddress:e,config:t})}async nfts(){return this.crossmintService.fetchNFTs(this.address,this.chain)}};var u=require("@crossmint/client-sdk-base"),l=class extends u.CrossmintSDKError{constructor(e,t,n=u.SmartWalletErrorCode.UNCATEGORIZED){super(e,n,t)}},P=class extends l{constructor(e,t,n){super(e,u.SmartWalletErrorCode.ADMIN_MISMATCH),this.required=t,this.used=n}},E=class extends l{constructor(e,t,n){super(e,u.SmartWalletErrorCode.PASSKEY_MISMATCH),this.required=t,this.used=n}},A=class extends l{constructor(t){super(`The user with userId ${t.toString()} already has a wallet created for this project`);this.code=u.SmartWalletErrorCode.USER_WALLET_ALREADY_CREATED}},T=class extends l{constructor(e){super(`Prompt was either cancelled or timed out for passkey ${e}`,void 0,u.SmartWalletErrorCode.PASSKEY_PROMPT),this.passkeyName=e}},b=class extends l{constructor(e){super(`Registration for passkey ${e} failed, either the registration took too long, or passkey signature vaildation failed.`,void 0,u.SmartWalletErrorCode.PASSKEY_REGISTRATION),this.passkeyName=e}},x=class extends l{constructor(e){super(`User selected authenticator for passkey ${e} is not compatible with Crossmint's Smart Wallets.`,void 0,u.SmartWalletErrorCode.PASSKEY_INCOMPATIBLE_AUTHENTICATOR),this.passkeyName=e}},h=class extends l{constructor(e){super(e,void 0,u.SmartWalletErrorCode.WALLET_CONFIG)}},w=class extends h{constructor(){super("This signer was already used to create another wallet. Please use a different signer.");this.code=u.SmartWalletErrorCode.ADMIN_SIGNER_ALREADY_USED}},W=class extends h{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=u.SmartWalletErrorCode.SMART_WALLETS_NOT_ENABLED}};var c=require("@crossmint/client-sdk-base");var $e=require("viem"),Be=require("@crossmint/common-sdk-base");var v=require("@crossmint/client-sdk-base"),Te=require("@crossmint/common-sdk-base");var he=require("@zerodev/passkey-validator"),$=require("viem"),p=require("zod");var Xe=p.z.custom(r=>(0,$.isHex)(r),{message:"Invalid hex string"}),K=p.z.custom(r=>(0,$.isAddress)(r),{message:"Invalid evm address"}),Ze=p.z.object({eoaAddress:K,type:p.z.literal("eoa")}),Qe=p.z.object({entryPoint:K,validatorAddress:K,pubKeyX:p.z.string(),pubKeyY:p.z.string(),authenticatorIdHash:Xe,authenticatorId:p.z.string()}),et=Qe.extend({passkeyName:p.z.string(),validatorContractVersion:p.z.nativeEnum(he.PasskeyValidatorContractVersion),domain:p.z.string(),type:p.z.literal("passkeys")}),tt=p.z.discriminatedUnion("type",[et,Ze]),B=p.z.object({kernelVersion:p.z.enum(ie,{errorMap:(r,e)=>({message:`Unsupported kernel version. Supported versions: ${ie.join(", ")}. Version used: ${e.data}. Please contact support`})}),entryPointVersion:p.z.enum(le,{errorMap:(r,e)=>({message:`Unsupported entry point version. Supported versions: ${le.join(", ")}. Version used: ${e.data}. Please contact support`})}),userId:p.z.string().min(1),signers:p.z.array(p.z.object({signerData:tt})).min(0).max(1,"Invalid wallet signer configuration. Please contact support"),smartContractWalletAddress:K.optional()});var Ce=require("viem");function Y(r,e){let t=e(r);return t.replace?t.value:Array.isArray(r)?r.map(n=>Y(n,e)):r!==null&&typeof r=="object"?Object.fromEntries(Object.entries(r).map(([n,a])=>[n,Y(a,e)])):t.value}function Ee(r){return Y(r,e=>typeof e=="bigint"?{value:(0,Ce.toHex)(e),replace:!0}:{value:e,replace:!1})}function Ae(r){return Y(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 G=class extends v.BaseCrossmintService{constructor(){super(...arguments);this.logger=S;this.apiErrorService=new v.APIErrorService({ERROR_USER_WALLET_ALREADY_CREATED:({userId:t})=>new A(t),ERROR_ADMIN_SIGNER_ALREADY_USED:()=>new w,ERROR_PROJECT_NONCUSTODIAL_WALLETS_NOT_ENABLED:()=>new W})}async idempotentCreateSmartWallet(t,n){await this.fetchCrossmintAPI(`${V}/sdk/smart-wallet`,{method:"PUT",body:JSON.stringify(n)},"Error creating abstract wallet. Please contact support",t.jwt)}async sponsorUserOperation(t,n,a,o){let s=(0,Te.blockchainToChainId)(o),i=await this.fetchCrossmintAPI(`${V}/sdk/paymaster`,{method:"POST",body:JSON.stringify({userOp:Ee(n),entryPoint:a,chainId:s})},"Error sponsoring user operation. Please contact support",t.jwt);return Ae(i)}async getSmartWalletConfig(t,n){let a=await this.fetchCrossmintAPI(`${V}/sdk/smart-wallet/config?chain=${n}`,{method:"GET"},"Error getting smart wallet version configuration. Please contact support",t.jwt),o=B.safeParse(a);if(!o.success)throw new v.CrossmintServiceError(`Invalid smart wallet config, please contact support. Details below:
2
+ ${o.error.toString()}`);return o.data}async fetchNFTs(t,n){return this.fetchCrossmintAPI(`v1-alpha1/wallets/${n}:${t}/nfts`,{method:"GET"},`Error fetching NFTs for wallet: ${t}`)}getPasskeyServerUrl(){return this.crossmintBaseUrl+"/internal/passkeys"}};var j=require("viem");var F=class{constructor(e){this.keyPrefix=e}set(e,t){localStorage.setItem(this.key(e),JSON.stringify(t))}get(e){let t=this.key(e),n=localStorage.getItem(t);if(n==null)return null;let a=B.safeParse(JSON.parse(n));return a.success?a.data:(localStorage.removeItem(t),null)}clear(){for(let e=0;e<localStorage.length;e++){let t=localStorage.key(e);t&&t.startsWith(this.keyPrefix)&&(localStorage.removeItem(t),e--)}}key(e){return`${this.keyPrefix}-${(0,j.keccak256)((0,j.toHex)(e.jwt))}`}};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}}},I=class{constructor(e){this.type="eoa";this.data=e}display(){return this.data}};var H=class{constructor(e,t){this.crossmintService=e;this.configCache=t}async get(e,t){let n=this.configCache.get(e);if(n!=null)return{config:this.validateAndFormat(e,n),cached:!0};let a=await this.crossmintService.getSmartWalletConfig(e,t);return{config:this.validateAndFormat(e,a),cached:!1}}cache({entryPointVersion:e,kernelVersion:t,user:n,existing:a}){this.configCache.clear(),this.configCache.set(n,{entryPointVersion:e,kernelVersion:t,userId:n.id,signers:[{signerData:a.signerConfig.data}],smartContractWalletAddress:a.address})}validateAndFormat(e,{entryPointVersion:t,kernelVersion:n,signers:a,smartContractWalletAddress:o,userId:s}){if(t==="v0.7"&&n.startsWith("0.2")||t==="v0.6"&&n.startsWith("0.3"))throw new l(`Unsupported combination: entryPoint ${t} and kernel version ${n}. Please contact support`);let i=a.map(g=>g.signerData),m=this.getSigner(i);if(o!=null&&m==null||m!=null&&o==null)throw new l("Either both signer and address must be present, or both must be null");return m==null||o==null?{entryPointVersion:t,kernelVersion:n,userWithId:{...e,id:s}}:{entryPointVersion:t,kernelVersion:n,userWithId:{...e,id:s},existing:{signerConfig:m,address:o}}}getSigner(e){if(e.length===0)return;let t=e[0];if(t.type==="eoa")return new I(t);if(t.type==="passkeys")return new k(t)}};function pe(r){return"signer"in r&&"type"in r.signer&&r.signer.type==="PASSKEY"}function be(r){let e=r.existing==null||r.existing.signerConfig.type==="passkeys";return pe(r.walletParams)&&e}function rt(r){return"signer"in r&&("type"in r.signer&&r.signer.type==="VIEM_ACCOUNT"||"request"in r.signer&&typeof r.signer.request=="function")}function xe(r){let e=r.existing==null||r.existing.signerConfig.type==="eoa";return rt(r.walletParams)&&e}var z=class{constructor(e,t){this.eoaStrategy=e;this.passkeyStrategy=t}get(e){if(be(e))return this.passkeyStrategy.create(e);if(xe(e))return this.eoaStrategy.create(e);if(e.existing==null)throw new h(`Unsupported wallet params:
3
+ ${e.walletParams}`);let t=e.existing.signerConfig.display(),n=pe(e.walletParams)?"passkey":"eoa";throw new P(`Cannot create wallet with ${n} signer for user ${e.user.id}', they already have a wallet with signer:
4
+ '${JSON.stringify(t,null,2)}'`,t)}};var ke=require("@zerodev/ecdsa-validator"),Ie=require("@zerodev/sdk");function we(r,e){return r?.toLowerCase()===e?.toLowerCase()}var We=require("permissionless");async function ve({walletParams:r}){if(nt(r.signer))return await(0,We.providerToSmartAccountSigner)(r.signer);if(at(r.signer))return r.signer.account;{let e=r.signer;throw new l(`The signer type ${e.type} is not supported`)}}function nt(r){return r&&typeof r.request=="function"}function at(r){return r&&r.type==="VIEM_ACCOUNT"}var J=class{async create({chain:e,publicClient:t,entryPoint:n,walletParams:a,kernelVersion:o,user:s,existing:i}){let m=await ve({chain:e,walletParams:a});if(i!=null&&!we(m.address,i.signerConfig.data.eoaAddress))throw new P(`User '${s.id}' has an existing wallet with an eoa signer '${i.signerConfig.data.eoaAddress}', this does not match input eoa signer '${m.address}'.`,i.signerConfig.display(),{type:"eoa",eoaAddress:i.signerConfig.data.eoaAddress});let g=await(0,ke.signerToEcdsaValidator)(t,{signer:m,entryPoint:n,kernelVersion:o});return{account:await(0,Ie.createKernelAccount)(t,{plugins:{sudo:g},index:0n,entryPoint:n,kernelVersion:o,deployedAccountAddress:i?.address}),signerConfig:new I({eoaAddress:m.address,type:"eoa"})}}};var O=require("@zerodev/passkey-validator"),Oe=require("@zerodev/sdk"),Re=require("@zerodev/webauthn-key");var q=class{constructor(e,t){this.passkeyServerUrl=e;this.apiKey=t}async create({user:e,publicClient:t,walletParams:n,entryPoint:a,kernelVersion:o,existing:s}){let i=n.signer.passkeyName??e.id;if(s!=null&&s.signerConfig.data.passkeyName!==i)throw new E(`User '${e.id}' has an existing wallet created with a passkey named '${s.signerConfig.data.passkeyName}', this does match input passkey name '${i}'.`,s.signerConfig.display());try{let m=await this.getPasskey(e,i,s?.signerConfig.data),g=O.PasskeyValidatorContractVersion.V0_0_2,f=s==null?g:s.signerConfig.data.validatorContractVersion,R=await(0,O.toPasskeyValidator)(t,{webAuthnKey:m,entryPoint:a,validatorContractVersion:f,kernelVersion:o}),se=await(0,Oe.createKernelAccount)(t,{plugins:{sudo:R},entryPoint:a,kernelVersion:o,deployedAccountAddress:s?.address});return{signerConfig:this.getSignerConfig(R,f,i),account:this.decorate(se,i)}}catch(m){throw this.mapError(m,i)}}async getPasskey(e,t,n){return n!=null?{pubX:BigInt(n.pubKeyX),pubY:BigInt(n.pubKeyY),authenticatorId:n.authenticatorId,authenticatorIdHash:n.authenticatorIdHash}:(0,Re.toWebAuthnKey)({passkeyName:t,passkeyServerUrl:this.passkeyServerUrl,mode:O.WebAuthnMode.Register,passkeyServerHeaders:this.createPasskeysServerHeaders(e)})}getSignerConfig(e,t,n){return new k({...it(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 x(t):e.message==="Registration not verified"?new b(t):e.code==="ERROR_PASSTHROUGH_SEE_CAUSE_PROPERTY"&&e.name==="NotAllowedError"?new T(t):e}decorate(e,t){return new Proxy(e,{get:(n,a,o)=>{let s=Reflect.get(n,a,o);return typeof s!="function"||typeof a!="string"||!ot(a)?s:async(...i)=>{try{return await s.call(n,...i)}catch(m){throw this.mapError(m,t)}}}})}},st=["signMessage","signTypedData","signUserOperation","signTransaction"];function ot(r){return st.includes(r)}var it=r=>{let e=lt(r),t=new TextDecoder().decode(e);return JSON.parse(t)};function lt(r){let e=atob(r);return Uint8Array.from(e,t=>t.codePointAt(0))}var me=require("viem");function X(r){return!1}var pt=["sendTransaction","writeContract","sendUserOperation"],ct=["signMessage","signTypedData"];function ce(r){return pt.includes(r)}function mt(r){return ct.includes(r)}var Z=class{constructor(e,t=S){this.errorProcessor=e;this.logger=t}decorate({crossmintChain:e,smartAccountClient:t}){return new Proxy(t,{get:(n,a,o)=>{let s=Reflect.get(n,a,o);return typeof s!="function"||typeof a!="string"||!(mt(a)||ce(a))?s:(...i)=>this.logger.logPerformance(`CrossmintSmartWallet.${a}`,()=>this.execute(n,a,s,i,e))}})}async execute(e,t,n,a,o){try{this.logger.log(`[CrossmintSmartWallet.${t}] - params: ${(0,me.stringify)(a)}`);let s=ce(t)?this.processTxnArgs(t,o,a):a;return await n.call(e,...s)}catch(s){let i=ce(t)?"signing":"sending transaction";throw this.errorProcessor.map(s,new l(`Error ${i}: ${s.message}`,(0,me.stringify)(s)))}}processTxnArgs(e,t,n){if(e==="sendUserOperation"){let[{userOperation:o,middleware:s,account:i}]=n;return[{middleware:s,account:i,userOperation:this.addGelatoBundlerProperties(t,o)},...n.slice(1)]}let[a]=n;return[this.addGelatoBundlerProperties(t,a),...n.slice(1)]}addGelatoBundlerProperties(e,t){return X(e)?{...t,maxFeePerGas:"0x0",maxPriorityFeePerGas:"0x0"}:t}};var Ve=require("@zerodev/sdk"),ee=require("permissionless"),N=require("viem"),Le=require("@crossmint/common-sdk-base");var d=require("viem/chains"),y=require("@crossmint/common-sdk-base");var _e={BASE_SEPOLIA:y.BlockchainIncludingTestnet.BASE_SEPOLIA,POLYGON_AMOY:y.BlockchainIncludingTestnet.POLYGON_AMOY,OPTIMISM_SEPOLIA:y.BlockchainIncludingTestnet.OPTIMISM_SEPOLIA,ARBITRUM_SEPOLIA:y.BlockchainIncludingTestnet.ARBITRUM_SEPOLIA},yr=(0,y.objectValues)(_e),De={BASE:y.BlockchainIncludingTestnet.BASE,POLYGON:y.BlockchainIncludingTestnet.POLYGON,OPTIMISM:y.BlockchainIncludingTestnet.OPTIMISM,ARBITRUM:y.BlockchainIncludingTestnet.ARBITRUM},fr=(0,y.objectValues)(De),dt={..._e,...De},gr=(0,y.objectValues)(dt),ut={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"},Ne={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},de=r=>ye+ut[r];function Ue(r){return!X(r)}function Me({entryPoint:r,chain:e,walletService:t,user:n}){return{middleware:{sponsorUserOperation:async({userOperation:a})=>{let{sponsorUserOpParams:o}=await t.sponsorUserOperation(n,a,r,e);return o}}}}var Q=class{constructor(e,t,n,a){this.crossmintService=e;this.accountConfigService=t;this.accountCreator=n;this.clientDecorator=a}async getOrCreate(e,t,n){let{config:{entryPointVersion:a,kernelVersion:o,existing:s,userWithId:i},cached:m}=await this.accountConfigService.get(e,t),g=(0,N.createPublicClient)({transport:(0,N.http)(de(t))}),{account:f,signerConfig:R}=await this.accountCreator.get({chain:t,walletParams:n,publicClient:g,user:i,entryPoint:a==="v0.6"?ee.ENTRYPOINT_ADDRESS_V06:ee.ENTRYPOINT_ADDRESS_V07,kernelVersion:o,existing:s});s==null&&await this.crossmintService.idempotentCreateSmartWallet(e,{type:ue,smartContractWalletAddress:f.address,signerData:R.data,version:0,baseLayer:"evm",chainId:(0,Le.blockchainToChainId)(t),entryPointVersion:a,kernelVersion:o}),m||this.accountConfigService.cache({entryPointVersion:a,kernelVersion:o,user:i,existing:{address:f.address,signerConfig:R}});let se=(0,Ve.createKernelAccountClient)({account:f,chain:Ne[t],entryPoint:f.entryPoint,bundlerTransport:(0,N.http)(de(t)),...Ue(t)&&Me({entryPoint:f.entryPoint,chain:t,walletService:this.crossmintService,user:e})}),Ye=this.clientDecorator.decorate({crossmintChain:t,smartAccountClient:se});return new C(this.crossmintService,Ye,g,t)}};var re=require("viem");var te=class{constructor(e){this.logger=e}map(e,t){return this.record(e),e instanceof l||e instanceof re.BaseError?e:t}record(e){let t=e instanceof Error?e.message:String(e);this.logger.error(`Smart Wallet SDK Error: ${t}`,{stack:e instanceof Error?e.stack:void 0,name:e instanceof Error?e.name:"UnknownError",details:(0,re.stringify)(e),domain:window.location.hostname,sdk_version:M})}};function Ke(){return typeof window<"u"}var ne=class r{constructor(e,t,n=S){this.smartWalletService=e;this.errorProcessor=t;this.logger=n}static init({clientApiKey:e}){if(!Ke())throw new l("Smart Wallet SDK should only be used client side.");if(!(0,Be.validateAPIKey)(e).isValid)throw new Error("API key invalid");let n=new G(e),a=new te(fe),o=new z(new J,new q(n.getPasskeyServerUrl(),e)),s=new F(`smart-wallet-${M}`),i=new Q(n,new H(n,s),o,new Z(a));return new r(i,a)}async getOrCreateWallet(e,t,n={signer:{type:"PASSKEY"}}){return this.logger.logPerformance("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,$e.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});
5
5
  //# sourceMappingURL=index.cjs.map