Skip to content

Commit

Permalink
Merge pull request starknet-io#269 from chainapsis/master
Browse files Browse the repository at this point in the history
feat: support keplr wallet
  • Loading branch information
fracek authored Oct 15, 2024
2 parents ff37390 + 2ae401b commit 27e2ae8
Show file tree
Hide file tree
Showing 7 changed files with 733 additions and 88 deletions.
5 changes: 5 additions & 0 deletions .changeset/dry-socks-relax.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"get-starknet-core": patch
---

Support Keplr wallet
2 changes: 1 addition & 1 deletion packages/core/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@
"typescript": "^4.6.4",
"vite": "^3.0.0",
"vite-plugin-dts": "^1.4.0",
"vitest": "^0.19.1"
"vitest": "^2.1.3"
},
"peerDependencies": {
"starknet": "^5.18.0"
Expand Down
13 changes: 10 additions & 3 deletions packages/core/src/__test__/main.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import { mockStorageFunction } from "./storage.mock"
import {
ArgentXMock,
BraavosMock,
KeplrMock,
OKXMock,
UnknownWalletAMock,
UnknownWalletBMock,
Expand Down Expand Up @@ -33,12 +34,14 @@ describe("getAvailableWallets()", () => {
starknet: ArgentXMock,
"starknet-braavos": BraavosMock,
starknet_okxwallet: OKXMock,
starknet_keplr: KeplrMock,
})
const availableWallets = await sn.getAvailableWallets()
expect(availableWallets.length).toBe(3)
expect(availableWallets.length).toBe(4)
expect(availableWallets).toContainEqual(ArgentXMock)
expect(availableWallets).toContainEqual(BraavosMock)
expect(availableWallets).toContainEqual(OKXMock)
expect(availableWallets).toContainEqual(KeplrMock)
})
it("should return one injected wallet", async () => {
const sn = getWallet({
Expand Down Expand Up @@ -114,18 +117,21 @@ describe("getPreAuthorizedWallets()", () => {
"starknet-argent": makePreAuthorized(true)(ArgentXMock),
"starknet-braavos": makePreAuthorized(true)(BraavosMock),
starknet_okxwallet: makePreAuthorized(true)(OKXMock),
starknet_keplr: makePreAuthorized(true)(KeplrMock),
})
const preauthorizedWallets = await sn.getPreAuthorizedWallets()
expect(preauthorizedWallets.length).toBe(3)
expect(preauthorizedWallets.length).toBe(4)
expect(preauthorizedWallets.map((w) => w.id)).contains(ArgentXMock.id)
expect(preauthorizedWallets.map((w) => w.id)).contains(BraavosMock.id)
expect(preauthorizedWallets.map((w) => w.id)).contains(OKXMock.id)
expect(preauthorizedWallets.map((w) => w.id)).contains(KeplrMock.id)
})
it("should return one preauthorized wallet", async () => {
const sn = getWallet({
"starknet-argent": makePreAuthorized(true)(ArgentXMock),
"starknet-braavos": makePreAuthorized(false)(BraavosMock),
starknet_okxwallet: makePreAuthorized(false)(OKXMock),
starknet_keplr: makePreAuthorized(false)(KeplrMock),
})
const preauthorizedWallets = await sn.getPreAuthorizedWallets()
expect(preauthorizedWallets.length).toBe(1)
Expand All @@ -137,9 +143,10 @@ describe("getDiscoveryWallets()", () => {
it("should return all discovery wallets", async () => {
const sn = getWallet({})
const discoveryWallets = await sn.getDiscoveryWallets()
expect(discoveryWallets.length).toBe(4)
expect(discoveryWallets.length).toBe(5)
expect(discoveryWallets.map((w) => w.id)).contains(ArgentXMock.id)
expect(discoveryWallets.map((w) => w.id)).contains(BraavosMock.id)
expect(discoveryWallets.map((w) => w.id)).contains(OKXMock.id)
expect(discoveryWallets.map((w) => w.id)).contains(KeplrMock.id)
})
})
37 changes: 24 additions & 13 deletions packages/core/src/__test__/storage.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import { mockStorageFunction } from "./storage.mock"
import {
ArgentXMock,
BraavosMock,
KeplrMock,
OKXMock,
UnknownWalletAMock,
UnknownWalletBMock,
Expand Down Expand Up @@ -50,6 +51,7 @@ describe("getLastConnectedWallet()", () => {
"starknet-argentX": makePreAuthorized(false)(ArgentXMock),
"starknet-braavos": makePreAuthorized(false)(BraavosMock),
starknet_okxwallet: makePreAuthorized(false)(OKXMock),
starknet_keplr: makePreAuthorized(false)(KeplrMock),
},
mockStorageFunction({
"gsw-last": "braavos",
Expand All @@ -64,6 +66,7 @@ describe("getLastConnectedWallet()", () => {
"starknet-argentX": makePreAuthorized(false)(ArgentXMock),
"starknet-braavos": makePreAuthorized(true)(BraavosMock),
starknet_okxwallet: makePreAuthorized(false)(OKXMock),
starknet_keplr: makePreAuthorized(false)(KeplrMock),
},
mockStorageFunction({
"gsw-last": "braavos",
Expand All @@ -78,26 +81,32 @@ describe("getLastConnectedWallet()", () => {
"starknet-argentX": makePreAuthorized(true)(ArgentXMock),
"starknet-braavos": makePreAuthorized(true)(BraavosMock),
starknet_okxwallet: makePreAuthorized(true)(OKXMock),
starknet_keplr: makePreAuthorized(true)(KeplrMock),
},
mockStorageFunction({ "gsw-last": "braavos" }),
)
const lastConnectedWallet = await sn.getLastConnectedWallet()
expect(lastConnectedWallet?.id).toBe(BraavosMock.id)
})
it("should set the last connected wallet when enabled", async () => {
const sn = getWallet({
"starknet-argentX": makeConnected(true)(ArgentXMock),
"starknet-braavos": makeConnected(true)(BraavosMock),
starknet_okxwallet: makeConnected(true)(OKXMock),
})
const lastConnectedWallet = await sn.getLastConnectedWallet()
expect(lastConnectedWallet).toBe(null)
it(
"should set the last connected wallet when enabled",
{ retry: 5 },
async () => {
const sn = getWallet({
"starknet-argentX": makeConnected(true)(ArgentXMock),
"starknet-braavos": makeConnected(true)(BraavosMock),
starknet_okxwallet: makeConnected(true)(OKXMock),
starknet_keplr: makePreAuthorized(true)(KeplrMock),
})
const lastConnectedWallet = await sn.getLastConnectedWallet()
expect(lastConnectedWallet).toBe(null)

const [newLastConnectedWallet] = await sn.getAvailableWallets()
await sn.enable(newLastConnectedWallet)
const lastConnectedWalletAfterEnable = await sn.getLastConnectedWallet()
expect(lastConnectedWalletAfterEnable).toBe(newLastConnectedWallet)
})
const [newLastConnectedWallet] = await sn.getAvailableWallets()
await sn.enable(newLastConnectedWallet)
const lastConnectedWalletAfterEnable = await sn.getLastConnectedWallet()
expect(lastConnectedWalletAfterEnable).toBe(newLastConnectedWallet)
},
)
it("enabling fails", async () => {
const sn = getWallet({
"starknet-argentX": makeConnected(false)(ArgentXMock),
Expand All @@ -114,6 +123,7 @@ describe("getLastConnectedWallet()", () => {
"starknet-argentX": makePreAuthorized(true)(ArgentXMock),
"starknet-braavos": makePreAuthorized(true)(BraavosMock),
starknet_okxwallet: makePreAuthorized(true)(OKXMock),
starknet_keplr: makePreAuthorized(true)(KeplrMock),
},
mockStorageFunction({
"gsw-last": "braavos",
Expand All @@ -132,6 +142,7 @@ describe("getLastConnectedWallet()", () => {
"starknet-argentX": makePreAuthorized(true)(ArgentXMock),
"starknet-braavos": makePreAuthorized(true)(BraavosMock),
starknet_okxwallet: makePreAuthorized(true)(OKXMock),
starknet_keplr: makePreAuthorized(true)(KeplrMock),
},
mockStorageFunction({
"gsw-last": "braavos",
Expand Down
5 changes: 5 additions & 0 deletions packages/core/src/__test__/wallet.mock.ts
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,11 @@ export const OKXMock: WalletMock = {
isPreauthorized: async () => false,
}

export const KeplrMock: WalletMock = {
...wallets.find((w) => w.id === "keplr")!,
isPreauthorized: async () => false,
}

export function makePreAuthorized(isPreauthorized: boolean) {
return (wallet: WalletMock) => ({
...wallet,
Expand Down
11 changes: 11 additions & 0 deletions packages/core/src/discovery.ts
Original file line number Diff line number Diff line change
Expand Up @@ -81,6 +81,17 @@ const wallets: WalletProvider[] = [
edge: "https://microsoftedge.microsoft.com/addons/detail/metamask/ejbalbakoplchlghecdalmeeeajnimhm?hl=en-US",
},
},
{
id: "keplr",
name: "Keplr",
icon: "",
downloads: {
chrome:
"https://chrome.google.com/webstore/detail/keplr/dmkamcknogkgcdfhhbddcghachkejeap",
firefox: "https://addons.mozilla.org/en-US/firefox/addon/keplr",
edge: "https://microsoftedge.microsoft.com/addons/detail/keplr/ocodgmmffbkkeecmadcijjhkmeohinei",
},
},
]

export default wallets
Loading

0 comments on commit 27e2ae8

Please sign in to comment.