Create account
Orderly Key
Creates anOrderlyKey. The validity of the OrderlyKey (in days) can be set.
OrderlyKey is successfully created, it will be stored in the KeyStore, and will be used for API signatures later on.
KeyStore
TheKeyStore instance is responsible for storing the Orderly private key, which is used for trading.
By default the key will be stored in local Storage, but a custom KeyStore implementation can be given to OrderlyConfigProvider like explained here.
Account status
TheAccount object has the following statuses:
NotConnected/Connected- Wallet connection status, not related to Orderly.NotConnectedmeans no wallet connected,Connectedmeans the wallet app is connected and we know the user’s wallet address.NotSignedIn/SignedIn- The result from callingGet Account InformationorRegister Account.NotSignedInmeans there’s no registered account associated with the wallet address andbrokerIdpair.SignedInmeans that an account has been previously registered with the wallet address andbrokerIdpair.DisabledTrading/EnableTrading- The result from callingGet Orderly KeyorAdd Orderly Key.DisabledTradingmeans no active Orderly Key is found in theKeyStore.EnableTradingmeans an active Orderly Key is found in theKeyStoreand can be used to authenticate for any private API requests.
Get account status
There are two ways to get the account status. You can get it either directly fromuseAccount’s value, or through subscribing to the account status change event:
- Retrieve from the
statevalue inuseAccount:
state also contains the following account info, as shown below:
- Subscribe to the
change:statusevent in theAccountinstance. (accountis a singleton of theAccountinstance)。
Update account status
@orderly.network/hooks currently does not provide the functionality for connecting wallets, builders have to handle wallet connection logic themselves, refer here.
Once the user has successfully connected a wallet, use the setAddress method to pass the address to the Account instance. 3 additional parameters need to be passed when calling setAddress:
provider- provider according to theEIP1193Providerstandardchain- information regarding the connected chain, including theidwallet- wallet information, including the name of the wallet app
setAddress method in Account will check the accound_id and the existence of any valid OrderlyKey from the provided address and update the state. If the state is AccountStatusEnum.EnableTrading, then the full login process in complete and the user can then access all functionalities provided by Orderly.