"use strict"; var __create = Object.create; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __getProtoOf = Object.getPrototypeOf; var __hasOwnProp = Object.prototype.hasOwnProperty; var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( // If the importer is in node compatibility mode or this is not an ESM // file that has been converted to a CommonJS file using a Babel- // compatible transform (i.e. "__esModule" has not been set), then set // "default" to the CommonJS "module.exports" for node compatibility. isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod )); var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); // src/index.ts var src_exports = {}; __export(src_exports, { BaseWallet: () => BaseWallet, DeflyWallet: () => DeflyWallet, ExodusWallet: () => ExodusWallet, KmdWallet: () => KmdWallet, MnemonicWallet: () => MnemonicWallet, NetworkId: () => NetworkId, PeraWallet: () => PeraWallet, StorageAdapter: () => StorageAdapter, WalletConnect: () => WalletConnect, WalletId: () => WalletId, WalletManager: () => WalletManager, defaultState: () => defaultState }); module.exports = __toCommonJS(src_exports); // src/manager.ts var import_store10 = require("@tanstack/store"); var import_algosdk10 = __toESM(require("algosdk"), 1); // src/network.ts var NetworkId = /* @__PURE__ */ ((NetworkId2) => { NetworkId2["MAINNET"] = "mainnet"; NetworkId2["TESTNET"] = "testnet"; NetworkId2["BETANET"] = "betanet"; NetworkId2["LOCALNET"] = "localnet"; return NetworkId2; })(NetworkId || {}); function isValidNetworkId(networkId) { return Object.values(NetworkId).includes(networkId); } function isNetworkConfigMap(config) { const networkKeys = Object.values(NetworkId); return Object.keys(config).some((key) => networkKeys.includes(key)); } var nodeServerMap = { ["mainnet" /* MAINNET */]: "https://mainnet-api.algonode.cloud", ["testnet" /* TESTNET */]: "https://testnet-api.algonode.cloud", ["betanet" /* BETANET */]: "https://betanet-api.algonode.cloud", ["localnet" /* LOCALNET */]: "http://localhost" }; function createDefaultNetworkConfig() { return Object.values(NetworkId).reduce((acc, value) => { acc[value] = { token: "", baseServer: nodeServerMap[value], port: "", headers: {} }; return acc; }, {}); } var caipChainId = { ["mainnet" /* MAINNET */]: "algorand:wGHE2Pwdvd7S12BL5FaOP20EGYesN73k", ["testnet" /* TESTNET */]: "algorand:SGO1GKSzyE7IEPItTxCByw9x8FmnrCDe", ["betanet" /* BETANET */]: "algorand:mFgazF-2uRS1tMiL9dsj01hJGySEmPN2" }; // src/storage.ts var StorageAdapter = class { static getItem(key) { if (typeof window === "undefined") { return null; } return localStorage.getItem(key); } static setItem(key, value) { if (typeof window === "undefined") { return; } localStorage.setItem(key, value); } }; // src/wallets/base.ts var BaseWallet = class { id; metadata; store; getAlgodClient; subscribe; constructor({ id, metadata, store, subscribe, getAlgodClient }) { this.id = id; this.store = store; this.subscribe = subscribe; this.getAlgodClient = getAlgodClient; const ctor = this.constructor; this.metadata = { ...ctor.defaultMetadata, ...metadata }; } static defaultMetadata = { name: "Base Wallet", icon: "" }; setActive() { console.info(`[Wallet] Set active wallet: ${this.id}`); setActiveWallet(this.store, { walletId: this.id }); } setActiveAccount(account) { console.info(`[Wallet] Set active account: ${account}`); setActiveAccount(this.store, { walletId: this.id, address: account }); } // ---------- Derived Properties ------------------------------------ // get name() { return this.id.toUpperCase(); } get accounts() { const state = this.store.state; const walletState = state.wallets[this.id]; return walletState ? walletState.accounts : []; } get addresses() { return this.accounts.map((account) => account.address); } get activeAccount() { const state = this.store.state; const walletState = state.wallets[this.id]; return walletState ? walletState.activeAccount : null; } get activeAddress() { return this.activeAccount?.address ?? null; } get activeNetwork() { const state = this.store.state; return state.activeNetwork; } get isConnected() { const state = this.store.state; const walletState = state.wallets[this.id]; return walletState ? walletState.accounts.length > 0 : false; } get isActive() { const state = this.store.state; return state.activeWallet === this.id; } // ---------- Protected Methods ------------------------------------- // onDisconnect() { removeWallet(this.store, { walletId: this.id }); } }; // src/wallets/defly.ts var import_algosdk9 = __toESM(require("algosdk"), 1); // src/utils.ts var import_algosdk8 = __toESM(require("algosdk"), 1); // src/wallets/types.ts var WalletId = /* @__PURE__ */ ((WalletId2) => { WalletId2["DEFLY"] = "defly"; WalletId2["EXODUS"] = "exodus"; WalletId2["KIBISIS"] = "kibisis"; WalletId2["KMD"] = "kmd"; WalletId2["LUTE"] = "lute"; WalletId2["MNEMONIC"] = "mnemonic"; WalletId2["PERA"] = "pera"; WalletId2["WALLETCONNECT"] = "walletconnect"; return WalletId2; })(WalletId || {}); // src/wallets/exodus.ts var import_algosdk = __toESM(require("algosdk"), 1); var icon = "data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPCEtLSBHZW5lcmF0b3I6IEFkb2JlIElsbHVzdHJhdG9yIDI2LjUuMCwgU1ZHIEV4cG9ydCBQbHVnLUluIC4gU1ZHIFZlcnNpb246IDYuMDAgQnVpbGQgMCkgIC0tPgo8c3ZnIHZlcnNpb249IjEuMSIgaWQ9IkxheWVyXzEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4IgoJIHZpZXdCb3g9IjAgMCAzMDAgMzAwIiBzdHlsZT0iZW5hYmxlLWJhY2tncm91bmQ6bmV3IDAgMCAzMDAgMzAwOyIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSI+CjxzdHlsZSB0eXBlPSJ0ZXh0L2NzcyI+Cgkuc3Qwe2ZpbGw6dXJsKCNTVkdJRF8xXyk7fQoJLnN0MXtmaWxsOnVybCgjU1ZHSURfMDAwMDAwNDM0MjYxNjcxNDAxMDY1ODIyNzAwMDAwMDIxMzA3Njg5MDYwNzMxMTM0ODRfKTt9Cgkuc3Qye2ZpbGw6dXJsKCNTVkdJRF8wMDAwMDEwMjUxOTMxNjAxNTI3NjU4MTY0MDAwMDAxNjI3NDExMjM4MzE3NTY0MTc1OV8pO2ZpbHRlcjp1cmwoI0Fkb2JlX09wYWNpdHlNYXNrRmlsdGVyKTt9Cgkuc3Qze2ZpbGw6dXJsKCNTVkdJRF8wMDAwMDEzODU2MzM4MjQ2MjA4NjAyMDM1MDAwMDAxNDg3ODQ5MDI3MDc4MjA3MTIwN18pO30KCS5zdDR7bWFzazp1cmwoI21hc2swXzE2NjFfMjk1XzAwMDAwMDg4MTMyMjUxNTk3NDQxNTczNDkwMDAwMDExNjkzNjEyMDE4NTA2NjgxNDgxXyk7fQoJLnN0NXtmaWxsOnVybCgjU1ZHSURfMDAwMDAxMDYxMjA2MzI0NjE3OTI4NzExNjAwMDAwMDc0MzM5MTMwMzgzMzc3NjY1NzZfKTt9Cjwvc3R5bGU+CjxnPgoJCgkJPGxpbmVhckdyYWRpZW50IGlkPSJTVkdJRF8xXyIgZ3JhZGllbnRVbml0cz0idXNlclNwYWNlT25Vc2UiIHgxPSIyNDYuNjAzIiB5MT0iOS4yMjEyIiB4Mj0iMTc0LjE1OCIgeTI9IjMwOC41NDI2IiBncmFkaWVudFRyYW5zZm9ybT0ibWF0cml4KDEgMCAwIC0xIDAgMzAyKSI+CgkJPHN0b3AgIG9mZnNldD0iMCIgc3R5bGU9InN0b3AtY29sb3I6IzBCNDZGOSIvPgoJCTxzdG9wICBvZmZzZXQ9IjEiIHN0eWxlPSJzdG9wLWNvbG9yOiNCQkZCRTAiLz4KCTwvbGluZWFyR3JhZGllbnQ+Cgk8cGF0aCBjbGFzcz0ic3QwIiBkPSJNMjc0LjcsOTMuOUwxNjYuNiwyM3YzOS42bDY5LjQsNDUuMWwtOC4yLDI1LjhoLTYxLjJ2MzIuOWg2MS4ybDguMiwyNS44bC02OS40LDQ1LjFWMjc3bDEwOC4yLTcwLjdMMjU3LDE1MC4xCgkJTDI3NC43LDkzLjl6Ii8+CgkKCQk8bGluZWFyR3JhZGllbnQgaWQ9IlNWR0lEXzAwMDAwMDE4MjI4MjM3MTUxMjM5MTUxMzIwMDAwMDE3ODM4NjY0MjU5NzY2MjczOTI1XyIgZ3JhZGllbnRVbml0cz0idXNlclNwYWNlT25Vc2UiIHgxPSIxMjkuMzUxNiIgeTE9Ii0xOS4xNTczIiB4Mj0iNTYuOTA2NiIgeTI9IjI4MC4xNjQxIiBncmFkaWVudFRyYW5zZm9ybT0ibWF0cml4KDEgMCAwIC0xIDAgMzAyKSI+CgkJPHN0b3AgIG9mZnNldD0iMCIgc3R5bGU9InN0b3AtY29sb3I6IzBCNDZGOSIvPgoJCTxzdG9wICBvZmZzZXQ9IjEiIHN0eWxlPSJzdG9wLWNvbG9yOiNCQkZCRTAiLz4KCTwvbGluZWFyR3JhZGllbnQ+Cgk8cGF0aCBzdHlsZT0iZmlsbDp1cmwoI1NWR0lEXzAwMDAwMDE4MjI4MjM3MTUxMjM5MTUxMzIwMDAwMDE3ODM4NjY0MjU5NzY2MjczOTI1Xyk7IiBkPSJNNzIuNSwxNjYuNGg2MXYtMzIuOUg3Mi4ybC03LjktMjUuOAoJCWw2OS4yLTQ1LjFWMjNMMjUuMyw5My45TDQzLDE1MC4xbC0xNy43LDU2LjJMMTMzLjcsMjc3di0zOS42bC02OS40LTQ1LjFMNzIuNSwxNjYuNHoiLz4KCTxkZWZzPgoJCTxmaWx0ZXIgaWQ9IkFkb2JlX09wYWNpdHlNYXNrRmlsdGVyIiBmaWx0ZXJVbml0cz0idXNlclNwYWNlT25Vc2UiIHg9IjI1LjQiIHk9IjIzIiB3aWR0aD0iMjQ3LjYiIGhlaWdodD0iMjU0Ij4KCQkJPGZlQ29sb3JNYXRyaXggIHR5cGU9Im1hdHJpeCIgdmFsdWVzPSIxIDAgMCAwIDAgIDAgMSAwIDAgMCAgMCAwIDEgMCAwICAwIDAgMCAxIDAiLz4KCQk8L2ZpbHRlcj4KCTwvZGVmcz4KCQoJCTxtYXNrIG1hc2tVbml0cz0idXNlclNwYWNlT25Vc2UiIHg9IjI1LjQiIHk9IjIzIiB3aWR0aD0iMjQ3LjYiIGhlaWdodD0iMjU0IiBpZD0ibWFzazBfMTY2MV8yOTVfMDAwMDAwODgxMzIyNTE1OTc0NDE1NzM0OTAwMDAwMTE2OTM2MTIwMTg1MDY2ODE0ODFfIj4KCQkKCQkJPGxpbmVhckdyYWRpZW50IGlkPSJTVkdJRF8wMDAwMDE2NTkyOTcyNDMwMzE2NDIwMzAwMDAwMDAwNzEwMTkwNDk4NDUxOTkxNTE2Ml8iIGdyYWRpZW50VW5pdHM9InVzZXJTcGFjZU9uVXNlIiB4MT0iMjQ2LjYwMzgiIHkxPSI5LjIyMTQiIHgyPSIxNzQuMTU4OCIgeTI9IjMwOC41NDI4IiBncmFkaWVudFRyYW5zZm9ybT0ibWF0cml4KDEgMCAwIC0xIDAgMzAyKSI+CgkJCTxzdG9wICBvZmZzZXQ9IjAiIHN0eWxlPSJzdG9wLWNvbG9yOiMwQjQ2RjkiLz4KCQkJPHN0b3AgIG9mZnNldD0iMSIgc3R5bGU9InN0b3AtY29sb3I6I0JCRkJFMCIvPgoJCTwvbGluZWFyR3JhZGllbnQ+CgkJPHBhdGggc3R5bGU9ImZpbGw6dXJsKCNTVkdJRF8wMDAwMDE2NTkyOTcyNDMwMzE2NDIwMzAwMDAwMDAwNzEwMTkwNDk4NDUxOTkxNTE2Ml8pO2ZpbHRlcjp1cmwoI0Fkb2JlX09wYWNpdHlNYXNrRmlsdGVyKTsiIGQ9IgoJCQlNMjc0LjcsOTMuOUwxNjYuNiwyM3YzOS42bDY5LjQsNDUuMWwtOC4yLDI1LjhoLTYxLjJ2MzIuOWg2MS4ybDguMiwyNS44bC02OS40LDQ1LjFWMjc3bDEwOC4yLTcwLjdMMjU3LDE1MC4xTDI3NC43LDkzLjl6Ii8+CgkJCgkJCTxsaW5lYXJHcmFkaWVudCBpZD0iU1ZHSURfMDAwMDAxMTk4MTE3MDc2MjE0NzI4MTQyNzAwMDAwMTA4Mjk2NTkzODM4NTEyMDI0OTFfIiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSIgeDE9IjEyOS4zNTIxIiB5MT0iLTE5LjE1NzEiIHgyPSI1Ni45MDcxIiB5Mj0iMjgwLjE2NDIiIGdyYWRpZW50VHJhbnNmb3JtPSJtYXRyaXgoMSAwIDAgLTEgMCAzMDIpIj4KCQkJPHN0b3AgIG9mZnNldD0iMCIgc3R5bGU9InN0b3AtY29sb3I6IzBCNDZGOSIvPgoJCQk8c3RvcCAgb2Zmc2V0PSIxIiBzdHlsZT0ic3RvcC1jb2xvcjojQkJGQkUwIi8+CgkJPC9saW5lYXJHcmFkaWVudD4KCQk8cGF0aCBzdHlsZT0iZmlsbDp1cmwoI1NWR0lEXzAwMDAwMTE5ODExNzA3NjIxNDcyODE0MjcwMDAwMDEwODI5NjU5MzgzODUxMjAyNDkxXyk7IiBkPSJNNzIuNSwxNjYuNGg2MXYtMzIuOUg3Mi4ybC03LjktMjUuOAoJCQlsNjkuMi00NS4xVjIzTDI1LjMsOTMuOUw0MywxNTAuMWwtMTcuNyw1Ni4yTDEzMy43LDI3N3YtMzkuNmwtNjkuNC00NS4xTDcyLjUsMTY2LjR6Ii8+Cgk8L21hc2s+Cgk8ZyBjbGFzcz0ic3Q0Ij4KCQkKCQkJPGxpbmVhckdyYWRpZW50IGlkPSJTVkdJRF8wMDAwMDEwOTAxOTkxODU1Nzc3MzA1MzQyMDAwMDAxNzYwMjQwNTkwODA2NzEyMDMwMF8iIGdyYWRpZW50VW5pdHM9InVzZXJTcGFjZU9uVXNlIiB4MT0iNDYuNDY2MiIgeTE9IjIyOC43NTU0IiB4Mj0iMTcxLjg2MzgiIHkyPSIxMzUuMTAzOSIgZ3JhZGllbnRUcmFuc2Zvcm09Im1hdHJpeCgxIDAgMCAtMSAwIDMwMikiPgoJCQk8c3RvcCAgb2Zmc2V0PSIwLjExOTgiIHN0eWxlPSJzdG9wLWNvbG9yOiM4OTUyRkY7c3RvcC1vcGFjaXR5OjAuODciLz4KCQkJPHN0b3AgIG9mZnNldD0iMSIgc3R5bGU9InN0b3AtY29sb3I6I0RBQkRGRjtzdG9wLW9wYWNpdHk6MCIvPgoJCTwvbGluZWFyR3JhZGllbnQ+CgkJCgkJCTxyZWN0IHg9IjI1LjQiIHk9IjIzIiBzdHlsZT0iZmlsbDp1cmwoI1NWR0lEXzAwMDAwMTA5MDE5OTE4NTU3NzczMDUzNDIwMDAwMDE3NjAyNDA1OTA4MDY3MTIwMzAwXyk7IiB3aWR0aD0iMjQ3LjYiIGhlaWdodD0iMjU0Ii8+Cgk8L2c+CjwvZz4KPC9zdmc+Cg=="; var ExodusWallet = class extends BaseWallet { client = null; options; store; constructor({ id, store, subscribe, getAlgodClient, options = {}, metadata = {} }) { super({ id, metadata, getAlgodClient, store, subscribe }); this.options = options; this.store = store; } static defaultMetadata = { name: "Exodus", icon }; async initializeClient() { console.info("[ExodusWallet] Initializing client..."); if (typeof window === "undefined" || window.algorand === void 0) { throw new Error("Exodus is not available."); } const client = window.algorand; this.client = client; return client; } async connect() { console.info("[ExodusWallet] Connecting..."); try { const client = this.client || await this.initializeClient(); const { accounts } = await client.enable(this.options); if (accounts.length === 0) { throw new Error("No accounts found!"); } const walletAccounts = accounts.map((address, idx) => ({ name: `Exodus Wallet ${idx + 1}`, address })); const activeAccount = walletAccounts[0]; addWallet(this.store, { walletId: this.id, wallet: { accounts: walletAccounts, activeAccount } }); return walletAccounts; } catch (error) { if (error.name === "UserRejectedRequestError") { console.info("[ExodusWallet] Connection cancelled."); } else { console.error(`[ExodusWallet] Error connecting: ${error.message}`); } return []; } } async disconnect() { console.info("[ExodusWallet] Disconnecting..."); this.onDisconnect(); } async resumeSession() { const state = this.store.state; const walletState = state.wallets[this.id]; if (!walletState) { return; } console.info("[ExodusWallet] Resuming session..."); if (window === void 0 || window.algorand === void 0 || window.algorand.isConnected !== true) { this.onDisconnect(); } } signTransactions = async (txnGroup, indexesToSign, returnGroup = true) => { if (!this.client) { throw new Error("[ExodusWallet] Client not initialized!"); } const txnsToSign = []; const signedIndexes = []; const msgpackTxnGroup = normalizeTxnGroup(txnGroup); const decodedObjects = msgpackTxnGroup.map((txn) => { return import_algosdk.default.decodeObj(txn); }); decodedObjects.forEach((txnObject, idx) => { const isSigned = isSignedTxnObject(txnObject); const shouldSign = shouldSignTxnObject(txnObject, this.addresses, indexesToSign, idx); const txnBuffer = msgpackTxnGroup[idx]; const txn = isSigned ? import_algosdk.default.decodeSignedTransaction(txnBuffer).txn : import_algosdk.default.decodeUnsignedTransaction(txnBuffer); const txnBase64 = Buffer.from(txn.toByte()).toString("base64"); if (shouldSign) { txnsToSign.push({ txn: txnBase64 }); signedIndexes.push(idx); } else { txnsToSign.push({ txn: txnBase64, signers: [] }); } }); const signTxnsResult = await this.client.signTxns(txnsToSign); const signedTxnsBase64 = signTxnsResult.filter(Boolean); const signedTxns = signedTxnsBase64.map((txn) => new Uint8Array(Buffer.from(txn, "base64"))); const txnGroupSigned = mergeSignedTxnsWithGroup( signedTxns, msgpackTxnGroup, signedIndexes, returnGroup ); return txnGroupSigned; }; transactionSigner = async (txnGroup, indexesToSign) => { if (!this.client) { throw new Error("[ExodusWallet] Client not initialized!"); } const txnsToSign = txnGroup.reduce((acc, txn, idx) => { const txnBase64 = Buffer.from(txn.toByte()).toString("base64"); if (indexesToSign.includes(idx)) { acc.push({ txn: txnBase64 }); } else { acc.push({ txn: txnBase64, signers: [] }); } return acc; }, []); const signTxnsResult = await this.client.signTxns(txnsToSign); const signedTxnsBase64 = signTxnsResult.filter(Boolean); const signedTxns = signedTxnsBase64.map((txn) => new Uint8Array(Buffer.from(txn, "base64"))); return signedTxns; }; }; // src/wallets/kibisis.ts var import_algosdk2 = __toESM(require("algosdk"), 1); var ARC_0027_PREFIX = "arc0027"; var ARC_0027_CHANNEL_NAME = `${ARC_0027_PREFIX}:channel`; var ARC_0027_ENABLE_REQUEST = `${ARC_0027_PREFIX}:enable:request`; var ARC_0027_GET_PROVIDERS_REQUEST = `${ARC_0027_PREFIX}:get_providers:request`; var ARC_0027_PROVIDER_ID = "f6d1c86b-4493-42fb-b88d-a62407b4cdf6"; var ARC_0027_SIGN_TXNS_REQUEST = `${ARC_0027_PREFIX}:sign_txns:request`; var UNKNOWN_ERROR = 4e3; var METHOD_TIMED_OUT_ERROR = 4002; var METHOD_NOT_SUPPORTED_ERROR = 4003; var NETWORK_NOT_SUPPORTED_ERROR = 4004; var DEFAULT_REQUEST_TIMEOUT = 18e4; var LOWER_REQUEST_TIMEOUT = 750; var icon2 = "data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<svg
   version="1.1"
   id="svg2"
   viewBox="0 0 1365.3333 1365.3333"
   xmlns="http://www.w3.org/2000/svg">
  <path
    d="m 667.99998,1048.6662 c 0,-64.16698 -0.62044,-128.81698 -1.37877,-143.6667 -2.81107,-55.04737 -12.06749,-93.05259 -33.24059,-136.47992 -21.50734,-44.11289 -51.07057,-82.63022 -84.73686,-110.40198 -23.64821,-19.50771 -29.39484,-23.57963 -53.59707,-37.97755 -10.35553,-6.16049 -45.97102,-22.80673 -48.79622,-22.80673 -0.94443,0 -2.28715,-0.55289 -2.98381,-1.22865 -1.49195,-1.44716 -34.00787,-11.07847 -44.6,-13.21064 -19.50928,-3.92718 -46.10131,-6.86412 -65.92915,-7.28152 l -13.26249,-0.27919 -1.7944,12.66667 c -2.47233,17.45225 -2.99432,48.31543 -3.00487,177.66666 l -0.009,111.66666 h -28 -28 l 0.0289,-130.33333 c 0.0264,-118.93357 0.25284,-132.49082 2.58856,-154.99999 2.65523,-25.58826 6.36768,-48.68686 9.85759,-61.33334 7.05452,-25.56358 10.62579,-37.26221 12.82143,-42 0.6797,-1.46666 2.12633,-5.36666 3.21473,-8.66666 6.69676,-20.30447 26.44015,-58.78136 43.48873,-84.75303 28.07737,-42.77281 60.34669,-76.88074 104.66667,-110.63026 4.68777,-3.56972 29.48305,-20.07199 39.65998,-26.39532 13.56241,-8.42689 51.8048,-26.68925 65.00668,-31.04345 3.3,-1.0884 7.2,-2.5312 8.66667,-3.20623 7.66133,-3.52609 41.20988,-13.19069 56,-16.13237 79.95878,-15.90339 157.97892,-10.76771 233.99999,15.40306 41.91861,14.43076 75.99649,32.17779 114.75166,59.76019 16.88047,12.01399 47.22176,38.98231 59.91116,53.25103 5.4193,6.09383 11.5108,12.77503 13.5365,14.8471 3.5636,3.64509 24.2294,30.54649 29.8278,38.82787 24.1677,35.74973 45.9126,81.87894 57.2291,121.40474 1.2598,4.4 2.8124,9.5 3.4504,11.33333 1.6148,4.64078 6.5309,28.2356 8.0563,38.66667 0.6971,4.76667 1.5803,9.51695 1.9626,10.55616 0.3824,1.03923 1.5716,13.03923 2.6427,26.66667 1.5197,19.33483 1.9495,52.67283 1.9563,151.77717 l 0.01,126.99999 h -27.9075 -27.9076 l -0.6392,-139.66666 c -0.5016,-109.57863 -1.0339,-142.10817 -2.4711,-151 l -1.8318,-11.33333 -12.6214,0.23304 c -41.1925,0.76057 -80.77972,8.52421 -118.96833,23.33147 l -14.34687,5.56286 1.01354,8.76964 c 0.55744,4.82331 1.01353,98.76965 1.01353,208.76965 V 1022 l -27.66667,0.3604 -27.66666,0.3603 V 829.21771 c 0,-164.92591 -0.27452,-193.39769 -1.85888,-192.78971 -8.26627,3.17206 -43.58517,34.17332 -59.26032,52.01589 -37.00596,42.12283 -63.2251,90.4213 -76.19445,140.35841 -11.33531,43.64536 -12.08592,57.98044 -11.07543,211.5173 l 0.82278,125.0137 h -28.21686 -28.21684 z m 40.14696,-307.1138 c 16.27048,-34.25598 35.15362,-62.1439 61.95641,-91.50158 13.40096,-14.67833 35.11755,-35.1939 45.22996,-42.72853 2.93334,-2.18558 5.63334,-4.3314 6,-4.76846 1.23395,-1.47087 24.88758,-18.25331 28.79636,-20.43126 2.12867,-1.18608 4.77031,-2.73178 5.87031,-3.43489 12.95169,-8.27868 34.57728,-19.50523 56.66666,-29.41752 10.81399,-4.85263 36.46823,-13.49716 51.33334,-17.29745 27.4759,-7.02427 48.25932,-10.24746 73.88342,-11.4582 10.6974,-0.50546 19.4499,-1.32891 19.4499,-1.8299 0,-6.44876 -18.2611,-48.25566 -30.718,-70.32563 -8.0122,-14.19544 -22.4358,-36.51048 -25.2246,-39.02566 -0.4066,-0.36666 -2.49612,-3.06666 -4.64343,-6 -19.70091,-26.91238 -55.03669,-60.38449 -86.74729,-82.17206 -59.74239,-41.04755 -130.73576,-63.81051 -206.23392,-66.12583 -47.60648,-1.45996 -100.20019,8.09475 -149.76607,27.20804 -25.94699,10.00551 -69.31731,34.56026 -90,50.95482 -49.53411,39.26422 -82.65688,79.90693 -110.4048,135.47026 -7.33047,14.67874 -20.26186,45.95237 -20.26186,49.0018 0,1.55306 3.72096,2.11661 18.95377,2.87058 17.53638,0.868 45.42285,4.04374 47.66237,5.42783 0.52933,0.32715 4.20724,1.14152 8.17313,1.80972 14.93084,2.51565 55.94471,14.86908 65.47784,19.722 1.98026,1.00807 4.13546,1.83284 4.78935,1.83284 0.65389,0 2.77945,-4.05 4.72345,-9 3.43291,-8.74117 15.75027,-30.58893 21.41884,-37.9914 16.18291,-21.13291 24.58009,-30.25938 39.46791,-42.89572 15.20517,-12.90569 21.18029,-17.01928 39.57184,-27.24334 38.05215,-21.15363 86.78361,-31.79744 129.22511,-28.22507 33.24759,2.79849 55.08487,8.61855 82.53637,21.99753 36.08704,17.58766 63.48564,40.6231 88.77871,74.64096 8.79708,11.83161 8.77466,12.077 -1.44537,15.82228 -3.3,1.20933 -13.46387,6.34285 -22.58638,11.40783 -9.1225,5.06497 -17.34417,8.91824 -18.27037,8.56282 -0.9262,-0.35541 -3.48367,-3.45073 -5.68325,-6.87849 -5.72215,-8.9172 -29.71267,-31.94085 -41.46,-39.78908 -35.15967,-23.48966 -74.14367,-33.38888 -116.99736,-29.70914 -59.00047,5.06622 -114.77348,44.51395 -141.72094,100.23789 -2.90494,6.00702 -5.2817,11.99141 -5.2817,13.29864 0,1.42466 2.10534,3.45082 5.25567,5.058 14.95501,7.62948 46.47975,33.03684 69.48549,56.00185 27.71011,27.66102 45.78993,50.90598 65.26615,83.91165 8.61696,14.60287 12.45974,22.45113 22.12106,45.17868 l 2.4312,5.71922 2.55432,-5.71922 c 1.40488,-3.14558 6.06976,-13.12064 10.3664,-22.16681 z m -245.48028,96.66981 c 0,-101.44445 0.35001,-184.79445 0.7778,-185.22224 1.96604,-1.96605 21.31041,9.57859 41.22219,24.60125 l 14.66667,11.06543 0.33851,167 0.33849,166.99995 h -28.67183 -28.67183 z"
    fill="#ffffff" />
  <path
    d="M 0,682.66665 V 0 H 682.66665 1365.3333 V 682.66665 1365.3333 H 682.66665 0 Z M 724.31186,1025 c 0.35268,-127.16682 0.62556,-142.82667 2.66614,-153.00002 1.25029,-6.23333 3.24665,-17.03333 4.43634,-24 2.16934,-12.70313 5.92839,-27.27872 9.28444,-36 0.9877,-2.56667 2.52744,-7.06667 3.42167,-10 0.89423,-2.93333 3.63295,-9.68587 6.08604,-15.00564 2.45309,-5.31976 4.46016,-10.07235 4.46016,-10.56129 0,-0.79015 6.02644,-13.25635 9.39438,-19.43307 0.69975,-1.28333 1.84658,-3.38333 2.5485,-4.66667 3.19304,-5.83793 14.00864,-23.73489 14.70525,-24.33333 0.42683,-0.36666 3.74159,-4.86666 7.36615,-10 3.62454,-5.13333 7.58488,-10.53333 8.80072,-12 19.29624,-23.27701 36.11289,-40.52984 48.77253,-50.03758 4.26019,-3.19952 8.3458,-6.46344 9.07913,-7.25316 0.73334,-0.78971 4.48334,-3.72346 8.33334,-6.51944 l 7,-5.0836 v 192.78022 192.78018 h 29.36974 29.36976 l -0.50057,-205.66662 c -0.27532,-113.11666 -0.74171,-207.04878 -1.03643,-208.73803 -0.45497,-2.60782 0.47033,-3.48762 6.13083,-5.82935 3.66666,-1.51688 8.55734,-3.58476 10.86817,-4.59529 2.31083,-1.01052 5.18473,-1.83732 6.38645,-1.83732 1.20172,0 4.41104,-1.09491 7.13183,-2.43312 13.95896,-6.86568 61.75347,-15.65211 91.74867,-16.86684 l 20.1352,-0.81542 0.8678,8.39102 c 0.4774,4.61506 1.4469,12.59102 2.1546,17.72436 0.7517,5.45282 1.3133,64.49186 1.3507,141.99999 0.035,72.96667 0.548,133.42916 1.1395,134.36111 0.8261,1.3015 7.5464,1.6107 28.9796,1.33333 l 27.9041,-0.36111 -0.097,-136.66666 c -0.094,-132.77025 -0.1816,-137.35092 -3.0572,-160.66666 -3.1982,-25.93164 -5.3365,-37.35066 -10.4864,-56 -1.8225,-6.6 -3.4399,-12.6 -3.594,-13.33334 -1.58,-7.51577 -3.0996,-12.2983 -6.9374,-21.83424 -2.4719,-6.14216 -4.4944,-11.99044 -4.4944,-12.99617 0,-3.12641 -23.5111,-52.10944 -28.6483,-59.68569 -1.5478,-2.28281 -3.2077,-5.17791 -3.6885,-6.43356 -1.7821,-4.6538 -26.3419,-40.5152 -32.3299,-47.20705 -0.7333,-0.81954 -4.3333,-5.24312 -8,-9.8302 -8.6111,-10.77274 -41.51559,-44.08064 -52.5576,-53.20203 -4.70668,-3.88802 -9.38875,-7.90028 -10.4046,-8.91613 -1.88196,-1.88195 -5.9573,-4.743 -28.37112,-19.91772 -6.96667,-4.7166 -13.32856,-9.13235 -14.13755,-9.81277 -0.80899,-0.68042 -5.30899,-3.21343 -10,-5.62892 -4.69101,-2.4155 -8.82912,-4.76454 -9.19579,-5.22008 -2.29568,-2.85222 -50.51323,-24.55016 -63.99999,-28.80007 -24.50114,-7.72073 -36.41424,-11.18047 -43.33334,-12.58465 -4.4,-0.89295 -11.9,-2.6806 -16.66666,-3.97256 -39.92045,-10.82007 -138.66639,-10.5152 -179.33333,0.55369 -3.66667,0.998 -11.46667,2.85771 -17.33333,4.13267 -5.86667,1.27496 -16.43624,4.35152 -23.48794,6.8368 -7.0517,2.48528 -13.56102,4.51869 -14.46517,4.51869 -0.90413,0 -3.53456,0.85664 -5.84539,1.90364 -10.55421,4.78195 -16.78252,7.42969 -17.47686,7.42969 -2.22768,0 -53.3482,26.1356 -56.82195,29.05048 -1.04648,0.87812 -8.20269,5.79796 -15.90269,10.93298 -29.30767,19.54481 -41.85027,29.79922 -66.02928,53.98333 -18.63801,18.64194 -28.44184,29.94284 -41.55199,47.89706 -3.80302,5.20822 -8.67102,11.86948 -10.81778,14.80282 -2.14676,2.93333 -5.61493,8.33333 -7.70705,12 -2.09212,3.66666 -4.61131,7.49673 -5.59822,8.51124 -0.98689,1.01452 -3.17358,4.61452 -4.8593,8 -1.68572,3.38549 -6.4741,12.75542 -10.64083,20.82209 -4.16673,8.06667 -9.99083,20.36667 -12.94241,27.33333 -2.9516,6.96667 -6.22603,14.55735 -7.27651,16.86817 -1.05048,2.31083 -1.92673,5.01083 -1.94723,6 -0.0205,0.98918 -1.84905,6.8985 -4.06348,13.13183 -3.69322,10.39603 -5.29117,16.30048 -11.18624,41.33333 -8.34681,35.44398 -9.24678,56.6025 -8.81888,207.33333 0.19986,70.4 0.64084,128.45 0.97998,129 0.79664,1.29199 52.64238,1.27261 54.63697,-0.0204 1.10148,-0.71407 1.72211,-38.38596 2.28959,-138.97958 0.6902,-122.34366 1.63085,-161.20929 3.95801,-163.53647 1.27033,-1.27032 48.18516,2.01814 58.90798,4.12911 5.86667,1.15495 15.46667,3.03797 21.33334,4.18449 19.70825,3.85159 45.96932,12.55162 61.59188,20.40479 4.5422,2.28328 9.0722,4.15141 10.06666,4.15141 0.99447,0 2.37812,0.52034 3.07479,1.1563 0.69667,0.63596 6.38513,3.84669 12.64104,7.13495 6.25589,3.28827 16.68092,9.51794 23.1667,13.84371 6.4858,4.32577 14.1826,9.43523 17.104,11.35436 2.92142,1.91912 5.69639,4.02157 6.16663,4.67211 0.47023,0.65054 5.05496,4.54081 10.18829,8.64502 17.1745,13.73143 41.9613,39.78551 53.60592,56.34663 1.6166,2.29915 3.44883,4.78025 4.07163,5.51359 6.22307,7.3275 20.14761,30.77688 29.69066,49.99999 8.80256,17.73154 20.15559,47.1823 21.84452,56.66667 0.52236,2.93333 1.7697,8.33333 2.77186,12 8.46457,30.96997 9.98312,63.10922 10.00109,211.66664 l 0.0143,118.3333 h 28.62616 28.62616 z M 690.97754,756.63417 c -11.2437,-29.05673 -36.97408,-69.97481 -62.86053,-99.96484 -8.56836,-9.92665 -43.62093,-44.6051 -45.11702,-44.63549 -0.91667,-0.0187 -1.66667,-0.60503 -1.66667,-1.30313 0,-0.69811 -2.85,-3.21603 -6.33333,-5.59539 -3.48334,-2.37937 -6.93334,-5.01516 -7.66667,-5.85731 -0.73333,-0.84216 -3.43333,-2.94532 -6,-4.6737 -2.56667,-1.72838 -4.96667,-3.52699 -5.33333,-3.99692 -0.99291,-1.27252 -14.52226,-10.6074 -15.37366,-10.6074 -1.70414,0 -8.62634,-5.96747 -8.62634,-7.43658 0,-1.74832 10.46426,-23.48185 11.82681,-24.56342 0.46192,-0.36667 2.29511,-3.36667 4.07375,-6.66667 1.77864,-3.3 3.60754,-6.3 4.06424,-6.66667 0.45669,-0.36666 2.24942,-2.76666 3.98385,-5.33333 4.59703,-6.80281 25.07355,-27.44316 32.05135,-32.30775 3.3,-2.30061 6.3,-4.56726 6.66666,-5.03702 0.36667,-0.46976 3.36667,-2.30936 6.66667,-4.088 3.3,-1.77864 6.3,-3.57864 6.66667,-4 2.68844,-3.08944 27.84783,-14.08632 39.33333,-17.19213 33.63024,-9.09404 55.1398,-9.38251 90,-1.20699 16.81683,3.94395 36.72495,12.25293 52.05337,21.72534 14.26138,8.81304 40.60658,34.10844 48.3672,46.43988 1.26916,2.01667 3.42072,3.66667 4.78124,3.66667 1.3605,0 7.49668,-2.79531 13.63592,-6.21179 6.13925,-3.41648 16.86226,-8.88181 23.82893,-12.14518 6.96667,-3.26338 12.86461,-6.11602 13.10653,-6.3392 1.4462,-1.33416 -17.92538,-26.1947 -30.6663,-39.35561 -18.88996,-19.51267 -36.39015,-32.93164 -56.77415,-43.53386 -6.41635,-3.33729 -12.33145,-6.59901 -13.14468,-7.24826 -0.81323,-0.64924 -4.11323,-2.02276 -7.33333,-3.05226 -3.22011,-1.0295 -9.15474,-3.1648 -13.18807,-4.74512 -9.87499,-3.86913 -18.80515,-6.20818 -30,-7.85778 -5.13333,-0.75642 -13.23333,-2.09068 -18,-2.96502 -12.58961,-2.3093 -43.79428,-2.06017 -57.33333,0.45775 -6.23333,1.15924 -14.33333,2.51076 -18,3.00337 -9.0462,1.21538 -17.58605,3.58932 -32.97853,9.16751 -13.15661,4.76792 -38.64191,16.85327 -42.33625,20.07623 -1.1102,0.96854 -4.11855,2.81132 -6.68522,4.09505 -4.55192,2.27668 -5.44998,2.93809 -11.66666,8.59228 -1.65,1.50071 -3.36027,2.72856 -3.80059,2.72856 -1.812,0 -21.55885,18.70875 -29.73959,28.17613 -16.20242,18.75073 -17.56958,20.46515 -21.12484,26.49053 -1.94716,3.3 -3.95778,6.3 -4.46806,6.66667 -1.52882,1.09855 -15.86692,29.66788 -15.86692,31.61556 0,2.78469 -3.69512,3.55027 -7.01029,1.45241 -6.49263,-4.10854 -45.25275,-16.1076 -61.65638,-19.08709 -6.6,-1.19879 -17.7,-3.30105 -24.66666,-4.67169 -6.96667,-1.37064 -21.51667,-2.91278 -32.33334,-3.42698 -10.81666,-0.51418 -19.66666,-1.46612 -19.66666,-2.1154 0,-0.64926 1.42767,-4.61242 3.1726,-8.80698 1.74493,-4.19458 3.6271,-9.1265 4.18261,-10.95983 0.55549,-1.83333 3.32783,-8.29487 6.16073,-14.35896 2.8329,-6.06409 5.15072,-11.87868 5.15072,-12.9213 0,-1.04263 0.65967,-2.30339 1.46592,-2.80168 0.80626,-0.4983 3.09504,-4.2837 5.0862,-8.41202 17.2361,-35.73613 57.40118,-86.1652 88.78122,-111.46881 4.4,-3.54799 9.2,-7.54928 10.66666,-8.89176 5.56832,-5.09685 29.65399,-21.86884 38.96783,-27.13513 2.03436,-1.15029 5.49884,-3.21231 7.69884,-4.58225 10.4895,-6.5319 46.88989,-23.56135 56.77826,-26.56299 2.50528,-0.76049 9.35507,-3.11591 15.22174,-5.23427 5.86666,-2.11836 15.46666,-4.92036 21.33333,-6.22666 5.86667,-1.30632 14.86667,-3.46812 20,-4.80402 5.13333,-1.33589 16.23333,-3.21742 24.66666,-4.18118 19.97748,-2.28303 83.90895,-2.30776 103.33334,-0.04 29.44775,3.43801 72.86169,15.74508 102.66666,29.10414 15.83343,7.0968 38.12728,18.69999 39.33333,20.47167 0.36667,0.53863 2.16667,1.75229 4,2.69703 4.95184,2.55173 21.79683,13.63742 23.33333,15.35566 0.73334,0.82007 5.02834,3.98888 9.54446,7.04179 4.5161,3.05292 8.4161,6.01575 8.66666,6.58407 0.25055,0.56833 3.45174,3.43331 7.11375,6.36665 10.50117,8.41164 31.33919,29.49292 42.83328,43.33333 11.97244,14.41641 25.26221,31.93116 27.59701,36.37035 0.868,1.65028 3.0233,5.01834 4.7896,7.48456 1.7664,2.46622 4.9931,7.85778 7.1706,11.98124 10.7318,20.32249 18.5736,36.13963 20.9039,42.16385 1.4184,3.66666 4.4093,11.07884 6.6465,16.47148 2.2371,5.39265 4.0676,10.5558 4.0676,11.47366 0,1.21783 -5.3151,1.9259 -19.6667,2.61994 -10.8167,0.5231 -24.1667,1.84622 -29.6667,2.94028 -5.5,1.09404 -12.99996,2.4884 -16.66662,3.09856 -3.66667,0.61016 -10.26667,1.81097 -14.66667,2.66845 -12.81304,2.49705 -54.06,15.65579 -58.66667,18.71603 -0.73333,0.48716 -4.33333,1.98709 -8,3.33318 -6.01769,2.20919 -23.62673,10.96127 -43.33333,21.5376 -50.3214,27.00702 -112.18594,87.32824 -141.33333,137.80751 -3.18817,5.52148 -4.87261,8.49321 -6.61292,11.66666 -0.70377,1.28334 -2.65956,4.73334 -4.34621,7.66667 -2.80165,4.87253 -13.38321,27.36492 -16.60731,35.30085 -1.24049,3.05344 -1.64946,2.50376 -5.456,-7.33333 z m -170.99797,99.69914 c -0.0107,-91.48333 -0.46122,-167.0049 -1,-167.8257 -1.27748,-1.9462 -20.33372,-17.04469 -23.96632,-18.9888 -1.54293,-0.82575 -3.60212,-2.27943 -4.57596,-3.23039 -3.49041,-3.40836 -21.83683,-13.21226 -25.10397,-13.41496 l -3.33333,-0.20681 -0.33801,185 -0.33802,184.99995 h 29.33801 29.33802 z"
    fill="#8c019a" />
</svg>
"; function isResponseError(error) { return typeof error === "object" && "code" in error && "message" in error; } var KibisisWallet = class _KibisisWallet extends BaseWallet { methods = []; store; constructor({ id, store, subscribe, getAlgodClient, metadata = {} }) { super({ id, metadata, getAlgodClient, store, subscribe }); this.store = store; } static defaultMetadata = { name: "Kibisis", icon: icon2 }; static async sendRequestWithTimeout({ method, params, timeout, reference }) { return new Promise((resolve, reject) => { const channel = new BroadcastChannel(ARC_0027_CHANNEL_NAME); const requestId = generateUuid(); let timer; channel.onmessage = (message) => { if (!message.data || message.data.requestId !== requestId) { return; } window.clearTimeout(timer); if (message.data.error) { reject(message.data.error); return channel.close(); } resolve(message.data.result); return channel.close(); }; timer = window.setTimeout(() => { channel.close(); reject({ code: METHOD_TIMED_OUT_ERROR, data: { method }, message: `No response from provider "${"kibisis" /* KIBISIS */.toUpperCase()}"`, providerId: ARC_0027_PROVIDER_ID }); }, timeout || DEFAULT_REQUEST_TIMEOUT); channel.postMessage({ id: requestId, params, reference }); }); } /** * Calls the enable method on the provider that returns the authorized accounts. * @returns {Arc0027Account[]} the authorized accounts. * @throws {METHOD_CANCELED_ERROR} if the method was cancelled by the user. * @throws {METHOD_NOT_SUPPORTED_ERROR} if the method is not supported for the configured network. * @throws {METHOD_TIMED_OUT_ERROR} if the method timed out by lack of response. * @throws {NETWORK_NOT_SUPPORTED_ERROR} if the network is not supported for the configured network. * @throws {UNKNOWN_ERROR} if the response result was empty. */ async enable() { const method = "enable"; this.validateMethod(method); const genesisHash = await this.getGenesisHash(); const result = await _KibisisWallet.sendRequestWithTimeout({ method, params: { genesisHash, providerId: ARC_0027_PROVIDER_ID }, reference: ARC_0027_ENABLE_REQUEST }); if (!result) { throw { code: UNKNOWN_ERROR, message: `Received response, but "${method}" request details were empty for provider "${this.name}"`, providerId: ARC_0027_PROVIDER_ID }; } return result.accounts; } /** * Gets the genesis hash of the algod client's configured network. * @returns {string} the genesis hash */ async getGenesisHash() { const algodClient = this.getAlgodClient(); const version = await algodClient.versionsCheck().do(); const genesisHash = version.genesis_hash_b64; return genesisHash; } /** * Gets the provider information and updates the supported methods. This should be called * before interacting with the provider to ensure methods are supported. * @throws {METHOD_TIMED_OUT_ERROR} if the method timed out by lack of response. * @throws {NETWORK_NOT_SUPPORTED_ERROR} if the network is not supported for the configured network. * @throws {UNKNOWN_ERROR} if the response result was empty. */ async getSupportedMethods() { const genesisHash = await this.getGenesisHash(); const result = await _KibisisWallet.sendRequestWithTimeout({ method: "getProviders", params: { providerId: ARC_0027_PROVIDER_ID }, reference: ARC_0027_GET_PROVIDERS_REQUEST, timeout: LOWER_REQUEST_TIMEOUT }); if (!result) { throw { code: UNKNOWN_ERROR, message: `Received response, but provider details were empty for provider "${this.name}"`, providerId: ARC_0027_PROVIDER_ID }; } const networkConfiguration = result.networks.find((value) => value.genesisHash === genesisHash); if (!networkConfiguration) { throw { code: NETWORK_NOT_SUPPORTED_ERROR, data: { genesisHash }, message: `Network "${this.activeNetwork}" not supported on provider "${this.name}"`, providerId: ARC_0027_PROVIDER_ID }; } this.methods = networkConfiguration.methods; } /** * Calls the signTxns methods to sign the supplied transactions. * @param {Arc0001SignTxns[]} txns - the unsigned or signed transactions as defined in ARC-0001. * @returns {(string | null)[]} the authorized accounts. * @throws {INVALID_INPUT_ERROR} if computed group ID for the txns does not match the assigned group ID. * @throws {INVALID_GROUP_ID_ERROR} if the unsigned txns is malformed or not conforming to ARC-0001. * @throws {METHOD_CANCELED_ERROR} if the method was cancelled by the user. * @throws {METHOD_NOT_SUPPORTED_ERROR} if the method is not supported for the configured network. * @throws {METHOD_TIMED_OUT_ERROR} if the method timed out by lack of response. * @throws {NETWORK_NOT_SUPPORTED_ERROR} if the network is not supported for the configured network. * @throws {UNAUTHORIZED_SIGNER_ERROR} if a signer in the request is not authorized by the provider. * @throws {UNKNOWN_ERROR} if the response result was empty. */ async signTxns(txns) { const method = "signTxns"; this.validateMethod(method); const result = await _KibisisWallet.sendRequestWithTimeout({ method, params: { providerId: ARC_0027_PROVIDER_ID, txns }, reference: ARC_0027_SIGN_TXNS_REQUEST }); if (!result) { throw { code: UNKNOWN_ERROR, message: `Received response, but "${method}" request details were empty for provider "${this.name}"`, providerId: ARC_0027_PROVIDER_ID }; } return result.stxns; } /** * Validates whether a method is supported with the provider. * @param {ProviderMethod} method - the method to validate. * @throws {METHOD_NOT_SUPPORTED_ERROR} if the method is not supported for the configured network. */ validateMethod(method) { if (!this.methods.includes(method)) { throw { code: METHOD_NOT_SUPPORTED_ERROR, data: { method }, message: `"${method}" operation not supported on "${this.activeNetwork}" for provider "${this.name}"`, providerId: ARC_0027_PROVIDER_ID }; } } async connect() { console.info("[KibisisWallet] Connecting..."); try { await this.getSupportedMethods(); const accounts = await this.enable(); const walletAccounts = accounts.map(({ address, name }, idx) => ({ name: name || `Kibisis Wallet ${idx + 1}`, address })); const activeAccount = walletAccounts[0]; addWallet(this.store, { walletId: this.id, wallet: { accounts: walletAccounts, activeAccount } }); return walletAccounts; } catch (error) { console.error(`[KibisisWallet] Error connecting: ${error.message}`); return []; } } async disconnect() { console.info("[KibisisWallet] Disconnecting..."); this.onDisconnect(); } resumeSession() { return Promise.resolve(); } signTransactions = async (txnGroup, indexesToSign, returnGroup = true) => { try { await this.getSupportedMethods(); const txnsToSign = []; const signedIndexes = []; const msgpackTxnGroup = normalizeTxnGroup(txnGroup); const decodedObjects = msgpackTxnGroup.map((txn) => { return import_algosdk2.default.decodeObj(txn); }); decodedObjects.forEach((txnObject, idx) => { const isSigned = isSignedTxnObject(txnObject); const shouldSign = shouldSignTxnObject(txnObject, this.addresses, indexesToSign, idx); const txnBuffer = msgpackTxnGroup[idx]; const txn = isSigned ? import_algosdk2.default.decodeSignedTransaction(txnBuffer).txn : import_algosdk2.default.decodeUnsignedTransaction(txnBuffer); const txnBase64 = Buffer.from(txn.toByte()).toString("base64"); if (shouldSign) { txnsToSign.push({ txn: txnBase64 }); signedIndexes.push(idx); } else { txnsToSign.push({ txn: txnBase64, signers: [] }); } }); const signTxnsResult = await this.signTxns(txnsToSign); const signedTxnsBase64 = signTxnsResult.filter(Boolean); const signedTxns = signedTxnsBase64.map((txn) => new Uint8Array(Buffer.from(txn, "base64"))); const txnGroupSigned = mergeSignedTxnsWithGroup( signedTxns, msgpackTxnGroup, signedIndexes, returnGroup ); return txnGroupSigned; } catch (error) { console.error( `[KibisisWallet] Error signing transactions: ` + (isResponseError(error) ? `${error.message} (code: ${error.code})` : error.message) ); throw error; } }; transactionSigner = async (txnGroup, indexesToSign) => { try { const txnsToSign = txnGroup.reduce((acc, txn, idx) => { const txnBase64 = Buffer.from(txn.toByte()).toString("base64"); if (indexesToSign.includes(idx)) { acc.push({ txn: txnBase64 }); } else { acc.push({ txn: txnBase64, signers: [] }); } return acc; }, []); const signTxnsResult = await this.signTxns(txnsToSign); const signedTxnsBase64 = signTxnsResult.filter(Boolean); const signedTxns = signedTxnsBase64.map((txn) => new Uint8Array(Buffer.from(txn, "base64"))); return signedTxns; } catch (error) { console.error( `[KibisisWallet] Error signing transactions: ` + (isResponseError(error) ? `${error.message} (code: ${error.code})` : error.message) ); throw error; } }; }; // src/wallets/kmd.ts var import_algosdk3 = __toESM(require("algosdk"), 1); var icon3 = "data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIGlkPSJMYXllcl8xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA0MDkuODMgMjEwLjMzIj48dGV4dCB0cmFuc2Zvcm09InRyYW5zbGF0ZSgwIDE2MS4zMSkiIHN0eWxlPSJmb250LWZhbWlseTpJQk1QbGV4U2Fucy1NZWRtLCAmYXBvcztJQk0gUGxleCBTYW5zJmFwb3M7OyBmb250LXNpemU6MTkwcHg7Ij48dHNwYW4geD0iMCIgeT0iMCI+S01EPC90c3Bhbj48L3RleHQ+PC9zdmc+"; var KmdWallet = class extends BaseWallet { client = null; options; walletName; walletId = ""; password = ""; store; constructor({ id, store, subscribe, getAlgodClient, options, metadata = {} }) { super({ id, metadata, getAlgodClient, store, subscribe }); const { token = "a".repeat(64), baseServer = "http://127.0.0.1", port = 4002, wallet = "unencrypted-default-wallet" } = options || {}; this.options = { token, baseServer, port }; this.walletName = wallet; this.store = store; } static defaultMetadata = { name: "KMD", icon: icon3 }; async initializeClient() { console.info("[KmdWallet] Initializing client..."); const { token, baseServer, port } = this.options; const client = new import_algosdk3.default.Kmd(token, baseServer, port); this.client = client; return client; } async connect() { console.info("[KmdWallet] Connecting..."); try { if (!this.client) { await this.initializeClient(); } const walletId = this.walletId || await this.fetchWalletId(); const token = await this.fetchToken(walletId, this.getPassword()); const accounts = await this.fetchAccounts(token); if (accounts.length === 0) { throw new Error("No accounts found!"); } const walletAccounts = accounts.map((address, idx) => ({ name: `KMD Wallet ${idx + 1}`, address })); const activeAccount = walletAccounts[0]; addWallet(this.store, { walletId: this.id, wallet: { accounts: walletAccounts, activeAccount } }); await this.releaseToken(token); return walletAccounts; } catch (error) { console.error("[KmdWallet] Error connecting:", error); return []; } } async disconnect() { console.info("[KmdWallet] Disconnecting..."); this.onDisconnect(); } resumeSession() { return Promise.resolve(); } signTransactions = async (txnGroup, indexesToSign, returnGroup = true) => { if (!this.client) { throw new Error("[KmdWallet] Client not initialized!"); } const walletId = this.walletId || await this.fetchWalletId(); const password = this.getPassword(); const token = await this.fetchToken(walletId, password); const signTxnPromises = []; const signedIndexes = []; const msgpackTxnGroup = normalizeTxnGroup(txnGroup); const decodedObjects = msgpackTxnGroup.map((txn) => { return import_algosdk3.default.decodeObj(txn); }); decodedObjects.forEach((txnObject, idx) => { const isSigned = isSignedTxnObject(txnObject); const shouldSign = shouldSignTxnObject(txnObject, this.addresses, indexesToSign, idx); const txnBuffer = msgpackTxnGroup[idx]; const txn = isSigned ? import_algosdk3.default.decodeSignedTransaction(txnBuffer).txn : import_algosdk3.default.decodeUnsignedTransaction(txnBuffer); if (shouldSign) { signTxnPromises.push(this.client.signTransaction(token, password, txn)); signedIndexes.push(idx); } }); const signedTxns = await Promise.all(signTxnPromises); await this.releaseToken(token); const txnGroupSigned = mergeSignedTxnsWithGroup( signedTxns, msgpackTxnGroup, signedIndexes, returnGroup ); return txnGroupSigned; }; transactionSigner = async (txnGroup, indexesToSign) => { if (!this.client) { throw new Error("[KmdWallet] Client not initialized!"); } const walletId = this.walletId || await this.fetchWalletId(); const password = this.getPassword(); const token = await this.fetchToken(walletId, password); const signTxnPromises = []; txnGroup.forEach((txn, idx) => { if (indexesToSign.includes(idx)) { signTxnPromises.push(this.client.signTransaction(token, password, txn)); } }); const signedTxns = await Promise.all(signTxnPromises); return signedTxns; }; async fetchWalletId() { console.info("[KmdWallet] Fetching wallet data..."); if (!this.client) { throw new Error("Client not initialized!"); } const { wallets } = await this.client.listWallets(); const wallet = wallets.find((wallet2) => wallet2.name === this.walletName); if (!wallet) { throw new Error(`Wallet ${this.walletName} not found!`); } this.walletId = wallet.id; return wallet.id; } async fetchToken(walletId, password) { console.info("[KmdWallet] Fetching token..."); if (!this.client) { throw new Error("Client not initialized!"); } const { wallet_handle_token } = await this.client.initWalletHandle( walletId, password ); return wallet_handle_token; } async fetchAccounts(token) { console.info("[KmdWallet] Fetching accounts..."); if (!this.client) { throw new Error("Client not initialized!"); } const { addresses } = await this.client.listKeys(token); return addresses; } async releaseToken(token) { console.info("[KmdWallet] Releasing token..."); if (!this.client) { throw new Error("Client not initialized!"); } await this.client.releaseWalletHandle(token); } getPassword() { if (this.password) { return this.password; } const password = prompt("KMD password") || ""; this.password = password; return password; } }; // src/wallets/lute.ts var import_algosdk4 = __toESM(require("algosdk"), 1); function isSignTxnsError(error) { return error instanceof Error && "code" in error; } var svgIcon = ` `; var LuteWallet = class extends BaseWallet { client = null; options; store; constructor({ id, store, subscribe, getAlgodClient, options, metadata = {} }) { super({ id, metadata, getAlgodClient, store, subscribe }); if (!options?.siteName) { throw new Error("[LuteWallet] Missing required option: siteName"); } this.options = options; this.store = store; } static defaultMetadata = { name: "Lute", icon: `data:image/svg+xml;base64,${btoa(svgIcon.trim())}` }; async initializeClient() { console.info("[LuteWallet] Initializing client..."); const module2 = await import("lute-connect"); const LuteConnect = module2.default; const client = new LuteConnect(this.options.siteName); this.client = client; return client; } async getGenesisId() { const algodClient = this.getAlgodClient(); const genesis = await algodClient.genesis().do(); const genesisId = `${genesis.network}-${genesis.id}`; return genesisId; } async connect() { console.info("[LuteWallet] Connecting..."); try { const client = this.client || await this.initializeClient(); const genesisId = await this.getGenesisId(); const accounts = await client.connect(genesisId); if (accounts.length === 0) { throw new Error("No accounts found!"); } const walletAccounts = accounts.map((address, idx) => ({ name: `Lute Wallet ${idx + 1}`, address })); const activeAccount = walletAccounts[0]; addWallet(this.store, { walletId: this.id, wallet: { accounts: walletAccounts, activeAccount } }); return walletAccounts; } catch (error) { console.error(`[LuteWallet] Error connecting: ${error.message}`); return []; } } async disconnect() { console.info("[LuteWallet] Disconnecting..."); this.onDisconnect(); } resumeSession() { return Promise.resolve(); } signTransactions = async (txnGroup, indexesToSign, returnGroup = true) => { try { if (!this.client) { throw new Error("[LuteWallet] Client not initialized!"); } const txnsToSign = []; const signedIndexes = []; const msgpackTxnGroup = normalizeTxnGroup(txnGroup); const decodedObjects = msgpackTxnGroup.map((txn) => { return import_algosdk4.default.decodeObj(txn); }); decodedObjects.forEach((txnObject, idx) => { const isSigned = isSignedTxnObject(txnObject); const shouldSign = shouldSignTxnObject(txnObject, this.addresses, indexesToSign, idx); const txnBuffer = msgpackTxnGroup[idx]; const txn = isSigned ? import_algosdk4.default.decodeSignedTransaction(txnBuffer).txn : import_algosdk4.default.decodeUnsignedTransaction(txnBuffer); const txnBase64 = Buffer.from(txn.toByte()).toString("base64"); if (shouldSign) { txnsToSign.push({ txn: txnBase64 }); signedIndexes.push(idx); } else { txnsToSign.push({ txn: txnBase64, signers: [] }); } }); const signTxnsResult = await this.client.signTxns(txnsToSign); const signedTxns = signTxnsResult.filter(Boolean); const txnGroupSigned = mergeSignedTxnsWithGroup( signedTxns, msgpackTxnGroup, signedIndexes, returnGroup ); return txnGroupSigned; } catch (error) { console.error( `[LuteWallet] Error signing transactions: ` + (isSignTxnsError(error) ? `${error.message} (code: ${error.code})` : error.message) ); throw error; } }; transactionSigner = async (txnGroup, indexesToSign) => { try { if (!this.client) { throw new Error("[LuteWallet] Client not initialized!"); } const txnsToSign = txnGroup.reduce((acc, txn, idx) => { const txnBase64 = Buffer.from(txn.toByte()).toString("base64"); if (indexesToSign.includes(idx)) { acc.push({ txn: txnBase64 }); } else { acc.push({ txn: txnBase64, signers: [] }); } return acc; }, []); const signTxnsResult = await this.client.signTxns(txnsToSign); const signedTxns = signTxnsResult.filter(Boolean); return signedTxns; } catch (error) { console.error( `[LuteWallet] Error signing transactions: ` + (isSignTxnsError(error) ? `${error.message} (code: ${error.code})` : error.message) ); throw error; } }; }; // src/wallets/mnemonic.ts var import_algosdk5 = __toESM(require("algosdk"), 1); var icon4 = `data:image/svg+xml,%3c%3fxml version='1.0' encoding='UTF-8'%3f%3e %3c!-- Generated by Pixelmator Pro 3.2.2 --%3e %3csvg width='409' height='210' viewBox='0 0 409 210' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink'%3e%3ctext id='MNEMONIC' xml:space='preserve' x='0' y='129' font-family='Helvetica' font-size='72' fill='black'%3eMNEMONIC%3c/text%3e%3c/svg%3e`; var MnemonicWallet = class extends BaseWallet { account = null; options; store; constructor({ id, store, subscribe, getAlgodClient, options, metadata = {} }) { super({ id, metadata, getAlgodClient, store, subscribe }); const { persistToStorage = false } = options || {}; this.options = { persistToStorage }; this.store = store; } static defaultMetadata = { name: "Mnemonic", icon: icon4 }; // @todo: Show explicit security warning if persistToStorage is true // @todo: Save/load mnemonic from storage if persistToStorage is true // @todo: Throw error with link to docs if using mainnet initializeAccount() { const mnemonic = prompt("Enter 25-word mnemonic passphrase:"); if (!mnemonic) { this.account = null; throw new Error("No mnemonic provided"); } const account = import_algosdk5.default.mnemonicToSecretKey(mnemonic); this.account = account; return account; } async connect() { console.info("[MnemonicWallet] Connecting..."); try { const account = this.initializeAccount(); const walletAccount = { name: "Mnemonic Account", address: account.addr }; addWallet(this.store, { walletId: this.id, wallet: { accounts: [walletAccount], activeAccount: walletAccount } }); return [walletAccount]; } catch (error) { console.error("[MnemonicWallet] Error connecting:", error); throw error; } } async disconnect() { console.info("[MnemonicWallet] Disconnecting..."); try { this.account = null; this.onDisconnect(); } catch (error) { console.error(error); } } async resumeSession() { const state = this.store.state; const walletState = state.wallets[this.id]; if (walletState) { try { this.account = null; this.onDisconnect(); } catch (error) { console.error(error); } } } signTransactions = async (txnGroup, indexesToSign, returnGroup = true) => { if (!this.account) { throw new Error("[MnemonicWallet] Client not initialized!"); } const txnGroupSigned = []; const msgpackTxnGroup = normalizeTxnGroup(txnGroup); const decodedObjects = msgpackTxnGroup.map((txn) => { return import_algosdk5.default.decodeObj(txn); }); decodedObjects.forEach((txnObject, idx) => { const isIndexMatch = !indexesToSign || indexesToSign.includes(idx); const isSigned = isSignedTxnObject(txnObject); const canSign = !isSigned && import_algosdk5.default.encodeAddress(txnObject.snd) === this.account.addr; const shouldSign = isIndexMatch && canSign; if (shouldSign) { const txn = import_algosdk5.default.Transaction.from_obj_for_encoding(txnObject); const signedTxn = txn.signTxn(this.account.sk); txnGroupSigned.push(signedTxn); } else if (returnGroup) { txnGroupSigned.push(msgpackTxnGroup[idx]); } }); return Promise.resolve(txnGroupSigned); }; transactionSigner = async (txnGroup, indexesToSign) => { if (!this.account) { throw new Error("[MnemonicWallet] Account not initialized!"); } const signedTxns = []; for (const index of indexesToSign) { const txnToSign = txnGroup[index]; if (txnToSign) { signedTxns.push(txnToSign.signTxn(this.account.sk)); } } return Promise.resolve(signedTxns); }; }; // src/wallets/pera.ts var import_algosdk6 = __toESM(require("algosdk"), 1); var icon5 = "data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIGlkPSJMYXllcl8xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxNzcgMTg3Ij48cmVjdCB4PSItMTEuMzgiIHk9Ii0yNS45NyIgd2lkdGg9IjIwMC4wMiIgaGVpZ2h0PSIyMzEuNTMiIHN0eWxlPSJmaWxsOiNmZTU7Ii8+PHBhdGggZD0iTTk0LjA1LDU5LjYxYzIuMDUsOC40OCwxLjM2LDE1Ljk0LTEuNTUsMTYuNjYtMi45LC43Mi02LjkxLTUuNTctOC45Ni0xNC4wNS0yLjA1LTguNDgtMS4zNi0xNS45NCwxLjU1LTE2LjY2LDIuOS0uNzIsNi45MSw1LjU3LDguOTYsMTQuMDVaIiBzdHlsZT0iZmlsbDojMWMxYzFjOyIvPjxwYXRoIGQ9Ik0xMjcuODUsNjYuOWMtNC41My00LjgxLTEzLjU1LTMuNS0yMC4xNSwyLjkxLTYuNTksNi40MS04LjI2LDE1LjUtMy43MywyMC4zMSw0LjUzLDQuOCwxMy41NSwzLjUsMjAuMTUtMi45MXM4LjI2LTE1LjUsMy43My0yMC4zMVoiIHN0eWxlPSJmaWxsOiMxYzFjMWM7Ii8+PHBhdGggZD0iTTkxLjc5LDE0MC40N2MyLjktLjcyLDMuNDktOC42LDEuMzItMTcuNjEtMi4xNy05LTYuMjktMTUuNzEtOS4xOS0xNC45OS0yLjksLjcyLTMuNDksOC42LTEuMzIsMTcuNjEsMi4xNyw5LDYuMjksMTUuNzEsOS4xOSwxNC45OVoiIHN0eWxlPSJmaWxsOiMxYzFjMWM7Ii8+PHBhdGggZD0iTTYyLjIyLDcxLjNjOC4zNywyLjQ3LDE0LjQ4LDYuOCwxMy42Niw5LjY3LS44MywyLjg3LTguMjgsMy4yLTE2LjY1LC43My04LjM3LTIuNDctMTQuNDgtNi44LTEzLjY2LTkuNjcsLjgzLTIuODcsOC4yOC0zLjIsMTYuNjUtLjczWiIgc3R5bGU9ImZpbGw6IzFjMWMxYzsiLz48cGF0aCBkPSJNMTE2LjU0LDEwMy43NGM4Ljg4LDIuNjIsMTUuNDEsNy4wNywxNC41OSw5Ljk0LS44MywyLjg3LTguNywzLjA4LTE3LjU4LC40Ni04Ljg4LTIuNjItMTUuNDEtNy4wNy0xNC41OS05Ljk0LC44My0yLjg3LDguNy0zLjA4LDE3LjU4LS40NloiIHN0eWxlPSJmaWxsOiMxYzFjMWM7Ii8+PHBhdGggZD0iTTcxLjY0LDk3LjcxYy0yLjA4LTIuMTUtOC44OCwuOTgtMTUuMiw2Ljk5LTYuMzIsNi4wMS05Ljc2LDEyLjYzLTcuNjksMTQuNzgsMi4wOCwyLjE1LDguODgtLjk4LDE1LjItNi45OSw2LjMyLTYuMDEsOS43Ni0xMi42Myw3LjY5LTE0Ljc4WiIgc3R5bGU9ImZpbGw6IzFjMWMxYzsiLz48L3N2Zz4="; var PeraWallet = class extends BaseWallet { client = null; options; store; constructor({ id, store, subscribe, getAlgodClient, options = {}, metadata = {} }) { super({ id, metadata, getAlgodClient, store, subscribe }); this.options = options; this.store = store; } static defaultMetadata = { name: "Pera", icon: icon5 }; async initializeClient() { console.info("[PeraWallet] Initializing client..."); const module2 = await import("@perawallet/connect"); const PeraWalletConnect = module2.default ? module2.default.PeraWalletConnect : module2.PeraWalletConnect; const client = new PeraWalletConnect(this.options); client.connector?.on("disconnect", this.onDisconnect); this.client = client; return client; } async connect() { console.info("[PeraWallet] Connecting..."); try { const client = this.client || await this.initializeClient(); const accounts = await client.connect(); if (accounts.length === 0) { throw new Error("No accounts found!"); } const walletAccounts = accounts.map((address, idx) => ({ name: `Pera Wallet ${idx + 1}`, address })); const activeAccount = walletAccounts[0]; addWallet(this.store, { walletId: this.id, wallet: { accounts: walletAccounts, activeAccount } }); return walletAccounts; } catch (error) { if (error?.data?.type !== "CONNECT_MODAL_CLOSED") { console.error(`[PeraWallet] Error connecting: ${error.message}`); } else { console.info("[PeraWallet] Connection cancelled."); } return []; } } async disconnect() { console.info("[PeraWallet] Disconnecting..."); try { await this.client?.disconnect(); this.onDisconnect(); } catch (error) { console.error(error); } } async resumeSession() { try { const state = this.store.state; const walletState = state.wallets[this.id]; if (!walletState) { return; } console.info("[PeraWallet] Resuming session..."); const client = this.client || await this.initializeClient(); const accounts = await client.reconnectSession(); if (accounts.length === 0) { throw new Error("[PeraWallet] No accounts found!"); } const walletAccounts = accounts.map((address, idx) => ({ name: `Pera Wallet ${idx + 1}`, address })); const match = compareAccounts(walletAccounts, walletState.accounts); if (!match) { console.warn(`[PeraWallet] Session accounts mismatch, updating accounts`); setAccounts(this.store, { walletId: this.id, accounts: walletAccounts }); } } catch (error) { console.error(error); this.onDisconnect(); } } signTransactions = async (txnGroup, indexesToSign, returnGroup = true) => { if (!this.client) { throw new Error("[PeraWallet] Client not initialized!"); } const txnsToSign = []; const signedIndexes = []; const msgpackTxnGroup = normalizeTxnGroup(txnGroup); const decodedObjects = msgpackTxnGroup.map((txn) => { return import_algosdk6.default.decodeObj(txn); }); decodedObjects.forEach((txnObject, idx) => { const isSigned = isSignedTxnObject(txnObject); const shouldSign = shouldSignTxnObject(txnObject, this.addresses, indexesToSign, idx); const txnBuffer = msgpackTxnGroup[idx]; const txn = isSigned ? import_algosdk6.default.decodeSignedTransaction(txnBuffer).txn : import_algosdk6.default.decodeUnsignedTransaction(txnBuffer); if (shouldSign) { txnsToSign.push({ txn }); signedIndexes.push(idx); } else { txnsToSign.push({ txn, signers: [] }); } }); const signedTxns = await this.client.signTransaction([txnsToSign]); const txnGroupSigned = mergeSignedTxnsWithGroup( signedTxns, msgpackTxnGroup, signedIndexes, returnGroup ); return txnGroupSigned; }; transactionSigner = async (txnGroup, indexesToSign) => { if (!this.client) { throw new Error("[PeraWallet] Client not initialized!"); } const txnsToSign = txnGroup.reduce((acc, txn, idx) => { if (indexesToSign.includes(idx)) { acc.push({ txn }); } else { acc.push({ txn, signers: [] }); } return acc; }, []); const signTxnsResult = await this.client.signTransaction([txnsToSign]); return signTxnsResult; }; }; // src/wallets/walletconnect.ts var import_utils7 = require("@walletconnect/utils"); var import_algosdk7 = __toESM(require("algosdk"), 1); var icon6 = "data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPHN2ZyB2ZXJzaW9uPSIxLjEiIGlkPSJMYXllcl8xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4PSIwcHgiIHk9IjBweCIKCSB2aWV3Qm94PSIwIDAgNDgwIDQ4MCIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAwIDAgNDgwIDQ4MDsiIHhtbDpzcGFjZT0icHJlc2VydmUiPgo8c3R5bGUgdHlwZT0idGV4dC9jc3MiPgoJLnN0MHtmaWxsOiMzMzk2RkY7fQo8L3N0eWxlPgo8cGF0aCBjbGFzcz0ic3QwIiBkPSJNMTI2LjYsMTY4YzYyLjYtNjEuMywxNjQuMi02MS4zLDIyNi44LDBsNy41LDcuNGMzLjEsMy4xLDMuMSw4LDAsMTEuMWwtMjUuOCwyNS4yYy0xLjYsMS41LTQuMSwxLjUtNS43LDAKCWwtMTAuNC0xMC4yYy00My43LTQyLjgtMTE0LjUtNDIuOC0xNTguMiwwbC0xMS4xLDEwLjljLTEuNiwxLjUtNC4xLDEuNS01LjcsMGwtMjUuOC0yNS4yYy0zLjEtMy4xLTMuMS04LDAtMTEuMUwxMjYuNiwxNjh6CgkgTTQwNi43LDIyMC4ybDIyLjksMjIuNWMzLjEsMy4xLDMuMSw4LDAsMTEuMUwzMjYuMiwzNTUuMWMtMy4xLDMuMS04LjIsMy4xLTExLjMsMGwtNzMuNC03MS45Yy0wLjgtMC44LTIuMS0wLjgtMi44LDBsLTczLjQsNzEuOQoJYy0zLjEsMy4xLTguMiwzLjEtMTEuMywwTDUwLjMsMjUzLjhjLTMuMS0zLjEtMy4xLTgsMC0xMS4xbDIyLjktMjIuNWMzLjEtMy4xLDguMi0zLjEsMTEuMywwbDczLjQsNzEuOWMwLjgsMC44LDIuMSwwLjgsMi44LDAKCWw3My40LTcxLjljMy4xLTMuMSw4LjItMy4xLDExLjMsMGw3My40LDcxLjljMC44LDAuOCwyLjEsMC44LDIuOCwwbDczLjQtNzEuOUMzOTguNSwyMTcuMSw0MDMuNiwyMTcuMSw0MDYuNywyMjAuMkw0MDYuNywyMjAuMnoiLz4KPC9zdmc+Cg=="; var WalletConnect = class extends BaseWallet { client = null; options; modal = null; modalOptions; session = null; chains; store; constructor({ id, store, subscribe, getAlgodClient, options, metadata = {} }) { super({ id, metadata, getAlgodClient, store, subscribe }); if (!options?.projectId) { throw new Error("[WalletConnect] Missing required option: projectId"); } const { projectId, relayUrl = "wss://relay.walletconnect.com", metadata: _metadata = (0, import_utils7.getAppMetadata)(), ...modalOptions } = options; this.options = { projectId, relayUrl, ..._metadata }; this.modalOptions = modalOptions; this.chains = Object.values(caipChainId); this.store = store; } static defaultMetadata = { name: "WalletConnect", icon: icon6 }; async initializeClient() { console.info("[WalletConnect] Initializing client..."); const SignClient = (await import("@walletconnect/sign-client")).SignClient; const client = await SignClient.init(this.options); client.on("session_event", (args) => { console.log("[WalletConnect] EVENT", "session_event", args); }); client.on("session_update", ({ topic, params }) => { console.log("[WalletConnect] EVENT", "session_update", { topic, params }); const { namespaces } = params; const session = client.session.get(topic); const updatedSession = { ...session, namespaces }; this.onSessionConnected(updatedSession); }); client.on("session_delete", () => { console.log("[WalletConnect] EVENT", "session_delete"); this.session = null; }); this.client = client; return client; } async initializeModal() { console.info("[WalletConnect] Initializing modal..."); const WalletConnectModal = (await import("@walletconnect/modal")).WalletConnectModal; const modal = new WalletConnectModal({ projectId: this.options.projectId, chains: this.chains, ...this.modalOptions }); modal.subscribeModal( (state) => console.info(`[WalletConnect] Modal ${state.open ? "open" : "closed"}`) ); this.modal = modal; return modal; } onSessionConnected(session) { const caipAccounts = session.namespaces.algorand.accounts; if (!caipAccounts.length) { throw new Error("No accounts found!"); } const accounts = [...new Set(caipAccounts.map((account) => account.split(":").pop()))]; const walletAccounts = accounts.map((address, idx) => ({ name: `WalletConnect ${idx + 1}`, address })); const state = this.store.state; const walletState = state.wallets[this.id]; if (!walletState) { addWallet(this.store, { walletId: this.id, wallet: { accounts: walletAccounts, activeAccount: walletAccounts[0] } }); } else { const match = compareAccounts(walletAccounts, walletState.accounts); if (!match) { console.warn(`[WalletConnect] Session accounts mismatch, updating accounts`); setAccounts(this.store, { walletId: this.id, accounts: walletAccounts }); } } this.session = session; return walletAccounts; } async connect() { console.info("[WalletConnect] Connecting..."); try { const client = this.client || await this.initializeClient(); const modal = this.modal || await this.initializeModal(); const requiredNamespaces = { algorand: { chains: this.chains, methods: ["algo_signTxn"], events: [] } }; const { uri, approval } = await client.connect({ requiredNamespaces }); if (!uri) { throw new Error("No URI found"); } await modal.openModal({ uri }); const session = await approval(); const walletAccounts = this.onSessionConnected(session); return walletAccounts; } catch (error) { console.error(`[WalletConnect] Error connecting: ${error.message}`); return []; } finally { this.modal?.closeModal(); } } async disconnect() { console.info("[WalletConnect] Disconnecting..."); try { if (this.client && this.session) { await this.client.disconnect({ topic: this.session.topic, reason: (0, import_utils7.getSdkError)("USER_DISCONNECTED") }); } this.onDisconnect(); } catch (error) { console.error(error); } } async resumeSession() { try { const state = this.store.state; const walletState = state.wallets[this.id]; if (!walletState) { return; } console.info("[WalletConnect] Resuming session..."); const client = this.client || await this.initializeClient(); if (client.session.length) { const lastKeyIndex = client.session.keys.length - 1; const restoredSession = client.session.get(client.session.keys[lastKeyIndex]); this.onSessionConnected(restoredSession); } } catch (error) { console.error(error); this.onDisconnect(); } } signTransactions = async (txnGroup, indexesToSign, returnGroup = true) => { if (!this.client) { throw new Error("[WalletConnect] Client not initialized!"); } if (!this.session) { throw new Error("[WalletConnect] Session is not connected"); } if (this.activeNetwork === "localnet" /* LOCALNET */) { throw new Error(`[WalletConnect] Invalid network: ${this.activeNetwork}`); } const txnsToSign = []; const signedIndexes = []; const msgpackTxnGroup = normalizeTxnGroup(txnGroup); const decodedObjects = msgpackTxnGroup.map((txn) => { return import_algosdk7.default.decodeObj(txn); }); decodedObjects.forEach((txnObject, idx) => { const isSigned = isSignedTxnObject(txnObject); const shouldSign = shouldSignTxnObject(txnObject, this.addresses, indexesToSign, idx); const txnBuffer = msgpackTxnGroup[idx]; const txn = isSigned ? import_algosdk7.default.decodeSignedTransaction(txnBuffer).txn : import_algosdk7.default.decodeUnsignedTransaction(txnBuffer); const txnBase64 = Buffer.from(txn.toByte()).toString("base64"); if (shouldSign) { txnsToSign.push({ txn: txnBase64 }); signedIndexes.push(idx); } else { txnsToSign.push({ txn: txnBase64, signers: [] }); } }); const request = formatJsonRpcRequest("algo_signTxn", [txnsToSign]); const signTxnsResult = await this.client.request({ chainId: caipChainId[this.activeNetwork], topic: this.session.topic, request }); const signedTxnsBase64 = signTxnsResult.filter(Boolean); const signedTxns = signedTxnsBase64.map((txn) => new Uint8Array(Buffer.from(txn, "base64"))); const txnGroupSigned = mergeSignedTxnsWithGroup( signedTxns, msgpackTxnGroup, signedIndexes, returnGroup ); return txnGroupSigned; }; transactionSigner = async (txnGroup, indexesToSign) => { if (!this.client) { throw new Error("[WalletConnect] Client not initialized!"); } if (!this.session) { throw new Error("[WalletConnect] Session is not connected"); } if (this.activeNetwork === "localnet" /* LOCALNET */) { throw new Error(`[WalletConnect] Invalid network: ${this.activeNetwork}`); } const txnsToSign = txnGroup.reduce((acc, txn, idx) => { const txnBase64 = Buffer.from(txn.toByte()).toString("base64"); if (indexesToSign.includes(idx)) { acc.push({ txn: txnBase64 }); } else { acc.push({ txn: txnBase64, signers: [] }); } return acc; }, []); const request = formatJsonRpcRequest("algo_signTxn", [txnsToSign]); const signTxnsResult = await this.client.request({ chainId: caipChainId[this.activeNetwork], topic: this.session.topic, request }); const signedTxnsBase64 = signTxnsResult.filter(Boolean); const signedTxns = signedTxnsBase64.map((txn) => new Uint8Array(Buffer.from(txn, "base64"))); return signedTxns; }; }; // src/utils.ts function createWalletMap() { return { ["defly" /* DEFLY */]: DeflyWallet, ["exodus" /* EXODUS */]: ExodusWallet, ["kibisis" /* KIBISIS */]: KibisisWallet, ["kmd" /* KMD */]: KmdWallet, ["lute" /* LUTE */]: LuteWallet, ["mnemonic" /* MNEMONIC */]: MnemonicWallet, ["pera" /* PERA */]: PeraWallet, ["walletconnect" /* WALLETCONNECT */]: WalletConnect }; } function compareAccounts(accounts, compareTo) { const addresses = new Set(accounts.map((account) => account.address)); const compareAddresses = new Set(compareTo.map((account) => account.address)); if (addresses.size !== compareAddresses.size) { return false; } for (const address of addresses) { if (!compareAddresses.has(address)) { return false; } } return true; } function isTransaction(item) { if (Array.isArray(item)) { return item.every( (elem) => typeof elem === "object" && elem !== null && "genesisID" in elem && typeof elem.genesisID === "string" ); } else { return typeof item === "object" && item !== null && "genesisID" in item && typeof item.genesisID === "string"; } } function isSignedTxnObject(item) { return item.txn !== void 0; } function normalizeTxnGroup(txnGroup) { if (!txnGroup[0]) { throw new Error("Empty transaction group!"); } const isTransactionType = isTransaction(txnGroup[0]); if (isTransactionType) { const transactionGroup = Array.isArray(txnGroup[0]) ? txnGroup.flatMap((txn) => txn) : txnGroup; return transactionGroup.map((txn) => { return import_algosdk8.default.encodeUnsignedTransaction(txn); }); } else { const transactionGroup = Array.isArray(txnGroup[0]) ? txnGroup.flatMap((txn) => txn) : txnGroup; return transactionGroup; } } function shouldSignTxnObject(txnObject, addresses, indexesToSign, idx) { const isIndexMatch = !indexesToSign || indexesToSign.includes(idx); const isSigned = isSignedTxnObject(txnObject); const canSign = !isSigned && addresses.includes(import_algosdk8.default.encodeAddress(txnObject.snd)); const shouldSign = isIndexMatch && canSign; return shouldSign; } function mergeSignedTxnsWithGroup(signedTxns, txnGroup, signedIndexes, returnGroup) { return txnGroup.reduce((acc, txn, i) => { if (signedIndexes.includes(i)) { const signedByUser = signedTxns.shift(); signedByUser && acc.push(signedByUser); } else if (returnGroup) { acc.push(txnGroup[i]); } return acc; }, []); } function getPayloadId() { const date = Date.now() * Math.pow(10, 3); const extra = Math.floor(Math.random() * Math.pow(10, 3)); return date + extra; } function formatJsonRpcRequest(method, params) { return { id: getPayloadId(), jsonrpc: "2.0", method, params }; } function deepMerge(target, source) { const isObject = (obj) => obj && typeof obj === "object"; if (!isObject(target) || !isObject(source)) { throw new Error("Target and source must be objects"); } Object.keys(source).forEach((key) => { const targetValue = target[key]; const sourceValue = source[key]; if (Array.isArray(targetValue) && Array.isArray(sourceValue)) { target[key] = targetValue.concat(sourceValue); } else if (isObject(targetValue) && isObject(sourceValue)) { target[key] = deepMerge(Object.assign({}, targetValue), sourceValue); } else { target[key] = sourceValue; } }); return target; } function generateUuid() { if (window.crypto.randomUUID) { return window.crypto.randomUUID(); } return "10000000-1000-4000-8000-100000000000".replace(/[018]/g, (value) => { const valueAsNumber = parseInt(value); return (valueAsNumber ^ window.crypto.getRandomValues(new Uint8Array(1))[0] & 15 >> valueAsNumber / 4).toString(16); }); } // src/wallets/defly.ts var icon7 = "data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+CjwhRE9DVFlQRSBzdmcgUFVCTElDICItLy9XM0MvL0RURCBTVkcgMS4xLy9FTiIgImh0dHA6Ly93d3cudzMub3JnL0dyYXBoaWNzL1NWRy8xLjEvRFREL3N2ZzExLmR0ZCI+Cjxzdmcgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgdmlld0JveD0iMCAwIDEwMjQgMTAyNCIgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4bWw6c3BhY2U9InByZXNlcnZlIiB4bWxuczpzZXJpZj0iaHR0cDovL3d3dy5zZXJpZi5jb20vIiBzdHlsZT0iZmlsbC1ydWxlOmV2ZW5vZGQ7Y2xpcC1ydWxlOmV2ZW5vZGQ7c3Ryb2tlLWxpbmVqb2luOnJvdW5kO3N0cm9rZS1taXRlcmxpbWl0OjI7Ij4KICAgIDxyZWN0IHg9IjAiIHk9IjAiIHdpZHRoPSIxMDI0IiBoZWlnaHQ9IjEwMjQiLz4KICAgIDxnIHRyYW5zZm9ybT0ibWF0cml4KDEuNjgyMDksMCwwLDEuNjgyMDksMjI2LjM2OCwyMTIuODE4KSI+CiAgICAgICAgPHBhdGggZD0iTTMyNy4wNDksMjgwLjE5MkwxNjkuNTI0LDEzTDEyLDI4MC4xOTJMMTY5LjUyNCwxODkuMDg0TDMyNy4wNDksMjgwLjE5MloiIHN0eWxlPSJmaWxsOndoaXRlO2ZpbGwtcnVsZTpub256ZXJvOyIvPgogICAgPC9nPgogICAgPGcgdHJhbnNmb3JtPSJtYXRyaXgoMS42ODIwOSwwLDAsMS42ODIwOSwyMjYuMzY4LDIxMi44MTgpIj4KICAgICAgICA8cGF0aCBkPSJNMjk5LjU0NiwzMDdMMTY5LjUyNSwyMzguNDczTDM5LjUwNCwzMDdMMTY5LjUyNSwyNjQuNjdMMjk5LjU0NiwzMDdaIiBzdHlsZT0iZmlsbDp3aGl0ZTtmaWxsLXJ1bGU6bm9uemVybzsiLz4KICAgIDwvZz4KPC9zdmc+Cg=="; var DeflyWallet = class extends BaseWallet { client = null; options; store; constructor({ id, store, subscribe, getAlgodClient, options = {}, metadata = {} }) { super({ id, metadata, getAlgodClient, store, subscribe }); this.options = options; this.store = store; } static defaultMetadata = { name: "Defly", icon: icon7 }; async initializeClient() { console.info("[DeflyWallet] Initializing client..."); const module2 = await import("@blockshake/defly-connect"); const DeflyWalletConnect = module2.default ? module2.default.DeflyWalletConnect : module2.DeflyWalletConnect; const client = new DeflyWalletConnect(this.options); client.connector?.on("disconnect", this.onDisconnect); this.client = client; return client; } async connect() { console.info("[DeflyWallet] Connecting..."); try { const client = this.client || await this.initializeClient(); const accounts = await client.connect(); if (accounts.length === 0) { throw new Error("No accounts found!"); } const walletAccounts = accounts.map((address, idx) => ({ name: `Defly Wallet ${idx + 1}`, address })); const activeAccount = walletAccounts[0]; addWallet(this.store, { walletId: this.id, wallet: { accounts: walletAccounts, activeAccount } }); return walletAccounts; } catch (error) { if (error?.data?.type !== "CONNECT_MODAL_CLOSED") { console.error(`[DeflyWallet] Error connecting: ${error.message}`); } else { console.info("[DeflyWallet] Connection cancelled."); } return []; } } async disconnect() { console.info("[DeflyWallet] Disconnecting..."); try { await this.client?.disconnect(); this.onDisconnect(); } catch (error) { console.error(error); } } async resumeSession() { try { const state = this.store.state; const walletState = state.wallets[this.id]; if (!walletState) { return; } console.info("[DeflyWallet] Resuming session..."); const client = this.client || await this.initializeClient(); const accounts = await client.reconnectSession(); if (accounts.length === 0) { throw new Error("[DeflyWallet] No accounts found!"); } const walletAccounts = accounts.map((address, idx) => ({ name: `Defly Wallet ${idx + 1}`, address })); const match = compareAccounts(walletAccounts, walletState.accounts); if (!match) { console.warn(`[DeflyWallet] Session accounts mismatch, updating accounts`); setAccounts(this.store, { walletId: this.id, accounts: walletAccounts }); } } catch (error) { console.error(error); this.onDisconnect(); } } signTransactions = async (txnGroup, indexesToSign, returnGroup = true) => { if (!this.client) { throw new Error("[DeflyWallet] Client not initialized!"); } const txnsToSign = []; const signedIndexes = []; const msgpackTxnGroup = normalizeTxnGroup(txnGroup); const decodedObjects = msgpackTxnGroup.map((txn) => { return import_algosdk9.default.decodeObj(txn); }); decodedObjects.forEach((txnObject, idx) => { const isSigned = isSignedTxnObject(txnObject); const shouldSign = shouldSignTxnObject(txnObject, this.addresses, indexesToSign, idx); const txnBuffer = msgpackTxnGroup[idx]; const txn = isSigned ? import_algosdk9.default.decodeSignedTransaction(txnBuffer).txn : import_algosdk9.default.decodeUnsignedTransaction(txnBuffer); if (shouldSign) { txnsToSign.push({ txn }); signedIndexes.push(idx); } else { txnsToSign.push({ txn, signers: [] }); } }); const signedTxns = await this.client.signTransaction([txnsToSign]); const txnGroupSigned = mergeSignedTxnsWithGroup( signedTxns, msgpackTxnGroup, signedIndexes, returnGroup ); return txnGroupSigned; }; transactionSigner = async (txnGroup, indexesToSign) => { if (!this.client) { throw new Error("[DeflyWallet] Client not initialized!"); } const txnsToSign = txnGroup.reduce((acc, txn, idx) => { if (indexesToSign.includes(idx)) { acc.push({ txn }); } else { acc.push({ txn, signers: [] }); } return acc; }, []); const signTxnsResult = await this.client.signTransaction([txnsToSign]); return signTxnsResult; }; }; // src/store.ts var defaultState = { wallets: {}, activeWallet: null, activeNetwork: "testnet" /* TESTNET */ }; var LOCAL_STORAGE_KEY = "@txnlab/use-wallet-js"; function addWallet(store, { walletId, wallet }) { store.setState((state) => { const newWallets = { ...state.wallets, [walletId]: wallet }; return { ...state, wallets: newWallets, activeWallet: walletId }; }); } function removeWallet(store, { walletId }) { store.setState((state) => { const newWallets = { ...state.wallets }; delete newWallets[walletId]; return { ...state, wallets: newWallets, activeWallet: state.activeWallet === walletId ? null : state.activeWallet }; }); } function setActiveWallet(store, { walletId }) { store.setState((state) => { return { ...state, activeWallet: walletId }; }); } function setActiveAccount(store, { walletId, address }) { store.setState((state) => { const wallet = state.wallets[walletId]; if (!wallet) { return state; } const activeAccount = wallet.accounts.find((a) => a.address === address); if (!activeAccount) { return state; } const newWallets = { ...state.wallets, [walletId]: { ...wallet, activeAccount } }; return { ...state, wallets: newWallets }; }); } function setAccounts(store, { walletId, accounts }) { store.setState((state) => { const wallet = state.wallets[walletId]; if (!wallet) { return state; } const isActiveAccountConnected = accounts.some( (account) => account.address === wallet.activeAccount?.address ); const activeAccount = isActiveAccountConnected ? wallet.activeAccount : accounts[0] || null; const newWallet = { ...wallet, accounts, activeAccount }; const newWallets = { ...state.wallets, [walletId]: newWallet }; return { ...state, wallets: newWallets }; }); } function setActiveNetwork(store, { networkId }) { store.setState((state) => { return { ...state, activeNetwork: networkId }; }); } function isValidWalletId(walletId) { return Object.values(WalletId).includes(walletId); } function isValidWalletAccount(account) { return typeof account === "object" && account !== null && typeof account.name === "string" && typeof account.address === "string"; } function isValidWalletState(wallet) { return typeof wallet === "object" && wallet !== null && Array.isArray(wallet.accounts) && wallet.accounts.every(isValidWalletAccount) && (wallet.activeAccount === null || isValidWalletAccount(wallet.activeAccount)); } function isValidState(state) { if (!state || typeof state !== "object") return false; if (typeof state.wallets !== "object") return false; for (const [walletId, wallet] of Object.entries(state.wallets)) { if (!isValidWalletId(walletId) || !isValidWalletState(wallet)) return false; } if (state.activeWallet !== null && !isValidWalletId(state.activeWallet)) return false; if (!isValidNetworkId(state.activeNetwork)) return false; return true; } // src/manager.ts var WalletManager = class { _clients = /* @__PURE__ */ new Map(); networkConfig; algodClient; store; subscribe; constructor({ wallets = [], network = "testnet" /* TESTNET */, algod = {} } = {}) { const initialState = this.loadPersistedState() || { ...defaultState, activeNetwork: network }; this.store = new import_store10.Store(initialState, { onUpdate: () => this.savePersistedState() }); this.savePersistedState(); this.subscribe = (callback) => { const unsubscribe = this.store.subscribe(() => { callback(this.store.state); }); return unsubscribe; }; this.networkConfig = this.initNetworkConfig(network, algod); this.algodClient = this.createAlgodClient(this.networkConfig[network]); this.initializeWallets(wallets); } // ---------- Store ------------------------------------------------- // loadPersistedState() { try { const serializedState = StorageAdapter.getItem(LOCAL_STORAGE_KEY); if (serializedState === null) { return null; } const parsedState = JSON.parse(serializedState); if (!isValidState(parsedState)) { console.warn("[Store] Parsed state:", parsedState); throw new Error("Persisted state is invalid"); } return parsedState; } catch (error) { console.error(`[Store] Could not load state from local storage: ${error.message}`); return null; } } savePersistedState() { try { const state = this.store.state; const serializedState = JSON.stringify(state); StorageAdapter.setItem(LOCAL_STORAGE_KEY, serializedState); } catch (error) { console.error("[Store] Could not save state to local storage:", error); } } // ---------- Wallets ----------------------------------------------- // initializeWallets(walletsConfig) { console.info("[Manager] Initializing wallets..."); for (const walletConfig of walletsConfig) { let walletId; let walletOptions; let walletMetadata; if (typeof walletConfig === "string") { walletId = walletConfig; } else { const { id, options, metadata } = walletConfig; walletId = id; walletOptions = options; walletMetadata = metadata; } const walletMap = createWalletMap(); const WalletClass = walletMap[walletId]; if (!WalletClass) { console.error(`[Manager] Wallet not found: ${walletId}`); continue; } const walletInstance = new WalletClass({ id: walletId, metadata: walletMetadata, options: walletOptions, getAlgodClient: this.getAlgodClient, store: this.store, subscribe: this.subscribe }); this._clients.set(walletId, walletInstance); console.info(`[Manager] \u2705 Initialized ${walletId}`); } const state = this.store.state; const connectedWallets = Object.keys(state.wallets); for (const walletId of connectedWallets) { if (!this._clients.has(walletId)) { console.warn(`[Manager] Connected wallet not found: ${walletId}`); removeWallet(this.store, { walletId }); } } if (state.activeWallet && !this._clients.has(state.activeWallet)) { console.warn(`[Manager] Active wallet not found: ${state.activeWallet}`); setActiveWallet(this.store, { walletId: null }); } } get wallets() { return [...this._clients.values()]; } getWallet(walletId) { return this._clients.get(walletId); } async resumeSessions() { const promises = this.wallets.map((wallet) => wallet?.resumeSession()); await Promise.all(promises); } // ---------- Network ----------------------------------------------- // initNetworkConfig(network, config) { console.info("[Manager] Initializing network..."); let networkConfig = createDefaultNetworkConfig(); if (isNetworkConfigMap(config)) { networkConfig = deepMerge(networkConfig, config); } else { networkConfig[network] = deepMerge(networkConfig[network], config); } console.info("[Manager] Algodv2 config:", networkConfig); return networkConfig; } createAlgodClient(config) { console.info(`[Manager] Creating Algodv2 client for ${this.activeNetwork}...`); const { token = "", baseServer, port = "", headers = {} } = config; return new import_algosdk10.default.Algodv2(token, baseServer, port, headers); } getAlgodClient = () => { return this.algodClient; }; setActiveNetwork(networkId) { setActiveNetwork(this.store, { networkId }); this.algodClient = this.createAlgodClient(this.networkConfig[networkId]); } get activeNetwork() { return this.store.state.activeNetwork; } // ---------- Active Wallet ----------------------------------------- // get activeWallet() { const state = this.store.state; const activeWallet = this.wallets.find((wallet) => wallet.id === state.activeWallet); if (!activeWallet) { return null; } return activeWallet; } get activeWalletAccounts() { if (!this.activeWallet) { return null; } return this.activeWallet.accounts; } get activeWalletAddresses() { if (!this.activeWallet) { return null; } return this.activeWallet.accounts.map((account) => account.address); } get activeAccount() { if (!this.activeWallet) { return null; } return this.activeWallet.activeAccount; } get activeAddress() { if (!this.activeAccount) { return null; } return this.activeAccount.address; } // ---------- Sign Transactions ------------------------------------- // get signTransactions() { if (!this.activeWallet) { throw new Error("[Manager] No active wallet found!"); } return this.activeWallet.signTransactions; } /** * A function which can sign transactions from an atomic transaction group. The logic will be * specific to each wallet, but the function will always return a promise that resolves to an * array of encoded signed transactions matching the length of the indexesToSign array. * * @see https://github.com/algorand/js-algorand-sdk/blob/v2.6.0/src/signer.ts#L7-L18 * * @param txnGroup - The atomic group containing transactions to be signed * @param indexesToSign - An array of indexes in the atomic transaction group that should be signed * @returns A promise which resolves an array of encoded signed transactions. The length of the * array will be the same as the length of indexesToSign, and each index i in the array * corresponds to the signed transaction from txnGroup[indexesToSign[i]] */ get transactionSigner() { if (!this.activeWallet) { throw new Error("[Manager] No active wallet found!"); } return this.activeWallet.transactionSigner; } /** * A wrapper around `TransactionSigner` that also has the sender address (the current active * account). Can be used to produce a `TransactionWithSigner` object ready to be passed to an * AtomicTransactionComposer's `addTransaction` method. * * @see https://github.com/algorandfoundation/algokit-utils-ts/blob/v4.0.0/docs/code/modules/index.md#gettransactionwithsigner */ get transactionSignerAccount() { if (!this.activeAddress) { throw new Error("[Manager] No active account found!"); } return { addr: this.activeAddress, signer: this.transactionSigner }; } }; // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { BaseWallet, DeflyWallet, ExodusWallet, KmdWallet, MnemonicWallet, NetworkId, PeraWallet, StorageAdapter, WalletConnect, WalletId, WalletManager, defaultState }); //# sourceMappingURL=index.cjs.map