Skip to content

Commit 9030802

Browse files
authored
Merge pull request #219 from argentlabs/update/starknetjs
refactor: update starknetjs
2 parents 00bc4af + ed9d716 commit 9030802

File tree

7 files changed

+6830
-4110
lines changed

7 files changed

+6830
-4110
lines changed

package.json

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -99,7 +99,7 @@
9999
"@cartridge/controller": "^0.7.13",
100100
"@starknet-io/get-starknet": "^4.0.6",
101101
"@starknet-io/get-starknet-core": "^4.0.6",
102-
"@starknet-io/types-js": "^0.7.10",
102+
"@starknet-io/types-js": "0.8.4",
103103
"@trpc/client": "^10.38.1",
104104
"@trpc/server": "^10.38.1",
105105
"@walletconnect/sign-client": "^2.11.0",
@@ -144,7 +144,7 @@
144144
"prettier": "^3.0.3",
145145
"prettier-plugin-import-sort": "^0.0.7",
146146
"semantic-release": "^24.0.0",
147-
"starknet": "^6.24.1",
147+
"starknet": "7.5.1",
148148
"svelte": "^4.0.0",
149149
"svelte-check": "^3.5.1",
150150
"svelte-eslint-parser": "^0.41.1",
@@ -159,7 +159,7 @@
159159
"zod": "^3.20.6"
160160
},
161161
"peerDependencies": {
162-
"starknet": "^6.24.1"
162+
"starknet": "7.5.1"
163163
},
164164
"gitHead": "b16688a8638cc138938e74e1a39d004760165d75"
165165
}

pnpm-lock.yaml

Lines changed: 6727 additions & 4050 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

src/connectors/argent/argentMobile/index.ts

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -140,7 +140,7 @@ export class ArgentMobileBaseConnector extends Connector {
140140
params: { silent_mode: true },
141141
})
142142

143-
return new WalletAccount(provider, this._wallet, undefined, accounts[0])
143+
return new WalletAccount(provider, this._wallet, accounts[0], undefined)
144144
}
145145

146146
async chainId(): Promise<bigint> {
Lines changed: 5 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -1,12 +1,12 @@
1-
import { constants } from "starknet";
1+
import { constants } from "starknet"
22

33
export const CONTROLLER_ICON =
4-
"";
4+
""
55

6-
const RPC_SEPOLIA = "https://api.cartridge.gg/x/starknet/sepolia";
7-
const RPC_MAINNET = "https://api.cartridge.gg/x/starknet/mainnet";
6+
const RPC_SEPOLIA = "https://api.cartridge.gg/x/starknet/sepolia"
7+
const RPC_MAINNET = "https://api.cartridge.gg/x/starknet/mainnet"
88

99
export const RPC_URLS = {
1010
[constants.StarknetChainId.SN_SEPOLIA]: RPC_SEPOLIA,
1111
[constants.StarknetChainId.SN_MAIN]: RPC_MAINNET,
12-
};
12+
}

src/connectors/controller/index.ts

Lines changed: 92 additions & 49 deletions
Original file line numberDiff line numberDiff line change
@@ -1,54 +1,81 @@
1-
import type { ProviderOptions, ProviderInterface, AccountInterface } from "starknet"
2-
import { constants } from "starknet";
3-
4-
import type { RequestFnCall, RpcMessage, RpcTypeToMessageMap, StarknetWindowObject, TypedData } from "@starknet-io/types-js"
5-
6-
import Controller, { type ControllerOptions } from "@cartridge/controller";
1+
import type {
2+
ProviderOptions,
3+
ProviderInterface,
4+
AccountInterface,
5+
} from "starknet"
6+
import { constants } from "starknet"
7+
8+
import type {
9+
RequestFnCall,
10+
RpcMessage,
11+
RpcTypeToMessageMap,
12+
StarknetWindowObject,
13+
TypedData,
14+
} from "@starknet-io/types-js"
15+
16+
import Controller, { type ControllerOptions } from "@cartridge/controller"
717
import { Connector, type ConnectArgs, type ConnectorData } from "../connector"
8-
import { ConnectorNotConnectedError, UserNotConnectedError, UserRejectedRequestError } from "../../errors"
18+
import {
19+
ConnectorNotConnectedError,
20+
UserNotConnectedError,
21+
UserRejectedRequestError,
22+
} from "../../errors"
923

10-
import { CONTROLLER_ICON, RPC_URLS } from "./constants";
24+
import { CONTROLLER_ICON, RPC_URLS } from "./constants"
1125

1226
export class ControllerConnector extends Connector {
13-
private controller: Controller | null;
27+
private controller: Controller | null
1428

1529
constructor(options: Partial<ControllerOptions> = {}) {
16-
super();
30+
super()
1731

1832
// Can pass in defaultChainId = SN_SEPOLIA to connect to Sepolia testnet
19-
options.defaultChainId = options.defaultChainId || constants.StarknetChainId.SN_MAIN;
20-
options.chains = options.chains || [{ rpcUrl: RPC_URLS[options.defaultChainId as keyof typeof RPC_URLS] }];
33+
options.defaultChainId =
34+
options.defaultChainId || constants.StarknetChainId.SN_MAIN
35+
options.chains = options.chains || [
36+
{ rpcUrl: RPC_URLS[options.defaultChainId as keyof typeof RPC_URLS] },
37+
]
2138

2239
this.controller = this.available()
2340
? new Controller(options as ControllerOptions)
24-
: null;
41+
: null
2542
}
2643

27-
get id() { return "cartridgeController" }
28-
get name() { return "Cartridge Controller" }
29-
get icon() { return { light: CONTROLLER_ICON, dark: CONTROLLER_ICON } }
44+
get id() {
45+
return "cartridgeController"
46+
}
47+
get name() {
48+
return "Cartridge Controller"
49+
}
50+
get icon() {
51+
return { light: CONTROLLER_ICON, dark: CONTROLLER_ICON }
52+
}
3053

3154
available() {
32-
return typeof window !== "undefined";
55+
return typeof window !== "undefined"
3356
}
3457

3558
async ready() {
3659
if (!this.controller) {
37-
return false;
60+
return false
3861
}
3962

40-
const account = await this.controller.probe();
41-
return account !== null;
63+
const account = await this.controller.probe()
64+
return account !== null
4265
}
4366

4467
async connect(_args?: ConnectArgs): Promise<ConnectorData> {
45-
if (!this.controller) { throw new ConnectorNotConnectedError(); }
68+
if (!this.controller) {
69+
throw new ConnectorNotConnectedError()
70+
}
4671

47-
const account = await this.controller.connect();
72+
const account = await this.controller.connect()
4873

49-
if (!account) { throw new UserNotConnectedError(); }
74+
if (!account) {
75+
throw new UserNotConnectedError()
76+
}
5077

51-
const chainId = await this.chainId();
78+
const chainId = await this.chainId()
5279

5380
/**
5481
* @dev This emit ensures compatibility with starknet-react
@@ -57,67 +84,83 @@ export class ControllerConnector extends Connector {
5784

5885
return {
5986
account: account.address,
60-
chainId: chainId
61-
};
87+
chainId: chainId,
88+
}
6289
}
6390

6491
async disconnect(): Promise<void> {
65-
if (!this.controller) { throw new ConnectorNotConnectedError(); }
92+
if (!this.controller) {
93+
throw new ConnectorNotConnectedError()
94+
}
6695

6796
/**
6897
* @dev This emit ensures compatibility with starknet-react
6998
*/
7099
this.emit("disconnect")
71100

72-
return this.controller.disconnect();
101+
return this.controller.disconnect()
73102
}
74103

75-
async account(_provider: ProviderOptions | ProviderInterface): Promise<AccountInterface> {
76-
if (!this.controller) { throw new ConnectorNotConnectedError(); }
104+
async account(
105+
_provider: ProviderOptions | ProviderInterface,
106+
): Promise<AccountInterface> {
107+
if (!this.controller) {
108+
throw new ConnectorNotConnectedError()
109+
}
77110

78-
const account = await this.controller.probe();
111+
const account = await this.controller.probe()
79112

80-
if (!account) { throw new UserNotConnectedError(); }
113+
if (!account) {
114+
throw new UserNotConnectedError()
115+
}
81116

82-
return account;
117+
return account
83118
}
84119

85120
async chainId(): Promise<bigint> {
86-
if (!this.controller) { throw new ConnectorNotConnectedError(); }
121+
if (!this.controller) {
122+
throw new ConnectorNotConnectedError()
123+
}
87124

88-
const account = await this.controller.probe();
125+
const account = await this.controller.probe()
89126

90-
if (!account) { throw new UserNotConnectedError(); }
127+
if (!account) {
128+
throw new UserNotConnectedError()
129+
}
91130

92-
return BigInt(await account.getChainId());
131+
return BigInt(await account.getChainId())
93132
}
94133

95134
async request<T extends RpcMessage["type"]>(
96-
call: RequestFnCall<T>
135+
call: RequestFnCall<T>,
97136
): Promise<RpcTypeToMessageMap[T]["result"]> {
98-
if (!this.controller) { throw new ConnectorNotConnectedError(); }
137+
if (!this.controller) {
138+
throw new ConnectorNotConnectedError()
139+
}
99140

100141
// Handle SNIP-12 compliance for signTypedData requests
101142
if (call.type === "wallet_signTypedData") {
102-
const params = call.params as TypedData;
143+
const params = call.params as TypedData
103144
if (!params.types.StarknetDomain) {
104-
throw new Error(
105-
`Controller requires a SNIP-12 version 1 domain separator. ` +
106-
`See: https://github.com/starknet-io/SNIPs/blob/main/SNIPS/snip-12.md#domain-separator`
107-
);
108-
}
145+
throw new Error(
146+
`Controller requires a SNIP-12 version 1 domain separator. ` +
147+
`See: https://github.com/starknet-io/SNIPs/blob/main/SNIPS/snip-12.md#domain-separator`,
148+
)
149+
}
109150
}
110151

111152
try {
112-
return await this.controller.request(call);
153+
return await this.controller.request(call)
113154
} catch {
114-
throw new UserRejectedRequestError();
155+
throw new UserRejectedRequestError()
115156
}
116157
}
117158

118159
get wallet(): StarknetWindowObject {
119-
if (!this.controller) { throw new ConnectorNotConnectedError(); }
160+
if (!this.controller) {
161+
throw new ConnectorNotConnectedError()
162+
}
120163

121-
return this.controller;
164+
return this.controller
122165
}
123166
}

src/connectors/injected/index.ts

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -168,7 +168,7 @@ export class InjectedConnector extends Connector {
168168
params: { silent_mode: true },
169169
})
170170

171-
return new WalletAccount(provider, this._wallet, undefined, accounts[0])
171+
return new WalletAccount(provider, this._wallet, accounts[0], undefined)
172172
}
173173

174174
async connect(_args: ConnectArgs = {}): Promise<ConnectorData> {

src/connectors/webwallet/index.ts

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -273,7 +273,7 @@ export class WebWalletConnector extends Connector {
273273
throw new ConnectorNotConnectedError()
274274
}
275275

276-
return new WalletAccount(provider, this._wallet, undefined, _address)
276+
return new WalletAccount(provider, this._wallet, _address, undefined)
277277
}
278278

279279
async chainId(): Promise<bigint> {

0 commit comments

Comments
 (0)