From ec29d600ff4ba2786799dc5f976ffd97ca62d27c Mon Sep 17 00:00:00 2001 From: bluecco Date: Thu, 7 Dec 2023 16:02:42 +0100 Subject: [PATCH 01/13] fix: use rpc provider instead of sequencer for webwallet --- src/connectors/webwallet/constants.ts | 6 +++++ .../helpers/mapTargetUrlToNodeUrl.ts | 24 +++++++++++++++++++ .../getWebWalletStarknetObject.ts | 8 +++---- 3 files changed, 34 insertions(+), 4 deletions(-) create mode 100644 src/connectors/webwallet/helpers/mapTargetUrlToNodeUrl.ts diff --git a/src/connectors/webwallet/constants.ts b/src/connectors/webwallet/constants.ts index d209e53..f1a69bd 100644 --- a/src/connectors/webwallet/constants.ts +++ b/src/connectors/webwallet/constants.ts @@ -14,3 +14,9 @@ export const DEFAULT_WEBWALLET_ICON = ` ` + +export const RPC_NODE_URL_TESTNET = + "https://api.hydrogen.argent47.net/v1/starknet/goerli/rpc/v0.5" + +export const RPC_NODE_URL_MAINNET = + "https://cloud.argent-api.com/v1/starknet/goerli/rpc/v0.5" diff --git a/src/connectors/webwallet/helpers/mapTargetUrlToNodeUrl.ts b/src/connectors/webwallet/helpers/mapTargetUrlToNodeUrl.ts new file mode 100644 index 0000000..d3f83de --- /dev/null +++ b/src/connectors/webwallet/helpers/mapTargetUrlToNodeUrl.ts @@ -0,0 +1,24 @@ +import { RPC_NODE_URL_MAINNET, RPC_NODE_URL_TESTNET } from "../constants" + +export function mapTargetUrlToNodeUrl(target: string): string { + try { + const { origin } = new URL(target) + if (origin.includes("localhost") || origin.includes("127.0.0.1")) { + return RPC_NODE_URL_TESTNET + } + if (origin.includes("hydrogen")) { + return RPC_NODE_URL_TESTNET + } + if (origin.includes("staging")) { + return RPC_NODE_URL_MAINNET + } + if (origin.includes("argent.xyz")) { + return RPC_NODE_URL_MAINNET + } + } catch (e) { + console.warn( + "Could not determine rpc nodeUrl from target URL, defaulting to mainnet", + ) + } + return RPC_NODE_URL_MAINNET +} diff --git a/src/connectors/webwallet/starknetWindowObject/getWebWalletStarknetObject.ts b/src/connectors/webwallet/starknetWindowObject/getWebWalletStarknetObject.ts index ffca03d..a7ae80e 100644 --- a/src/connectors/webwallet/starknetWindowObject/getWebWalletStarknetObject.ts +++ b/src/connectors/webwallet/starknetWindowObject/getWebWalletStarknetObject.ts @@ -1,7 +1,7 @@ import type { CreateTRPCProxyClient } from "@trpc/client" -import { SequencerProvider } from "starknet" +import { RpcProvider } from "starknet" -import { mapTargetUrlToNetworkId } from "../../../helpers/mapTargetUrlToNetworkId" +import { mapTargetUrlToNodeUrl } from "../helpers/mapTargetUrlToNodeUrl" import type { AppRouter } from "../helpers/trpc" import type { WebWalletStarknetWindowObject } from "./argentStarknetWindowObject" import { getArgentStarknetWindowObject } from "./argentStarknetWindowObject" @@ -15,8 +15,8 @@ export const getWebWalletStarknetObject = async ( throw new Error("window is not defined") } - const network = mapTargetUrlToNetworkId(target) - const defaultProvider = new SequencerProvider({ network }) + const nodeUrl = mapTargetUrlToNodeUrl(target) + const defaultProvider = new RpcProvider({ nodeUrl }) const starknetWindowObject = getArgentStarknetWindowObject( { host: globalWindow.location.origin, From 445127a8146c32560f45f5b3ed84b17a4c52097a Mon Sep 17 00:00:00 2001 From: semantic-release-bot Date: Thu, 7 Dec 2023 15:13:26 +0000 Subject: [PATCH 02/13] chore(release): 1.0.22 [skip ci] ## [1.0.22](https://github.com/argentlabs/starknetkit/compare/v1.0.21...v1.0.22) (2023-12-07) ### Bug Fixes * use rpc provider instead of sequencer for webwallet ([ec29d60](https://github.com/argentlabs/starknetkit/commit/ec29d600ff4ba2786799dc5f976ffd97ca62d27c)) --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index b41c414..1e26072 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "starknetkit", - "version": "1.0.21", + "version": "1.0.22", "repository": "github:argentlabs/starknetkit", "private": false, "browser": { From 8f288d3d7a9182d03a7e1e13d8cf33c5002fd47f Mon Sep 17 00:00:00 2001 From: Vladut Date: Thu, 7 Dec 2023 19:09:35 +0200 Subject: [PATCH 03/13] chore: update sn.js version --- package.json | 2 +- pnpm-lock.yaml | 47 ++++++++++++++++++++++++----------------------- 2 files changed, 25 insertions(+), 24 deletions(-) diff --git a/package.json b/package.json index 1e26072..350890a 100644 --- a/package.json +++ b/package.json @@ -104,7 +104,7 @@ "zod": "^3.20.6" }, "peerDependencies": { - "starknet": "^5.18.0" + "starknet": "^5.24.3" }, "gitHead": "b16688a8638cc138938e74e1a39d004760165d75" } diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 2bb2187..ebeffe8 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -28,13 +28,13 @@ dependencies: version: 3.3.0 get-starknet-core: specifier: ^3.1.0 - version: 3.1.0(starknet@5.18.0) + version: 3.1.0(starknet@5.24.3) lodash-es: specifier: ^4.17.21 version: 4.17.21 starknet: - specifier: ^5.18.0 - version: 5.18.0 + specifier: ^5.24.3 + version: 5.24.3 svelte-forms: specifier: ^2.3.1 version: 2.3.1 @@ -911,14 +911,10 @@ packages: glob: 7.1.7 dev: true - /@noble/curves@1.0.0: - resolution: {integrity: sha512-2upgEu0iLiDVDZkNLeFV2+ht0BAVgQnEmCk6JsOch9Rp8xfkMCbvbAZlA2pBHQc73dbl+vFOXfqkf4uemdn0bw==} + /@noble/curves@1.2.0: + resolution: {integrity: sha512-oYclrNgRaM9SsBUBVbb8M6DTV7ZHRTKugureoYEncY5c65HOmRzvSiTE3y5CYaPYJA/GVkrhXEoF0M3Ya9PMnw==} dependencies: - '@noble/hashes': 1.3.0 - dev: false - - /@noble/hashes@1.3.0: - resolution: {integrity: sha512-ilHEACi9DwqJB0pw7kv+Apvh50jiiSyR/cQ3y4W7lOR5mhvn/50FLUfsnfJz0BDZtl/RR16kXvptiv6q1msYZg==} + '@noble/hashes': 1.3.2 dev: false /@noble/hashes@1.3.2: @@ -1124,6 +1120,17 @@ packages: string-argv: 0.3.2 dev: true + /@scure/base@1.1.3: + resolution: {integrity: sha512-/+SgoRjLq7Xlf0CWuLHq2LUZeL/w65kfzAPG5NH9pcmBhs+nunQTn4gvdwgMTIXnt9b2C/1SeL2XiysZEyIC9Q==} + dev: false + + /@scure/starknet@0.3.0: + resolution: {integrity: sha512-Ma66yZlwa5z00qI5alSxdWtIpky5LBhy22acVFdoC5kwwbd9uDyMWEYzWHdNyKmQg9t5Y2UOXzINMeb3yez+Gw==} + dependencies: + '@noble/curves': 1.2.0 + '@noble/hashes': 1.3.2 + dev: false + /@semantic-release/commit-analyzer@10.0.4(semantic-release@21.1.1): resolution: {integrity: sha512-pFGn99fn8w4/MHE0otb2A/l5kxgOuxaaauIh4u30ncoTJuqWj4hXTgEJ03REqjS+w1R2vPftSsO26WC61yOcpw==} engines: {node: '>=18'} @@ -3717,12 +3724,12 @@ packages: has-symbols: 1.0.3 dev: true - /get-starknet-core@3.1.0(starknet@5.18.0): + /get-starknet-core@3.1.0(starknet@5.24.3): resolution: {integrity: sha512-SPeYnzqKRXuukNoEr5aobxBmvhUSt4uWs6kFhMXl+3fG2R43u2D2DreDkA1n6T5DF10x5zLogldiHqn/jGlxEA==} peerDependencies: starknet: ^5.14.1 dependencies: - starknet: 5.18.0 + starknet: 5.24.3 dev: false /get-stream@6.0.1: @@ -4857,13 +4864,6 @@ packages: engines: {node: '>= 8'} dev: true - /micro-starknet@0.2.3: - resolution: {integrity: sha512-6XBcC+GerlwJSR4iA0VaeXtS2wrayWFcA4PEzrJPMuFmWCaUtuGIq5K/DB5F/XgnL54/zl2Bxo690Lj7mYVA8A==} - dependencies: - '@noble/curves': 1.0.0 - '@noble/hashes': 1.3.2 - dev: false - /micromatch@4.0.5: resolution: {integrity: sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==} engines: {node: '>=8.6'} @@ -6128,13 +6128,14 @@ packages: resolution: {integrity: sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==} dev: true - /starknet@5.18.0: - resolution: {integrity: sha512-2b5+F+kfp8fTBAfBpHNmtjhuljZb3P2JMhubP/KWIJAGXwBAalPklOwEYY7Bb2slkPjfkDH0kPxI4037sQcQ+Q==} + /starknet@5.24.3: + resolution: {integrity: sha512-v0TuaNc9iNtHdbIRzX372jfQH1vgx2rwBHQDMqK4DqjJbwFEE5dog8Go6rGiZVW750NqRSWrZ7ahqyRNc3bscg==} dependencies: - '@noble/curves': 1.0.0 + '@noble/curves': 1.2.0 + '@scure/base': 1.1.3 + '@scure/starknet': 0.3.0 isomorphic-fetch: 3.0.0 lossless-json: 2.0.11 - micro-starknet: 0.2.3 pako: 2.1.0 url-join: 4.0.1 transitivePeerDependencies: From 583ba85e5137728600d8bdc4d3de51da97f4b04d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?David=20Vodr=C3=A1=C5=BEka?= <36418132+DaveVodrazka@users.noreply.github.com> Date: Fri, 8 Dec 2023 15:01:58 +0100 Subject: [PATCH 04/13] fix: prevent creating multiple root divs --- src/main.ts | 30 ++++++++++++++++++++++++------ 1 file changed, 24 insertions(+), 6 deletions(-) diff --git a/src/main.ts b/src/main.ts index ddbb659..6d3d51e 100644 --- a/src/main.ts +++ b/src/main.ts @@ -82,15 +82,33 @@ export const connect = async ({ storeVersion, }) - const element = document.createElement("div") - document.body.appendChild(element) - const target = element.attachShadow({ mode: "open" }) - - target.innerHTML = `` + const getTarget = (): ShadowRoot => { + const modalId = "starknetkit-modal" + const existingElement = document.getElementById(modalId) + + if (existingElement) { + if (existingElement.shadowRoot) { + // element already exists, use the existing as target + return existingElement.shadowRoot + } + // element exists but shadowRoot cannot be accessed + // delete the element and create new + existingElement.remove() + } + + const element = document.createElement("div") + // set id for future retrieval + element.id = modalId + document.body.appendChild(element) + const target = element.attachShadow({ mode: "open" }) + target.innerHTML = `` + + return target + } return new Promise((resolve) => { const modal = new Modal({ - target, + target: getTarget(), props: { dappName, callback: async (value: StarknetWindowObject | null) => { From 292292c5a3ff35af23c145d46f57c7ea35846ac7 Mon Sep 17 00:00:00 2001 From: semantic-release-bot Date: Tue, 12 Dec 2023 11:47:15 +0000 Subject: [PATCH 05/13] chore(release): 1.0.23 [skip ci] ## [1.0.23](https://github.com/argentlabs/starknetkit/compare/v1.0.22...v1.0.23) (2023-12-12) ### Bug Fixes * prevent creating multiple root divs ([583ba85](https://github.com/argentlabs/starknetkit/commit/583ba85e5137728600d8bdc4d3de51da97f4b04d)) --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index 350890a..bfda235 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "starknetkit", - "version": "1.0.22", + "version": "1.0.23", "repository": "github:argentlabs/starknetkit", "private": false, "browser": { From 5b2717b5eb2c04fbdd51f69d9e98d70203ed3be2 Mon Sep 17 00:00:00 2001 From: bluecco Date: Tue, 12 Dec 2023 15:29:12 +0100 Subject: [PATCH 06/13] fix: argent mobile connector icon url parameter --- src/connectors/argentMobile/index.ts | 5 ++++- src/connectors/argentMobile/modal/login.ts | 4 +++- 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/src/connectors/argentMobile/index.ts b/src/connectors/argentMobile/index.ts index e1939d8..bc9512b 100644 --- a/src/connectors/argentMobile/index.ts +++ b/src/connectors/argentMobile/index.ts @@ -25,6 +25,7 @@ export interface ArgentMobileConnectorOptions { chainId?: constants.NetworkName description?: string url?: string + icons?: string[] } export class ArgentMobileConnector extends Connector { @@ -143,13 +144,15 @@ export class ArgentMobileConnector extends Connector { private async ensureWallet(): Promise { const { getStarknetWindowObject } = await import("./modal") - const { chainId, projectId, dappName, description, url } = this._options + const { chainId, projectId, dappName, description, url, icons } = + this._options const options = { chainId: chainId ?? constants.NetworkName.SN_MAIN, name: dappName, projectId: projectId ?? DEFAULT_PROJECT_ID, description, url, + icons, } if (projectId === DEFAULT_PROJECT_ID) { diff --git a/src/connectors/argentMobile/modal/login.ts b/src/connectors/argentMobile/modal/login.ts index 8db7d64..6d63548 100644 --- a/src/connectors/argentMobile/modal/login.ts +++ b/src/connectors/argentMobile/modal/login.ts @@ -15,6 +15,7 @@ export interface IArgentLoginOptions { name?: string description?: string url?: string + icons?: string[] chainId?: string | number rpcUrl?: string bridgeUrl?: string @@ -34,6 +35,7 @@ export const login = async ( mobileUrl = getMobileUrl(chainId), modalType = "overlay", url, + icons, walletConnect, }: IArgentLoginOptions, Adapter: new (options: NamespaceAdapterOptions) => TAdapter, @@ -55,7 +57,7 @@ export const login = async ( name: name ?? "Unknown dapp", description: description ?? "Unknown dapp description", url: url ?? "#", - icons: ["https://walletconnect.com/walletconnect-logo.png"], + icons: icons ?? [], ...walletConnect?.metadata, }, } From 4c997a641c9263d01edace0f08ce3afa994a2b79 Mon Sep 17 00:00:00 2001 From: semantic-release-bot Date: Wed, 13 Dec 2023 10:58:56 +0000 Subject: [PATCH 07/13] chore(release): 1.0.24 [skip ci] ## [1.0.24](https://github.com/argentlabs/starknetkit/compare/v1.0.23...v1.0.24) (2023-12-13) ### Bug Fixes * argent mobile connector icon url parameter ([5b2717b](https://github.com/argentlabs/starknetkit/commit/5b2717b5eb2c04fbdd51f69d9e98d70203ed3be2)) --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index bfda235..3ce98fe 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "starknetkit", - "version": "1.0.23", + "version": "1.0.24", "repository": "github:argentlabs/starknetkit", "private": false, "browser": { From acdbf1c7d77d68286df81fb3ee74ee93424c47d4 Mon Sep 17 00:00:00 2001 From: bluecco Date: Wed, 13 Dec 2023 14:29:25 +0100 Subject: [PATCH 08/13] fix: allow custom provider for injected connectors --- src/connectors/injected/index.ts | 11 ++++++++++- src/helpers/defaultConnectors.ts | 7 +++++-- src/main.ts | 2 ++ src/types/modal.ts | 2 ++ 4 files changed, 19 insertions(+), 3 deletions(-) diff --git a/src/connectors/injected/index.ts b/src/connectors/injected/index.ts index fb29653..e90ee8b 100644 --- a/src/connectors/injected/index.ts +++ b/src/connectors/injected/index.ts @@ -1,5 +1,5 @@ import type { StarknetWindowObject } from "get-starknet-core" -import { AccountInterface, constants } from "starknet" +import { AccountInterface, ProviderInterface, constants } from "starknet" import { ConnectorNotConnectedError, ConnectorNotFoundError, @@ -23,6 +23,8 @@ export interface InjectedConnectorOptions { name?: string /** Wallet icons. */ icon?: ConnectorIcons + /** Provider */ + provider?: ProviderInterface } export class InjectedConnector extends Connector { @@ -211,6 +213,13 @@ export class InjectedConnector extends Connector { const installed = getAvailableWallets(globalThis) const wallet = installed.filter((w) => w.id === this._options.id)[0] if (wallet) { + const { provider } = this._options + if (provider) { + Object.assign(wallet, { + provider, + }) + } + this._wallet = wallet } } diff --git a/src/helpers/defaultConnectors.ts b/src/helpers/defaultConnectors.ts index 5a36195..acda731 100644 --- a/src/helpers/defaultConnectors.ts +++ b/src/helpers/defaultConnectors.ts @@ -1,3 +1,4 @@ +import { ProviderInterface } from "starknet" import { type Connector } from "../connectors" import { ArgentMobileConnector, @@ -9,9 +10,11 @@ import { WebWalletConnector } from "../connectors/webwallet" export const defaultConnectors = ({ argentMobileOptions, webWalletUrl, + provider, }: { argentMobileOptions?: ArgentMobileConnectorOptions webWalletUrl?: string + provider?: ProviderInterface }): Connector[] => { const isSafari = /^((?!chrome|android).)*safari/i.test(navigator.userAgent) @@ -19,10 +22,10 @@ export const defaultConnectors = ({ if (!isSafari) { defaultConnectors.push( - new InjectedConnector({ options: { id: "argentX" } }), + new InjectedConnector({ options: { id: "argentX", provider } }), ) defaultConnectors.push( - new InjectedConnector({ options: { id: "braavos" } }), + new InjectedConnector({ options: { id: "braavos", provider } }), ) } diff --git a/src/main.ts b/src/main.ts index 6d3d51e..cc2be13 100644 --- a/src/main.ts +++ b/src/main.ts @@ -31,6 +31,7 @@ export const connect = async ({ webWalletUrl = DEFAULT_WEBWALLET_URL, argentMobileOptions, connectors = [], + provider, ...restOptions }: ConnectOptions = {}): Promise => { // force null in case it was disconnected from mobile app @@ -40,6 +41,7 @@ export const connect = async ({ ? defaultConnectors({ argentMobileOptions, webWalletUrl, + provider, }) : connectors diff --git a/src/types/modal.ts b/src/types/modal.ts index 91608dd..4325fb6 100644 --- a/src/types/modal.ts +++ b/src/types/modal.ts @@ -1,6 +1,7 @@ import type { GetWalletOptions } from "get-starknet-core" import type { Connector, ConnectorIcons } from "../connectors/connector" import type { ArgentMobileConnectorOptions } from "../connectors/argentMobile" +import { ProviderInterface } from "starknet" export type StoreVersion = "chrome" | "firefox" | "edge" @@ -12,6 +13,7 @@ export interface ConnectOptions extends GetWalletOptions { modalTheme?: "light" | "dark" | "system" storeVersion?: StoreVersion | null webWalletUrl?: string + provider?: ProviderInterface } export type ModalWallet = { From 83b66015e6fe4e92fd558e0fbbd5bfde6b4947f0 Mon Sep 17 00:00:00 2001 From: bluecco Date: Wed, 13 Dec 2023 14:59:01 +0100 Subject: [PATCH 09/13] fix: allow custom provider for webwallet connector --- src/connectors/webwallet/index.ts | 10 ++++++++-- .../starknetWindowObject/getWebWalletStarknetObject.ts | 5 +++-- 2 files changed, 11 insertions(+), 4 deletions(-) diff --git a/src/connectors/webwallet/index.ts b/src/connectors/webwallet/index.ts index 18ddfb8..7e53c8f 100644 --- a/src/connectors/webwallet/index.ts +++ b/src/connectors/webwallet/index.ts @@ -2,7 +2,7 @@ import type { AccountChangeEventHandler, StarknetWindowObject, } from "get-starknet-core" -import type { AccountInterface } from "starknet" +import type { AccountInterface, ProviderInterface } from "starknet" import { Connector, type ConnectorData, @@ -23,6 +23,7 @@ let _wallet: StarknetWindowObject | null = null interface WebWalletConnectorOptions { url?: string + provider?: ProviderInterface } export class WebWalletConnector extends Connector { @@ -163,11 +164,16 @@ export class WebWalletConnector extends Connector { private async ensureWallet(): Promise { const origin = this._options.url || DEFAULT_WEBWALLET_URL + const provider = this._options.provider setPopupOptions({ origin, location: "/interstitialLogin", }) - const wallet = await getWebWalletStarknetObject(origin, trpcProxyClient({})) + const wallet = await getWebWalletStarknetObject( + origin, + trpcProxyClient({}), + provider, + ) _wallet = wallet ?? null this._wallet = _wallet diff --git a/src/connectors/webwallet/starknetWindowObject/getWebWalletStarknetObject.ts b/src/connectors/webwallet/starknetWindowObject/getWebWalletStarknetObject.ts index a7ae80e..90dd22e 100644 --- a/src/connectors/webwallet/starknetWindowObject/getWebWalletStarknetObject.ts +++ b/src/connectors/webwallet/starknetWindowObject/getWebWalletStarknetObject.ts @@ -1,5 +1,5 @@ import type { CreateTRPCProxyClient } from "@trpc/client" -import { RpcProvider } from "starknet" +import { ProviderInterface, RpcProvider } from "starknet" import { mapTargetUrlToNodeUrl } from "../helpers/mapTargetUrlToNodeUrl" import type { AppRouter } from "../helpers/trpc" @@ -9,6 +9,7 @@ import { getArgentStarknetWindowObject } from "./argentStarknetWindowObject" export const getWebWalletStarknetObject = async ( target: string, proxyLink: CreateTRPCProxyClient, + provider?: ProviderInterface, ): Promise => { const globalWindow = typeof window !== "undefined" ? window : undefined if (!globalWindow) { @@ -16,7 +17,7 @@ export const getWebWalletStarknetObject = async ( } const nodeUrl = mapTargetUrlToNodeUrl(target) - const defaultProvider = new RpcProvider({ nodeUrl }) + const defaultProvider = provider ?? new RpcProvider({ nodeUrl }) const starknetWindowObject = getArgentStarknetWindowObject( { host: globalWindow.location.origin, From 8e99cbb793882474015603185eb60515e4159b0a Mon Sep 17 00:00:00 2001 From: bluecco Date: Wed, 13 Dec 2023 14:59:23 +0100 Subject: [PATCH 10/13] fix: allow custom provider for argent mobile connector --- src/connectors/argentMobile/index.ts | 15 ++++++++++++++- .../argentMobile/modal/starknet/adapter.ts | 9 ++------- src/helpers/defaultConnectors.ts | 8 ++++++-- 3 files changed, 22 insertions(+), 10 deletions(-) diff --git a/src/connectors/argentMobile/index.ts b/src/connectors/argentMobile/index.ts index bc9512b..05641f9 100644 --- a/src/connectors/argentMobile/index.ts +++ b/src/connectors/argentMobile/index.ts @@ -2,7 +2,7 @@ import type { AccountChangeEventHandler, StarknetWindowObject, } from "get-starknet-core" -import type { AccountInterface } from "starknet" +import type { AccountInterface, ProviderInterface } from "starknet" import { constants } from "starknet" import { DEFAULT_ARGENT_MOBILE_ICON, DEFAULT_PROJECT_ID } from "./constants" import { @@ -26,6 +26,7 @@ export interface ArgentMobileConnectorOptions { description?: string url?: string icons?: string[] + provider?: ProviderInterface } export class ArgentMobileConnector extends Connector { @@ -153,6 +154,10 @@ export class ArgentMobileConnector extends Connector { description, url, icons, + rpcUrl: + chainId === constants.NetworkName.SN_MAIN + ? "https://cloud.argent-api.com/v1/starknet/goerli/rpc/v0.5" + : "https://api.hydrogen.argent47.net/v1/starknet/goerli/rpc/v0.5", } if (projectId === DEFAULT_PROJECT_ID) { @@ -171,6 +176,14 @@ export class ArgentMobileConnector extends Connector { } const _wallet = await getStarknetWindowObject(options) + + const { provider } = this._options + if (provider) { + Object.assign(_wallet, { + provider, + }) + } + console.log(_wallet.provider) this._wallet = _wallet // wallet connect rpc enable diff --git a/src/connectors/argentMobile/modal/starknet/adapter.ts b/src/connectors/argentMobile/modal/starknet/adapter.ts index 8c4152a..eabd13d 100644 --- a/src/connectors/argentMobile/modal/starknet/adapter.ts +++ b/src/connectors/argentMobile/modal/starknet/adapter.ts @@ -11,7 +11,7 @@ import type { ProviderInterface, SignerInterface, } from "starknet" -import { Provider, constants } from "starknet" +import { RpcProvider, constants } from "starknet" import type { NamespaceAdapterOptions } from "../adapter" import { NamespaceAdapter } from "../adapter" @@ -84,12 +84,7 @@ export class StarknetAdapter this.remoteSigner = new StarknetRemoteSigner(this.walletRpc) - if (rpcUrl) { - this.provider = new Provider({ rpc: { nodeUrl: rpcUrl } }) - } else { - const network = this.getNetworkName(this.chainId) - this.provider = new Provider({ sequencer: { network } }) - } + this.provider = new RpcProvider({ nodeUrl: rpcUrl }) this.account = new StarknetRemoteAccount( this.provider, "", diff --git a/src/helpers/defaultConnectors.ts b/src/helpers/defaultConnectors.ts index acda731..14b6659 100644 --- a/src/helpers/defaultConnectors.ts +++ b/src/helpers/defaultConnectors.ts @@ -29,8 +29,12 @@ export const defaultConnectors = ({ ) } - defaultConnectors.push(new ArgentMobileConnector(argentMobileOptions)) - defaultConnectors.push(new WebWalletConnector({ url: webWalletUrl })) + defaultConnectors.push( + new ArgentMobileConnector({ ...argentMobileOptions, provider }), + ) + defaultConnectors.push( + new WebWalletConnector({ url: webWalletUrl, provider }), + ) return defaultConnectors } From 041751b5f61eb02c6d5774be2c4860168beee906 Mon Sep 17 00:00:00 2001 From: bluecco Date: Wed, 13 Dec 2023 15:09:57 +0100 Subject: [PATCH 11/13] chore: removed console log --- src/connectors/argentMobile/index.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/connectors/argentMobile/index.ts b/src/connectors/argentMobile/index.ts index 05641f9..13dc819 100644 --- a/src/connectors/argentMobile/index.ts +++ b/src/connectors/argentMobile/index.ts @@ -183,7 +183,7 @@ export class ArgentMobileConnector extends Connector { provider, }) } - console.log(_wallet.provider) + this._wallet = _wallet // wallet connect rpc enable From e951459a74020a22273467ba8a227e3cb5bd648f Mon Sep 17 00:00:00 2001 From: bluecco Date: Wed, 13 Dec 2023 15:14:16 +0100 Subject: [PATCH 12/13] fix: rpc urls for mainnet --- src/connectors/argentMobile/index.ts | 2 +- src/connectors/webwallet/constants.ts | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/connectors/argentMobile/index.ts b/src/connectors/argentMobile/index.ts index 13dc819..a3e0524 100644 --- a/src/connectors/argentMobile/index.ts +++ b/src/connectors/argentMobile/index.ts @@ -156,7 +156,7 @@ export class ArgentMobileConnector extends Connector { icons, rpcUrl: chainId === constants.NetworkName.SN_MAIN - ? "https://cloud.argent-api.com/v1/starknet/goerli/rpc/v0.5" + ? "https://cloud.argent-api.com/v1/starknet/mainnet/rpc/v0.5" : "https://api.hydrogen.argent47.net/v1/starknet/goerli/rpc/v0.5", } diff --git a/src/connectors/webwallet/constants.ts b/src/connectors/webwallet/constants.ts index f1a69bd..4642193 100644 --- a/src/connectors/webwallet/constants.ts +++ b/src/connectors/webwallet/constants.ts @@ -19,4 +19,4 @@ export const RPC_NODE_URL_TESTNET = "https://api.hydrogen.argent47.net/v1/starknet/goerli/rpc/v0.5" export const RPC_NODE_URL_MAINNET = - "https://cloud.argent-api.com/v1/starknet/goerli/rpc/v0.5" + "https://cloud.argent-api.com/v1/starknet/mainnet/rpc/v0.5" From f56daf14d9ebbbe52a50f2199a88bf389c53c41a Mon Sep 17 00:00:00 2001 From: semantic-release-bot Date: Wed, 13 Dec 2023 14:25:06 +0000 Subject: [PATCH 13/13] chore(release): 1.0.25 [skip ci] ## [1.0.25](https://github.com/argentlabs/starknetkit/compare/v1.0.24...v1.0.25) (2023-12-13) ### Bug Fixes * allow custom provider for argent mobile connector ([8e99cbb](https://github.com/argentlabs/starknetkit/commit/8e99cbb793882474015603185eb60515e4159b0a)) * allow custom provider for injected connectors ([acdbf1c](https://github.com/argentlabs/starknetkit/commit/acdbf1c7d77d68286df81fb3ee74ee93424c47d4)) * allow custom provider for webwallet connector ([83b6601](https://github.com/argentlabs/starknetkit/commit/83b66015e6fe4e92fd558e0fbbd5bfde6b4947f0)) * rpc urls for mainnet ([e951459](https://github.com/argentlabs/starknetkit/commit/e951459a74020a22273467ba8a227e3cb5bd648f)) --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index 3ce98fe..a0abc33 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "starknetkit", - "version": "1.0.24", + "version": "1.0.25", "repository": "github:argentlabs/starknetkit", "private": false, "browser": {