All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.
- New version of tokenpoket plugin which has some minor updates.
- New version of anchor-link plugin which has some major upgrades.
Added the ability for hosting applicaiton to do account lookup once the wallet returns the keys.
-
The wallet.discover method currently takes a discoveryOptions parameter - wallet.discover( discoveryOptions )
-
A new property "keyLookupFunc" has been added to the discoveryOptions object.
-
Example:
discoveryOptions.keyLookupFunc = (discoveryData: DiscoveryData, callback: DiscoverContinueCallback) => { // Get the discoveryData object contains the keys. // It is up to your function to fetch the Account info and then call callback(accountInfoArray); }
-
Detailed Example:
discoveryOptions.keyLookupFunc = (discoveryData: DiscoveryData, callback: DiscoverContinueCallback) => { /* Exmaple discoveryData structure: { "keys": [ { "index": 0, "key": "EOS5TYtUXsbRJrz61gsQWQho6AYyCcRFgbFm4TPfrEbzb43x8Ewfq" }, { "index": 1, "key": "EOS8MBNb9GwkqM3eXYCDVsgeqVeMbf3wS7fp6smzCj63CVZgFEede" } ], } */ /* * Your function is provided with an array of keys in the format above. * Use whatever method you'd like to resolve the keys to account information and build a structure that looks like the DiscoveryAccount[] structure below. * Then call the callback() function with the data which will allow the login process to continue. */ let accountInfoArray: DiscoveryAccount[] = [{ index: 0, key: "EOS5TYtUXsbRJrz61gsQWQho6AYyCcRFgbFm4TPfrEbzb43x8Ewfq", accounts : [{ account: "wozzawozza", authorization: "active" }] }]; /* Example DiscoveryAccount[] structure [ { "index": 0, "key": "EOS5TYtUXsbRJrz61gsQWQho6AYyCcRFgbFm4TPfrEbzb43x8Ewfq", "accounts": [ { "account": "wozzawozza", "authorization": "active" } ] } ] */ callback(accountInfoArray); } .... wallet.discover( discoveryOptions ).then( .... );
Update the timeout in the metro plugin
Minor fix to the caching logic in ledger plugin to ensure the discover exists completely when presetKeyMap is supplied.
This change only effect Ledger and plugins that support discovery (currently only Ledger)
Added the ability warm the discovery cache when dealing with devices like Ledger.
When calling wallet.discover( discoveryOptions );
The DiscoveryOptions interface looks as follows. New param = presetKeyMap
export interface DiscoveryOptions { pathIndexList: number[]; keyModifierFunc?: KeyModifierCallback; presetKeyMap?: any; // TODO: This data structure is not defined as a type right now, but should be. It's the same as the response structure from discover() }
Setting this value will warm the discoveryData cache, this allows you to save discoveryData from a previous session and supply it again .. avoiding the network overhead of looking up the data again.
As an example one can save the previous discoveryData:
localStorage.setItem('discoveryData', JSON.stringify(discoveryData.keyToAccountMap));
and then
presetKeyMap = JSON.parse(discoveryDataCached);
discoveryOptions.presetKeyMap = presetKeyMap;
simpleEOS provider published
A known issues exists where if the user cancels account selection. Will be resolved shourtly.
Keycat provider published
Note that this provider has hard coded chain ids which limits it to mainnet and jungle usage right now.
The discover() methods options object now takes am optional new property keyModifierFunc. ( discoveryData: DiscoveryData ) => DiscoveryData; Callback of this kind can be supplied to the discover function, which will allow the caller to modify the list of keys before the account lookup process happens. The feature was added so that key returned from the Ledger device can be modified to have a ENU prefix when in use with the the enumivo chain
New provide eos-transit-whalevault-provider
New provide eos-transit-portis-provider
Updated [email protected] to [email protected]
Added WebBLE transport to the eos-transit-ledger-provider
Demo can be seen here - https://www.demo.eostransit.io
See the example below of how multiple Ledger instances are initialized with different transport support.
Note the intial testing shows that WebBLE only works on Mac OS
walletProviders: [
scatter(),
ledger({exchangeTimeout : 30000, transport: 'TransportWebBLE', name: 'Ledger Nano S BLE', shortName: 'Ledger Nano S BLE', id: 'ledgerble' }),
ledger({exchangeTimeout : 30000, transport: 'TransportU2F', name: 'Ledger Nano S U2F', shortName: 'Ledger Nano S U2F', id: 'ledgeru2f' }),
ledger({exchangeTimeout : 30000, transport: 'TransportWebAuthn', name: 'Ledger Nano S WebAuthn', shortName: 'Ledger Nano S WebAuthn', id: 'ledgeruwebauthn' }),
lynx(),
tokenpocket(),
meetone(),
metro() ]
I'm not entirly sure if this resolves the problem the pull intended to fix (need to do more testing), but it was a code improvement regardless.
Upgraded the Ledger hw-transport and hw-transport-u2f libraries
"@ledgerhq/hw-transport": "^4.32.0" -> "^4.60.2"
"@ledgerhq/hw-transport-u2f": "^4.32.0" -> "^4.60.2",
This pull request
Added WebAuthn support to the Ledger plugin and consolidated transport instances.
walletProviders: [ scatter(), ledger({exchangeTimeout : 30000, transport: 'TransportWebAuthn'}) ]
ledger plugin now take a parmam called transport which can be one of 'TransportWebAuthn' or 'TransportU2F'. Default is 'TransportU2F'
Added timeout parameter exchangeTimeout to the ledger plugin - to specify a u2f timeout that should be used when the ledger is signing transaction, create the object as follows: ledger({exchangeTimeout : 30000}). Default is 5000 (5 seconds).
Added ledger support for multiple actions withing a transaction.
Upgraded all packages to [email protected]
- Code improvement provided by @Bootl3r - fixes the meet.one detection.
- Meet.one plugin connect() fixed such that it will only resolve once the wallet is detected. If after 5 seconds it is not detected it'll resolve false.
- Meet.one plugin
- Added this Changelog
- README to each package so that that NPM gets something logical