UNPKG

starknetkit

Version:

<!-- logo --> <p align="center"> <img width='300' src="https://starknetkit-website-git-blo-1541-argentlabs.vercel.app/starknetKit-logo.svg"> </p>

1,417 lines 130 kB
var Ct = Object.defineProperty; var xt = (e, t, r) => t in e ? Ct(e, t, { enumerable: !0, configurable: !0, writable: !0, value: r }) : e[t] = r; var d = (e, t, r) => (xt(e, typeof t != "symbol" ? t + "" : t, r), r); import { shortString as J, constants as Q, WalletAccount as $t, num as Ot } from "starknet"; import { C as Lt, d as Ut, e as we, a as W, U as Yt } from "./connector-4bc69b15.js"; const nt = "0.10.0", Qt = { version: nt }; var P = /* @__PURE__ */ ((e) => (e.SUCCESS = "SUCCESS", e.NOT_CONNECTED = "NOT_CONNECTED", e.ERROR = "ERROR", e.CANCELED = "CANCELED", e.USER_INTERACTION_REQUIRED = "USER_INTERACTION_REQUIRED", e))(P || {}); function Pt(e) { return Array.isArray(e) ? e : [e]; } function Bt(e) { const t = e.pathname.split("/"); if (e.hostname === "localhost" || e.hostname === "127.0.0.1" || e.hostname === "0.0.0.0") { if (typeof XMLHttpRequest > "u") return console.warn( `Cannot make synchronous HTTP call in Node.js environment for ${e.toString()}` ), J.encodeShortString("LOCALHOST"); const r = new XMLHttpRequest(); r.open("POST", e.toString(), !1), r.setRequestHeader("Content-Type", "application/json"); const n = JSON.stringify({ jsonrpc: "2.0", method: "starknet_chainId", params: [], id: 1 }); try { if (r.send(n), r.status === 200) { const i = JSON.parse(r.responseText); if (i.result) return i.result; } throw new Error( `Failed to get chain ID from ${e.toString()}: ${r.status} ${r.statusText}` ); } catch (i) { throw new Error(`Failed to connect to ${e.toString()}: ${i}`); } } if (t.includes("starknet")) { if (t.includes("mainnet")) return Q.StarknetChainId.SN_MAIN; if (t.includes("sepolia")) return Q.StarknetChainId.SN_SEPOLIA; } else if (t.length >= 3) { const r = t[2]; if (t.includes("katana")) return J.encodeShortString( `WP_${r.toUpperCase().replace(/-/g, "_")}` ); if (t.includes("mainnet")) return J.encodeShortString( `GG_${r.toUpperCase().replace(/-/g, "_")}` ); } throw new Error(`Chain ${e.toString()} not supported`); } let D = class it extends Error { constructor() { super("Not ready to connect"), Object.setPrototypeOf(this, it.prototype); } }; const Rt = "https://x.cartridge.gg", _t = { ACCOUNTS: "accounts" }, Zt = ""; function Wt() { } class Vt { constructor() { d(this, "m_lastPromise", Promise.resolve()); } /** * Acquire lock * @param [bypass=false] option to skip lock acquisition */ async obtain(t = !1) { let r = Wt; if (t) return r; const n = this.m_lastPromise; return this.m_lastPromise = new Promise((i) => r = i), await n, r; } } const Ft = new Vt(); let Gt = class { constructor() { d(this, "id", "controller"); d(this, "name", "Controller"); d(this, "version", Qt.version); d(this, "icon", Zt); d(this, "account"); d(this, "subscriptions", []); d(this, "_probePromise", null); d(this, "request", async (t) => { switch (t.type) { case "wallet_getPermissions": return await this.safeProbe(), this.account ? [_t.ACCOUNTS] : []; case "wallet_requestAccounts": { if (this.account) return [this.account.address]; const n = t.params && t.params.silent_mode; return this.account = await this.safeProbe(), !this.account && !n && (this.account = await this.connect()), this.account ? [this.account.address] : []; } case "wallet_watchAsset": throw { code: 63, message: "An unexpected error occurred", data: "wallet_watchAsset not implemented" }; case "wallet_addStarknetChain": { let n = t.params; return this.addStarknetChain(n); } case "wallet_switchStarknetChain": { let n = t.params; return this.switchStarknetChain(n.chainId); } case "wallet_requestChainId": if (!this.account) throw { code: 63, message: "An unexpected error occurred", data: "Account not initialized" }; return await this.account.getChainId(); case "wallet_deploymentData": throw { code: 63, message: "An unexpected error occurred", data: "wallet_deploymentData not implemented" }; case "wallet_addInvokeTransaction": if (!this.account) throw { code: 63, message: "An unexpected error occurred", data: "Account not initialized" }; let r = t.params; return await this.account.execute( r.calls.map((n) => ({ contractAddress: n.contract_address, entrypoint: n.entry_point, calldata: n.calldata })) ); case "wallet_addDeclareTransaction": throw { code: 63, message: "An unexpected error occurred", data: "wallet_addDeclareTransaction not implemented" }; case "wallet_signTypedData": { if (!this.account) throw { code: 63, message: "An unexpected error occurred", data: "Account not initialized" }; return await this.account.signMessage(t.params); } case "wallet_supportedSpecs": return []; case "wallet_supportedWalletApi": return []; default: throw { code: 63, message: "An unexpected error occurred", data: `Unknown RPC call type: ${t.type}` }; } }); d(this, "on", (t, r) => { if (t !== "accountsChanged" && t !== "networkChanged") throw new Error(`Unknown event: ${t}`); this.subscriptions.push({ type: t, handler: r }); }); d(this, "off", (t, r) => { if (t !== "accountsChanged" && t !== "networkChanged") throw new Error(`Unknown event: ${t}`); const n = this.subscriptions.findIndex( (i) => i.type === t && i.handler === r ); n >= 0 && this.subscriptions.splice(n, 1); }); } async safeProbe() { if (this.account) return this.account; if (this._probePromise) return this._probePromise; const t = await Ft.obtain(); return await new Promise(async (r) => { try { this._probePromise = this.probe(); const n = await this._probePromise; r(n); } finally { this._probePromise = null; } }).finally(() => { t(); }); } emitNetworkChanged(t) { this.subscriptions.filter((r) => r.type === "networkChanged").forEach((r) => { r.handler(t); }); } emitAccountsChanged(t) { this.subscriptions.filter((r) => r.type === "accountsChanged").forEach((r) => { r.handler(t); }); } }; class Qe extends $t { constructor(r, n, i, o, s, a) { super({ provider: { nodeUrl: n }, walletProvider: r, address: i }); d(this, "keychain"); d(this, "modal"); d(this, "options"); this.keychain = o, this.options = s, this.modal = a; } /** * Invoke execute function in account contract * * @param calls the invocation object or an array of them, containing: * - contractAddress - the address of the contract * - entrypoint - the entrypoint of the contract * - calldata - (defaults to []) the calldata * - signature - (defaults to []) the signature * @param abis (optional) the abi of the contract for better displaying * * @returns response from addTransaction */ async execute(r) { return r = Pt(r), new Promise(async (n, i) => { const o = await this.keychain.execute( r, void 0, void 0, !1, this.options?.feeSource ); if (o.code === P.SUCCESS) { n(o); return; } if (this.options?.propagateSessionErrors && o.code !== P.USER_INTERACTION_REQUIRED) { i(o.error); return; } this.modal.open(); const s = await this.keychain.execute( r, void 0, void 0, !0, o.error ); if (s.code === P.SUCCESS) { n(s), this.modal.close(); return; } i(s.error); }); } /** * Sign an JSON object for off-chain usage with the starknet private key and return the signature * This adds a message prefix so it cant be interchanged with transactions * * @param json - JSON object to be signed * @returns the signature of the JSON object * @throws {Error} if the JSON object is not a valid JSON */ async signMessage(r) { return new Promise(async (n, i) => { const o = await this.keychain.signMessage(r, "", !0); if (!("code" in o)) { n(o); return; } this.modal.open(); const s = await this.keychain.signMessage(r, "", !1); "code" in s ? i(s.error) : n(s), this.modal.close(); }); } } var C; (function(e) { e.Call = "call", e.Reply = "reply", e.Syn = "syn", e.SynAck = "synAck", e.Ack = "ack"; })(C || (C = {})); var U; (function(e) { e.Fulfilled = "fulfilled", e.Rejected = "rejected"; })(U || (U = {})); var q; (function(e) { e.ConnectionDestroyed = "ConnectionDestroyed", e.ConnectionTimeout = "ConnectionTimeout", e.NoIframeSrc = "NoIframeSrc"; })(q || (q = {})); var Ie; (function(e) { e.DataCloneError = "DataCloneError"; })(Ie || (Ie = {})); var O; (function(e) { e.Message = "message"; })(O || (O = {})); const Ht = (e, t) => { const r = []; let n = !1; return { destroy(i) { n || (n = !0, t(`${e}: Destroying connection`), r.forEach((o) => { o(i); })); }, onDestroy(i) { n ? i() : r.push(i); } }; }, Jt = (e) => (...t) => { e && console.log("[Penpal]", ...t); }, Xt = { "http:": "80", "https:": "443" }, qt = /^(https?:)?\/\/([^/:]+)?(:(\d+))?/, Kt = ["file:", "data:"], er = (e) => { if (e && Kt.find((a) => e.startsWith(a))) return "null"; const t = document.location, r = qt.exec(e); let n, i, o; r ? (n = r[1] ? r[1] : t.protocol, i = r[2], o = r[4]) : (n = t.protocol, i = t.hostname, o = t.port); const s = o && o !== Xt[n] ? `:${o}` : ""; return `${n}//${i}${s}`; }, Pe = ({ name: e, message: t, stack: r }) => ({ name: e, message: t, stack: r }), tr = (e) => { const t = new Error(); return Object.keys(e).forEach((r) => t[r] = e[r]), t; }, rr = (e, t, r) => { const { localName: n, local: i, remote: o, originForSending: s, originForReceiving: a } = e; let h = !1; const c = (l) => { if (l.source !== o || l.data.penpal !== C.Call) return; if (a !== "*" && l.origin !== a) { r(`${n} received message from origin ${l.origin} which did not match expected origin ${a}`); return; } const u = l.data, { methodName: w, args: g, id: f } = u; r(`${n}: Received ${w}() call`); const A = (N) => (k) => { if (r(`${n}: Sending ${w}() reply`), h) { r(`${n}: Unable to send ${w}() reply due to destroyed connection`); return; } const p = { penpal: C.Reply, id: f, resolution: N, returnValue: k }; N === U.Rejected && k instanceof Error && (p.returnValue = Pe(k), p.returnValueIsError = !0); try { o.postMessage(p, s); } catch (M) { if (M.name === Ie.DataCloneError) { const v = { penpal: C.Reply, id: f, resolution: U.Rejected, returnValue: Pe(M), returnValueIsError: !0 }; o.postMessage(v, s); } throw M; } }; new Promise((N) => N(t[w].call(t, l.origin).apply(t, g))).then(A(U.Fulfilled), A(U.Rejected)); }; return i.addEventListener(O.Message, c), () => { h = !0, i.removeEventListener(O.Message, c); }; }; let nr = 0; const ir = () => ++nr, ot = ".", st = (e) => e ? e.split(ot) : [], or = (e) => e.join(ot), sr = (e, t) => { const r = st(t || ""); return r.push(e), or(r); }, ar = (e, t, r) => { const n = st(t); return n.reduce((i, o, s) => (typeof i[o] > "u" && (i[o] = {}), s === n.length - 1 && (i[o] = r), i[o]), e), e; }, at = (e, t) => { const r = {}; return Object.keys(e).forEach((n) => { const i = e[n], o = sr(n, t); typeof i == "object" && Object.assign(r, at(i, o)), typeof i == "function" && (r[o] = i); }), r; }, cr = (e) => { const t = {}; for (const r in e) ar(t, r, e[r]); return t; }, hr = (e, t, r, n, i) => { const { localName: o, local: s, remote: a, originForSending: h, originForReceiving: c } = t; let l = !1; i(`${o}: Connecting call sender`); const u = (g) => (...f) => { i(`${o}: Sending ${g}() call`); let A; try { a.closed && (A = !0); } catch { A = !0; } if (A && n(), l) { const N = new Error(`Unable to send ${g}() call due to destroyed connection`); throw N.code = q.ConnectionDestroyed, N; } return new Promise((N, k) => { const p = ir(), M = (T) => { if (T.source !== a || T.data.penpal !== C.Reply || T.data.id !== p) return; if (c !== "*" && T.origin !== c) { i(`${o} received message from origin ${T.origin} which did not match expected origin ${c}`); return; } const ue = T.data; i(`${o}: Received ${g}() reply`), s.removeEventListener(O.Message, M); let de = ue.returnValue; ue.returnValueIsError && (de = tr(de)), (ue.resolution === U.Fulfilled ? N : k)(de); }; s.addEventListener(O.Message, M); const v = { penpal: C.Call, id: p, methodName: g, args: f }; a.postMessage(v, h); }); }, w = r.reduce((g, f) => (g[f] = u(f), g), {}); return Object.assign(e, cr(w)), () => { l = !0; }; }, lr = (e, t, r, n, i) => { const { destroy: o, onDestroy: s } = n; let a, h; const c = {}; return (l) => { if (t !== "*" && l.origin !== t) { i(`Parent: Handshake - Received ACK message from origin ${l.origin} which did not match expected origin ${t}`); return; } i("Parent: Handshake - Received ACK"); const u = { localName: "Parent", local: window, remote: l.source, originForSending: r, originForReceiving: t }; a && a(), a = rr(u, e, i), s(a), h && h.forEach((g) => { delete c[g]; }), h = l.data.methodNames; const w = hr(c, u, h, o, i); return s(w), c; }; }, ur = (e, t, r, n) => (i) => { if (!i.source) return; if (r !== "*" && i.origin !== r) { e(`Parent: Handshake - Received SYN message from origin ${i.origin} which did not match expected origin ${r}`); return; } e("Parent: Handshake - Received SYN, responding with SYN-ACK"); const o = { penpal: C.SynAck, methodNames: Object.keys(t) }; i.source.postMessage(o, n); }, dr = 6e4, wr = (e, t) => { const { destroy: r, onDestroy: n } = t, i = setInterval(() => { e.isConnected || (clearInterval(i), r()); }, dr); n(() => { clearInterval(i); }); }, gr = (e, t) => { let r; return e !== void 0 && (r = window.setTimeout(() => { const n = new Error(`Connection timed out after ${e}ms`); n.code = q.ConnectionTimeout, t(n); }, e)), () => { clearTimeout(r); }; }, yr = (e) => { if (!e.src && !e.srcdoc) { const t = new Error("Iframe must have src or srcdoc property defined."); throw t.code = q.NoIframeSrc, t; } }, fr = (e) => { let { iframe: t, methods: r = {}, childOrigin: n, timeout: i, debug: o = !1 } = e; const s = Jt(o), a = Ht("Parent", s), { onDestroy: h, destroy: c } = a; n || (yr(t), n = er(t.src)); const l = n === "null" ? "*" : n, u = at(r), w = ur(s, u, n, l), g = lr(u, n, l, a, s); return { promise: new Promise((f, A) => { const N = gr(i, c), k = (p) => { if (!(p.source !== t.contentWindow || !p.data)) { if (p.data.penpal === C.Syn) { w(p); return; } if (p.data.penpal === C.Ack) { const M = g(p); M && (N(), f(M)); return; } } }; window.addEventListener(O.Message, k), s("Parent: Awaiting handshake"), wr(t, a), h((p) => { window.removeEventListener(O.Message, k), p && A(p); }); }), destroy() { c(); } }; }; class pr { constructor({ id: t, url: r, preset: n, onClose: i, onConnect: o, methods: s = {} }) { d(this, "url"); d(this, "iframe"); d(this, "container"); d(this, "onClose"); d(this, "child"); d(this, "closeTimeout"); if (typeof document > "u" || typeof window > "u") return; n && r.searchParams.set("preset", n), this.url = r; const a = document.createElement("iframe"); a.src = r.toString(), a.id = t, a.style.border = "none", a.sandbox.add("allow-forms"), a.sandbox.add("allow-popups"), a.sandbox.add("allow-popups-to-escape-sandbox"), a.sandbox.add("allow-scripts"), a.sandbox.add("allow-same-origin"), a.allow = "publickey-credentials-create *; publickey-credentials-get *; clipboard-write", document.hasStorageAccess && a.sandbox.add("allow-storage-access-by-user-activation"); const h = document.createElement("div"); h.id = "controller", h.style.position = "fixed", h.style.height = "100%", h.style.width = "100%", h.style.top = "0", h.style.left = "0", h.style.zIndex = "10000", h.style.backgroundColor = "rgba(0,0,0,0.6)", h.style.display = "none", h.style.alignItems = "center", h.style.justifyContent = "center", h.style.transition = "opacity 0.2s ease", h.style.opacity = "0", h.style.pointerEvents = "auto", h.appendChild(a), h.addEventListener("click", (u) => { u.target === h && (t === "controller-keychain" && this.child && this.child.reset?.().catch((w) => console.error("Error resetting context:", w)), this.close()); }), this.iframe = a, this.container = h, fr({ iframe: this.iframe, methods: { close: (u) => () => this.close(), reload: (u) => () => window.location.reload(), ...s } }).promise.then((u) => { this.child = u, o(u); }), this.resize(), window.addEventListener("resize", () => this.resize()); const c = new MutationObserver(() => { if (typeof document > "u") return; const u = document.getElementById("controller"); document.body && t === "controller-keychain" && !u && (document.body.appendChild(h), c.disconnect()); }); c.observe(document.documentElement, { childList: !0, subtree: !0 }); const l = document.getElementById("controller"); document.body && t === "controller-keychain" && !l && document.body.appendChild(h), this.onClose = i; } open() { !this.container || typeof document > "u" || !document.body || (this.closeTimeout && (clearTimeout(this.closeTimeout), this.closeTimeout = void 0), document.body.style.overflow = "hidden", this.container.style.display = "flex", requestAnimationFrame(() => { this.container && (this.container.style.opacity = "1"); })); } close() { !this.container || typeof document > "u" || !document.body || (this.onClose?.(), document.body.style.overflow = "auto", this.container.style.opacity = "0", this.closeTimeout = setTimeout(() => { this.container && (this.container.style.display = "none"), this.closeTimeout = void 0; }, 200)); } sendBackward() { this.container && (this.container.style.zIndex = "9999"); } sendForward() { this.container && (this.container.style.zIndex = "10000"); } resize() { if (!(!this.iframe || typeof window > "u")) { if (this.iframe.style.userSelect = "none", window.innerWidth < 768) { this.iframe.style.height = "100%", this.iframe.style.width = "100%", this.iframe.style.borderRadius = "0"; return; } this.iframe.style.height = "600px", this.iframe.style.width = "432px", this.iframe.style.borderRadius = "8px"; } } isOpen() { return this.container?.style.display !== "none"; } } const mr = "6.13.7"; function Be(e, t, r) { for (let n in t) { let i = t[n]; Object.defineProperty(e, n, { enumerable: !0, value: i, writable: !1 }); } } function _(e) { if (e == null) return "null"; if (Array.isArray(e)) return "[ " + e.map(_).join(", ") + " ]"; if (e instanceof Uint8Array) { const t = "0123456789abcdef"; let r = "0x"; for (let n = 0; n < e.length; n++) r += t[e[n] >> 4], r += t[e[n] & 15]; return r; } if (typeof e == "object" && typeof e.toJSON == "function") return _(e.toJSON()); switch (typeof e) { case "boolean": case "symbol": return e.toString(); case "bigint": return BigInt(e).toString(); case "number": return e.toString(); case "string": return JSON.stringify(e); case "object": { const t = Object.keys(e); return t.sort(), "{ " + t.map((r) => `${_(r)}: ${_(e[r])}`).join(", ") + " }"; } } return "[ COULD NOT SERIALIZE ]"; } function Nr(e, t, r) { let n = e; { const o = []; if (r) { if ("message" in r || "code" in r || "name" in r) throw new Error(`value will overwrite populated values: ${_(r)}`); for (const s in r) { if (s === "shortMessage") continue; const a = r[s]; o.push(s + "=" + _(a)); } } o.push(`code=${t}`), o.push(`version=${mr}`), o.length && (e += " (" + o.join(", ") + ")"); } let i; switch (t) { case "INVALID_ARGUMENT": i = new TypeError(e); break; case "NUMERIC_FAULT": case "BUFFER_OVERRUN": i = new RangeError(e); break; default: i = new Error(e); } return Be(i, { code: t }), r && Object.assign(i, r), i.shortMessage == null && Be(i, { shortMessage: n }), i; } function Mr(e, t, r, n) { if (!e) throw Nr(t, r, n); } function F(e, t, r, n) { Mr(e, t, "INVALID_ARGUMENT", { argument: r, value: n }); } ["NFD", "NFC", "NFKD", "NFKC"].reduce((e, t) => { try { if ("test".normalize(t) !== "test") throw new Error("bad"); if (t === "NFD" && "é".normalize("NFD") !== "é") throw new Error("broken"); e.push(t); } catch { } return e; }, []); function Ir(e, t, r) { if (e instanceof Uint8Array) return e; if (typeof e == "string" && e.match(/^0x(?:[0-9a-f][0-9a-f])*$/i)) { const n = new Uint8Array((e.length - 2) / 2); let i = 2; for (let o = 0; o < n.length; o++) n[o] = parseInt(e.substring(i, i + 2), 16), i += 2; return n; } F(!1, "invalid BytesLike value", t || "value", e); } function ke(e, t) { return Ir(e, t); } const Re = "0123456789abcdef"; function Ar(e) { const t = ke(e); let r = "0x"; for (let n = 0; n < t.length; n++) { const i = t[n]; r += Re[(i & 240) >> 4] + Re[i & 15]; } return r; } /*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) */ function jr(e) { return e instanceof Uint8Array || ArrayBuffer.isView(e) && e.constructor.name === "Uint8Array"; } function _e(e) { if (!Number.isSafeInteger(e) || e < 0) throw new Error("positive integer expected, got " + e); } function ie(e, ...t) { if (!jr(e)) throw new Error("Uint8Array expected"); if (t.length > 0 && !t.includes(e.length)) throw new Error("Uint8Array expected of length " + t + ", got length=" + e.length); } function Ze(e, t = !0) { if (e.destroyed) throw new Error("Hash instance has been destroyed"); if (t && e.finished) throw new Error("Hash#digest() has already been called"); } function Dr(e, t) { ie(e); const r = t.outputLen; if (e.length < r) throw new Error("digestInto() expects output buffer of length at least " + r); } function br(e) { return new Uint32Array(e.buffer, e.byteOffset, Math.floor(e.byteLength / 4)); } function ct(...e) { for (let t = 0; t < e.length; t++) e[t].fill(0); } const Er = new Uint8Array(new Uint32Array([287454020]).buffer)[0] === 68; function kr(e) { return e << 24 & 4278190080 | e << 8 & 16711680 | e >>> 8 & 65280 | e >>> 24 & 255; } function zr(e) { for (let t = 0; t < e.length; t++) e[t] = kr(e[t]); return e; } const We = Er ? (e) => e : zr; function vr(e) { if (typeof e != "string") throw new Error("string expected"); return new Uint8Array(new TextEncoder().encode(e)); } function ht(e) { return typeof e == "string" && (e = vr(e)), ie(e), e; } class Tr { } function Sr(e) { const t = (n) => e().update(ht(n)).digest(), r = e(); return t.outputLen = r.outputLen, t.blockLen = r.blockLen, t.create = () => e(), t; } const te = /* @__PURE__ */ BigInt(2 ** 32 - 1), Ve = /* @__PURE__ */ BigInt(32); function Cr(e, t = !1) { return t ? { h: Number(e & te), l: Number(e >> Ve & te) } : { h: Number(e >> Ve & te) | 0, l: Number(e & te) | 0 }; } function xr(e, t = !1) { const r = e.length; let n = new Uint32Array(r), i = new Uint32Array(r); for (let o = 0; o < r; o++) { const { h: s, l: a } = Cr(e[o], t); [n[o], i[o]] = [s, a]; } return [n, i]; } const $r = (e, t, r) => e << r | t >>> 32 - r, Or = (e, t, r) => t << r | e >>> 32 - r, Lr = (e, t, r) => t << r - 32 | e >>> 64 - r, Ur = (e, t, r) => e << r - 32 | t >>> 64 - r, Yr = BigInt(0), V = BigInt(1), Qr = BigInt(2), Pr = BigInt(7), Br = BigInt(256), Rr = BigInt(113), lt = [], ut = [], dt = []; for (let e = 0, t = V, r = 1, n = 0; e < 24; e++) { [r, n] = [n, (2 * r + 3 * n) % 5], lt.push(2 * (5 * n + r)), ut.push((e + 1) * (e + 2) / 2 % 64); let i = Yr; for (let o = 0; o < 7; o++) t = (t << V ^ (t >> Pr) * Rr) % Br, t & Qr && (i ^= V << (V << /* @__PURE__ */ BigInt(o)) - V); dt.push(i); } const wt = xr(dt, !0), _r = wt[0], Zr = wt[1], Fe = (e, t, r) => r > 32 ? Lr(e, t, r) : $r(e, t, r), Ge = (e, t, r) => r > 32 ? Ur(e, t, r) : Or(e, t, r); function Wr(e, t = 24) { const r = new Uint32Array(10); for (let n = 24 - t; n < 24; n++) { for (let s = 0; s < 10; s++) r[s] = e[s] ^ e[s + 10] ^ e[s + 20] ^ e[s + 30] ^ e[s + 40]; for (let s = 0; s < 10; s += 2) { const a = (s + 8) % 10, h = (s + 2) % 10, c = r[h], l = r[h + 1], u = Fe(c, l, 1) ^ r[a], w = Ge(c, l, 1) ^ r[a + 1]; for (let g = 0; g < 50; g += 10) e[s + g] ^= u, e[s + g + 1] ^= w; } let i = e[2], o = e[3]; for (let s = 0; s < 24; s++) { const a = ut[s], h = Fe(i, o, a), c = Ge(i, o, a), l = lt[s]; i = e[l], o = e[l + 1], e[l] = h, e[l + 1] = c; } for (let s = 0; s < 50; s += 10) { for (let a = 0; a < 10; a++) r[a] = e[s + a]; for (let a = 0; a < 10; a++) e[s + a] ^= ~r[(a + 2) % 10] & r[(a + 4) % 10]; } e[0] ^= _r[n], e[1] ^= Zr[n]; } ct(r); } class ze extends Tr { // NOTE: we accept arguments in bytes instead of bits here. constructor(t, r, n, i = !1, o = 24) { if (super(), this.pos = 0, this.posOut = 0, this.finished = !1, this.destroyed = !1, this.enableXOF = !1, this.blockLen = t, this.suffix = r, this.outputLen = n, this.enableXOF = i, this.rounds = o, _e(n), !(0 < t && t < 200)) throw new Error("only keccak-f1600 function is supported"); this.state = new Uint8Array(200), this.state32 = br(this.state); } clone() { return this._cloneInto(); } keccak() { We(this.state32), Wr(this.state32, this.rounds), We(this.state32), this.posOut = 0, this.pos = 0; } update(t) { Ze(this), t = ht(t), ie(t); const { blockLen: r, state: n } = this, i = t.length; for (let o = 0; o < i; ) { const s = Math.min(r - this.pos, i - o); for (let a = 0; a < s; a++) n[this.pos++] ^= t[o++]; this.pos === r && this.keccak(); } return this; } finish() { if (this.finished) return; this.finished = !0; const { state: t, suffix: r, pos: n, blockLen: i } = this; t[n] ^= r, r & 128 && n === i - 1 && this.keccak(), t[i - 1] ^= 128, this.keccak(); } writeInto(t) { Ze(this, !1), ie(t), this.finish(); const r = this.state, { blockLen: n } = this; for (let i = 0, o = t.length; i < o; ) { this.posOut >= n && this.keccak(); const s = Math.min(n - this.posOut, o - i); t.set(r.subarray(this.posOut, this.posOut + s), i), this.posOut += s, i += s; } return t; } xofInto(t) { if (!this.enableXOF) throw new Error("XOF is not possible for this instance"); return this.writeInto(t); } xof(t) { return _e(t), this.xofInto(new Uint8Array(t)); } digestInto(t) { if (Dr(t, this), this.finished) throw new Error("digest() was already called"); return this.writeInto(t), this.destroy(), t; } digest() { return this.digestInto(new Uint8Array(this.outputLen)); } destroy() { this.destroyed = !0, ct(this.state); } _cloneInto(t) { const { blockLen: r, suffix: n, outputLen: i, rounds: o, enableXOF: s } = this; return t || (t = new ze(r, n, i, s, o)), t.state32.set(this.state32), t.pos = this.pos, t.posOut = this.posOut, t.finished = this.finished, t.rounds = o, t.suffix = n, t.outputLen = i, t.enableXOF = s, t.destroyed = this.destroyed, t; } } const Vr = (e, t, r) => Sr(() => new ze(t, e, r)), Fr = Vr(1, 136, 256 / 8); let gt = !1; const yt = function(e) { return Fr(e); }; let ft = yt; function K(e) { const t = ke(e, "data"); return Ar(ft(t)); } K._ = yt; K.lock = function() { gt = !0; }; K.register = function(e) { if (gt) throw new TypeError("keccak256 is locked"); ft = e; }; Object.freeze(K); const Gr = BigInt(0), Hr = BigInt(36); function He(e) { e = e.toLowerCase(); const t = e.substring(2).split(""), r = new Uint8Array(40); for (let i = 0; i < 40; i++) r[i] = t[i].charCodeAt(0); const n = ke(K(r)); for (let i = 0; i < 40; i += 2) n[i >> 1] >> 4 >= 8 && (t[i] = t[i].toUpperCase()), (n[i >> 1] & 15) >= 8 && (t[i + 1] = t[i + 1].toUpperCase()); return "0x" + t.join(""); } const ve = {}; for (let e = 0; e < 10; e++) ve[String(e)] = String(e); for (let e = 0; e < 26; e++) ve[String.fromCharCode(65 + e)] = String(10 + e); const Je = 15; function Jr(e) { e = e.toUpperCase(), e = e.substring(4) + e.substring(0, 2) + "00"; let t = e.split("").map((n) => ve[n]).join(""); for (; t.length >= Je; ) { let n = t.substring(0, Je); t = parseInt(n, 10) % 97 + t.substring(n.length); } let r = String(98 - parseInt(t, 10) % 97); for (; r.length < 2; ) r = "0" + r; return r; } const Xr = function() { const e = {}; for (let t = 0; t < 36; t++) { const r = "0123456789abcdefghijklmnopqrstuvwxyz"[t]; e[r] = BigInt(t); } return e; }(); function qr(e) { e = e.toLowerCase(); let t = Gr; for (let r = 0; r < e.length; r++) t = t * Hr + Xr[e[r]]; return t; } function x(e) { if (F(typeof e == "string", "invalid address", "address", e), e.match(/^(0x)?[0-9a-fA-F]{40}$/)) { e.startsWith("0x") || (e = "0x" + e); const t = He(e); return F(!e.match(/([A-F].*[a-f])|([a-f].*[A-F])/) || t === e, "bad address checksum", "address", e), t; } if (e.match(/^XE[0-9]{2}[0-9A-Za-z]{30,31}$/)) { F(e.substring(2, 4) === Jr(e), "bad icap checksum", "address", e); let t = qr(e.substring(4)).toString(16); for (; t.length < 40; ) t = "0" + t; return He("0x" + t); } F(!1, "invalid address", "address", e); } class Kr { constructor() { d(this, "type", "argent"); d(this, "platform", "starknet"); d(this, "wallet"); d(this, "account"); d(this, "connectedAccounts", []); } isAvailable() { return typeof window < "u" && !!window.starknet_argentX; } getInfo() { const t = this.isAvailable(); return { type: this.type, available: t, version: t ? window.starknet_argentX?.version || "Unknown" : void 0, chainId: t ? window.starknet_argentX?.chainId : void 0, name: "Argent", platform: this.platform }; } async connect() { if (this.account) return { success: !0, wallet: this.type, account: this.account }; try { if (!this.isAvailable()) throw new Error("Argent is not available"); const t = window.starknet_argentX; if (!t) throw new Error("No wallet found"); const r = await t.request({ type: "wallet_requestAccounts", params: { silent_mode: !1 } }); if (!r || r.length === 0) throw new Error("No accounts found"); return this.wallet = t, this.account = r[0], this.connectedAccounts = r, { success: !0, wallet: this.type, account: this.account }; } catch (t) { return console.error("Error connecting to Argent:", t), { success: !1, wallet: this.type, error: t.message || "Unknown error" }; } } getConnectedAccounts() { return this.connectedAccounts; } async signTypedData(t) { try { if (!this.isAvailable() || !this.wallet) throw new Error("Argent is not connected"); const r = await this.wallet.request({ type: "wallet_signTypedData", params: t }); return { success: !0, wallet: this.type, result: r }; } catch (r) { return console.error("Error signing typed data with Argent:", r), { success: !1, wallet: this.type, error: r.message || "Unknown error" }; } } async sendTransaction(t) { if (!this.wallet) throw new Error("No wallet found"); try { const r = await this.wallet.request({ type: "wallet_addInvokeTransaction", params: { calls: t } }); return { success: !0, wallet: this.type, result: r }; } catch (r) { return console.error("Error sending transaction with Argent:", r), { success: !1, wallet: this.type, error: r.message || "Unknown error" }; } } async switchChain(t) { if (!this.wallet) throw new Error("No wallet found"); return await this.wallet.request({ type: "wallet_switchStarknetChain", params: { chainId: t } }); } async getBalance(t) { try { if (!this.isAvailable() || !this.wallet) throw new Error("Argent is not connected"); return { success: !0, wallet: this.type, result: "Implement based on Argent API" }; } catch (r) { return console.error("Error getting balance from Argent:", r), { success: !1, wallet: this.type, error: r.message || "Unknown error" }; } } async waitForTransaction(t, r) { return { success: !1, wallet: this.type, error: "waitForTransaction not supported for Argent wallet" }; } } function en(e) { if (typeof window > "u") return; const t = (r) => e(r.detail); return window.addEventListener("eip6963:announceProvider", t), window.dispatchEvent(new CustomEvent("eip6963:requestProvider")), () => window.removeEventListener("eip6963:announceProvider", t); } function tn() { const e = /* @__PURE__ */ new Set(); let t = []; const r = () => en((i) => { t.some(({ info: o }) => o.uuid === i.info.uuid) || (t = [...t, i], e.forEach((o) => o(t, { added: [i] }))); }); let n = r(); return { _listeners() { return e; }, clear() { e.forEach((i) => i([], { removed: [...t] })), t = []; }, destroy() { this.clear(), e.clear(), n?.(); }, findProvider({ rdns: i }) { return t.find((o) => o.info.rdns === i); }, getProviders() { return t; }, reset() { this.clear(), n?.(), n = r(); }, subscribe(i, { emitImmediately: o } = {}) { return e.add(i), o && i(t, { added: t }), () => e.delete(i); } }; } const rn = { "0x1": "ethereum", // ethereum mainnet "0xaa36a7": "ethereum", // ethereum sepolia "0x14a34": "base", // base mainnet "0x2105": "base", // base sepolia "0x66eee": "arbitrum", // arbitrum mainnet "0xa4b1": "arbitrum", // arbitrum sepolia "0xa": "optimism", // op mainnet "0xaa37dc": "optimism", // op sepolia [Q.StarknetChainId.SN_MAIN]: "starknet", [Q.StarknetChainId.SN_SEPOLIA]: "starknet" }, ge = (e) => { const t = Ot.toHex(e), r = rn[t]; return r || console.warn(`Unknown chain ID: ${t}`), r; }; class Te { constructor() { d(this, "platform"); d(this, "account"); d(this, "store", tn()); d(this, "provider"); d(this, "connectedAccounts", []); d(this, "initialized", !1); this.initializeIfAvailable(); } getProvider() { return this.provider || (this.provider = this.store.getProviders().find((t) => t.info.rdns === this.rdns)), this.provider; } getEthereumProvider() { const t = this.getProvider(); return t ? t.provider : this.rdns === "io.metamask" && typeof window < "u" && window.ethereum?.isMetaMask ? window.ethereum : null; } initializeIfAvailable() { this.getProvider() && !this.initialized && (this.initialized = !0, this.initializeProvider()); } initializeProvider() { const t = this.getProvider(); t && (t.provider.request({ method: "eth_accounts" }).then((r) => { this.connectedAccounts = r.map(x), r.length > 0 && (this.account = x(r[0])); }).catch(console.error), t.provider.request({ method: "eth_chainId" }).then((r) => { this.platform = ge(r); }).catch(console.error), t.provider?.on("chainChanged", (r) => { this.platform = ge(r); }), t.provider?.on("accountsChanged", (r) => { r && (this.connectedAccounts = r.map((n) => x(n)), this.account = r.length > 0 ? x(r[0]) : void 0); })); } isAvailable() { const t = this.getProvider(); return !t && this.rdns === "io.metamask" && typeof window < "u" ? !!window.ethereum?.isMetaMask : (t && !this.initialized && this.initializeIfAvailable(), typeof window < "u" && !!t); } getInfo() { const t = this.isAvailable(); return { type: this.type, available: t, version: t ? window.ethereum?.version || "Unknown" : void 0, chainId: t ? window.ethereum?.chainId : void 0, name: this.displayName, platform: this.platform, connectedAccounts: this.connectedAccounts }; } getConnectedAccounts() { return this.connectedAccounts; } async connect(t) { if (t && this.connectedAccounts.includes(x(t)) && (this.account = x(t)), this.account) return { success: !0, wallet: this.type, account: this.account }; try { if (!this.isAvailable()) throw new Error(`${this.displayName} is not available`); let r; const n = this.getProvider(); if (n ? r = n.provider : this.rdns === "io.metamask" && window.ethereum?.isMetaMask && (r = window.ethereum), !r) throw new Error(`${this.displayName} provider not found`); const i = await r.request({ method: "eth_requestAccounts" }); if (i && i.length > 0) return this.account = x(i[0]), this.connectedAccounts = i.map(x), !n && this.rdns === "io.metamask" && (this.provider = { info: { uuid: "metamask-fallback", name: "MetaMask", icon: "data:image/svg+xml;base64,", rdns: "io.metamask" }, provider: r }, this.initializeIfAvailable()), { success: !0, wallet: this.type, account: this.account }; throw new Error("No accounts found"); } catch (r) { return console.error(`Error connecting to ${this.displayName}:`, r), { success: !1, wallet: this.type, error: r.message || "Unknown error" }; } } async signTransaction(t) { try { if (!this.isAvailable() || !this.account) throw new Error(`${this.displayName} is not connected`); const r = this.getEthereumProvider(); if (!r) throw new Error(`${this.displayName} is not connected`); const n = await r.request({ method: "eth_sendTransaction", params: [t] }); return { success: !0, wallet: this.type, result: n }; } catch (r) { return console.error( `Error signing transaction with ${this.displayName}:`, r ), { success: !1, wallet: this.type, error: r.message || "Unknown error" }; } } async signMessage(t, r) { try { if (!this.isAvailable() || !this.account) throw new Error(`${this.displayName} is not connected`); const n = this.getEthereumProvider(); if (!n) throw new Error(`${this.displayName} provider not found`); const i = await n.request({ method: "personal_sign", params: [t, r || this.account] }); return { success: !0, wallet: this.type, result: i }; } catch (n) { return console.error(`Error signing message with ${this.displayName}:`, n), { success: !1, wallet: this.type, error: n.message || "Unknown error" }; } } async signTypedData(t) { try { if (!this.isAvailable() || !this.account) throw new Error(`${this.displayName} is not connected`); const r = this.getEthereumProvider(); if (!r) throw new Error(`${this.displayName} is not connected`); const n = await r.request({ method: "eth_signTypedData_v4", params: [this.account, JSON.stringify(t)] }); return { success: !0, wallet: this.type, result: n }; } catch (r) { return console.error( `Error signing typed data with ${this.displayName}:`, r ), { success: !1, wallet: this.type, error: r.message || "Unknown error" }; } } async sendTransaction(t) { try { if (!this.isAvailable() || !this.account) throw new Error(`${this.displayName} is not connected`); const r = this.getEthereumProvider(); if (!r) throw new Error(`${this.displayName} is not connected`); const n = await r.request({ method: "eth_sendTransaction", params: [t] }); return { success: !0, wallet: this.type, result: n }; } catch (r) { return console.error( `Error sending transaction with ${this.displayName}:`, r ), { success: !1, wallet: this.type, error: r.message || "Unknown error" }; } } async switchChain(t) { try { if (!this.isAvailable()) throw new Error(`${this.displayName} is not available`); const r = this.getEthereumProvider(); if (!r) throw new Error(`${this.displayName} is not connected`); try { return await r.request({ method: "wallet_switchEthereumChain", params: [{ chainId: t }] }), this.platform = ge(t), !0; } catch (n) { throw n.code === 4902 && console.warn(`Chain not added to ${this.displayName}`), n; } } catch (r) { return console.error(`Error switching chain for ${this.displayName}:`, r), !1; } } async getBalance(t) { try { if (!this.isAvailable() || !this.account) throw new Error(`${this.displayName} is not connected`); if (t) return { success: !1, wallet: this.type, error: "Not implemented for ERC20" }; { const r = this.getEthereumProvider(); if (!r) throw new Error(`${this.displayName} is not connected`); const n = await r.request({ method: "eth_getBalance", params: [this.account, "latest"] }); return { success: !0, wallet: this.type, result: n }; } } catch (r) { return console.error(`Error getting balance from ${this.displayName}:`, r), { success: !1, wallet: this.type, error: r.message || "Unknown error" }; } } async waitForTransaction(t, r = 6e4) { try { if (!this.isAvailable()) throw new Error(`${this.displayName} is not connected`); const n = this.getEthereumProvider(); if (!n) throw new Error(`${this.displayName} is not connected`); const i = Date.now(), o = 1e3; for (; Date.now() - i < r; ) { const s = await n.request({ method: "eth_getTransactionReceipt", params: [t] }); if (s) return { success: !0, wallet: this.type, result: s }; await new Promise((a) => setTimeout(a, o)); } throw new Error("Transaction confirmation timed out"); } catch (n) { return console.error( `Error waiting for transaction with ${this.displayName}:`, n ), { success: !1, wallet: this.type, error: n.message || "Unknown error" }; } } } class nn extends Te { constructor() { super(...arguments); d(this,