-
Notifications
You must be signed in to change notification settings - Fork 757
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fix: update to latest get-starknet dev
- Loading branch information
Showing
23 changed files
with
479 additions
and
215 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
13 changes: 5 additions & 8 deletions
13
src/wallet/getst/StarknetWindowObject.d.ts → src/wallet/getst/StarknetWindowObject.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,27 +1,24 @@ | ||
import { RequestFn } from './rpcMessage'; | ||
import { WalletEventHandlers } from './walletEvents'; | ||
|
||
declare type WalletEventListener = <E extends keyof WalletEventHandlers>( | ||
type WalletEventListener = <E extends keyof WalletEventHandlers>( | ||
event: E, | ||
handleEvent: WalletEventHandlers[E] | ||
) => void; | ||
|
||
// Implement the StarknetWindowObject interface with the improved request method | ||
export interface StarknetWindowObject { | ||
id: string; | ||
name: string; | ||
version: string; | ||
icon: | ||
| string | ||
| { | ||
dark: string; | ||
light: string; | ||
}; | ||
icon: string | { dark: string; light: string }; | ||
request: RequestFn; | ||
on: WalletEventListener; | ||
off: WalletEventListener; | ||
} | ||
|
||
declare global { | ||
interface Window { | ||
[key: `starknet_${string}`]: StarknetWindowObject | undefined; | ||
} | ||
} | ||
export {}; |
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,36 @@ | ||
export type WalletProvider = { | ||
id: string; | ||
name: string; | ||
icon: string; | ||
downloads: | ||
| { chrome?: `https://chrome.google.com/webstore/detail/${string}` } | ||
| { firefox?: `https://addons.mozilla.org/en-US/firefox/addon/${string}` } | ||
| { edge?: `https://microsoftedge.microsoft.com/addons/detail/${string}` }; | ||
}; | ||
|
||
const wallets: WalletProvider[] = [ | ||
{ | ||
id: 'argentX', | ||
name: 'Argent X', | ||
icon: '', | ||
downloads: { | ||
chrome: | ||
'https://chrome.google.com/webstore/detail/argent-x-starknet-wallet/dlcobpjiigpikoobohmabehhmhfoodbb', | ||
firefox: 'https://addons.mozilla.org/en-US/firefox/addon/argent-x', | ||
edge: 'https://microsoftedge.microsoft.com/addons/detail/argent-x/ajcicjlkibolbeaaagejfhnofogocgcj', | ||
}, | ||
}, | ||
{ | ||
id: 'braavos', | ||
name: 'Braavos', | ||
icon: '', | ||
downloads: { | ||
chrome: | ||
'https://chrome.google.com/webstore/detail/braavos-wallet/jnlgamecbpmbajjfhmmmlhejkemejdma', | ||
firefox: 'https://addons.mozilla.org/en-US/firefox/addon/braavos-wallet', | ||
edge: 'https://microsoftedge.microsoft.com/addons/detail/braavos-wallet/hkkpjehhcnhgefhbdcgfkeegglpjchdc', | ||
}, | ||
}, | ||
]; | ||
|
||
export default wallets; |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,81 @@ | ||
import { generateUID } from './utils'; | ||
|
||
export interface IStorageWrapper { | ||
set(value: string | null | undefined): boolean; | ||
get(): string | null | undefined; | ||
delete(): boolean; | ||
} | ||
|
||
export class LocalStorageWrapper implements IStorageWrapper { | ||
#initialized = false; | ||
|
||
#key: string | undefined = undefined; | ||
|
||
#prefix: string; | ||
|
||
value: string | null | undefined = undefined; | ||
|
||
constructor(key: string) { | ||
this.#prefix = key; | ||
|
||
this.#init(); | ||
} | ||
|
||
set(value: string | null | undefined) { | ||
if (!this.#initialized && !this.#init()) { | ||
return false; | ||
} | ||
|
||
this.delete(); // clear current key | ||
|
||
this.value = value; | ||
if (value) { | ||
this.#key = `${this.#prefix}-${generateUID()}`; | ||
localStorage.setItem(this.#key, value); | ||
} | ||
|
||
return true; | ||
} | ||
|
||
get() { | ||
this.#validateValue(); | ||
return this.value; | ||
} | ||
|
||
delete() { | ||
if (!this.#initialized && !this.#init()) { | ||
return false; | ||
} | ||
|
||
this.value = null; | ||
if (this.#key) localStorage.removeItem(this.#key); | ||
|
||
return true; | ||
} | ||
|
||
#validateValue() { | ||
if (this.value) { | ||
this.set(this.value); | ||
} | ||
} | ||
|
||
#init() { | ||
try { | ||
if (!this.#initialized && typeof window !== 'undefined') { | ||
// init with prev key/value | ||
this.#key = Object.keys(localStorage).find((sk) => sk.startsWith(this.#prefix)); | ||
|
||
// set initialized as soon as we managed to extract data | ||
// from localStorage, so the `set` call below won't result | ||
// in a endless-recursive loop | ||
this.#initialized = true; | ||
if (this.#key) { | ||
this.set(localStorage.getItem(this.#key)); | ||
} | ||
} | ||
} catch (err) { | ||
console.warn(err); | ||
} | ||
return this.#initialized; | ||
} | ||
} |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,131 @@ | ||
/* eslint-disable @typescript-eslint/no-shadow */ | ||
import { type StarknetWindowObject } from './StarknetWindowObject'; | ||
import discovery, { type WalletProvider } from './discovery'; | ||
import { LocalStorageWrapper } from './localStorageStore'; | ||
import { Permission } from './rpcMessage'; | ||
import type { GetStarknetOptions, GetStarknetResult } from './types'; | ||
import { pipe } from './utils'; | ||
import { filterBy, filterByAuthorized } from './wallet/filter'; | ||
import { isWalletObj } from './wallet/isWalletObject'; | ||
import { scanObjectForWallets } from './wallet/scan'; | ||
import { sortBy } from './wallet/sort'; | ||
|
||
export type { StarknetWindowObject } from './StarknetWindowObject'; | ||
|
||
export type { | ||
AddDeclareTransactionParameters, | ||
AddDeclareTransactionResult, | ||
AddDeployAccountTransactionParameters, | ||
AddDeployAccountTransactionResult, | ||
AddInvokeTransactionParameters, | ||
AddInvokeTransactionResult, | ||
AddStarknetChainParameters, | ||
RequestAccountsParameters, | ||
StarknetChainId, | ||
SwitchStarknetChainParameters, | ||
GetDeploymentDataResult, | ||
WatchAssetParameters, | ||
TypedData, | ||
RequestFn, | ||
RpcMessage, | ||
IsParamsOptional, | ||
RpcTypeToMessageMap, | ||
RequestFnCall, | ||
} from './rpcMessage'; | ||
|
||
export type { | ||
WalletEvents, | ||
AccountChangeEventHandler, | ||
NetworkChangeEventHandler, | ||
WalletEventHandlers, | ||
} from './walletEvents'; | ||
|
||
export { Permission } from './rpcMessage'; | ||
|
||
export type { | ||
DisconnectOptions, | ||
GetStarknetOptions, | ||
GetStarknetResult, | ||
GetWalletOptions, | ||
WalletProvider, | ||
} from './types'; | ||
|
||
const ssrSafeWindow = typeof window !== 'undefined' ? window : {}; | ||
|
||
const defaultOptions: GetStarknetOptions = { | ||
windowObject: ssrSafeWindow, | ||
isWalletObject: isWalletObj, | ||
storageFactoryImplementation: (name: string) => new LocalStorageWrapper(name), | ||
}; | ||
|
||
export function getStarknet(options: Partial<GetStarknetOptions> = {}): GetStarknetResult { | ||
const { storageFactoryImplementation, windowObject, isWalletObject } = { | ||
...defaultOptions, | ||
...options, | ||
}; | ||
const lastConnectedStore = storageFactoryImplementation('gsw-last'); | ||
|
||
return { | ||
getAvailableWallets: async (options = {}) => { | ||
const availableWallets = scanObjectForWallets(windowObject, isWalletObject); | ||
return pipe<StarknetWindowObject[]>( | ||
(_) => filterBy(_, options), | ||
(_) => sortBy(_, options.sort) | ||
)(availableWallets); | ||
}, | ||
getAuthorizedWallets: async (options = {}) => { | ||
const availableWallets = scanObjectForWallets(windowObject, isWalletObject); | ||
return pipe<StarknetWindowObject[]>( | ||
(_) => filterByAuthorized(_), | ||
(_) => filterBy(_, options), | ||
(_) => sortBy(_, options.sort) | ||
)(availableWallets); | ||
}, | ||
getDiscoveryWallets: async (options = {}) => { | ||
return pipe<WalletProvider[]>( | ||
(_) => filterBy(_, options), | ||
(_) => sortBy(_, options.sort) | ||
)(discovery); | ||
}, | ||
getLastConnectedWallet: async () => { | ||
const lastConnectedWalletId = lastConnectedStore.get(); | ||
const allWallets = scanObjectForWallets(windowObject, isWalletObject); | ||
const lastConnectedWallet = allWallets.find((w) => w.id === lastConnectedWalletId); | ||
const [firstAuthorizedWallet] = await filterByAuthorized( | ||
lastConnectedWallet ? [lastConnectedWallet] : [] | ||
); | ||
|
||
if (!firstAuthorizedWallet) { | ||
lastConnectedStore.delete(); | ||
return null; | ||
} | ||
|
||
return firstAuthorizedWallet; | ||
}, | ||
enable: async (wallet, options) => { | ||
await wallet.request({ | ||
type: 'wallet_requestAccounts', | ||
params: { | ||
silentMode: options?.silentMode, | ||
}, | ||
}); | ||
|
||
// check for permissions | ||
const permissions = await wallet.request({ | ||
type: 'wallet_getPermissions', | ||
}); | ||
if (!permissions?.includes(Permission.Accounts)) { | ||
throw new Error('Failed to connect to wallet'); | ||
} | ||
lastConnectedStore.set(wallet.id); | ||
return wallet; | ||
}, | ||
disconnect: async ({ clearLastWallet } = {}) => { | ||
if (clearLastWallet) { | ||
lastConnectedStore.delete(); | ||
} | ||
}, | ||
}; | ||
} | ||
|
||
export default getStarknet(); |
Oops, something went wrong.