Browse Source

Merge pull request #454 from gre/implement-libcore-optimistic-updates-and-perf

LibcoreBridge: perf + optimistic update
master
Meriadec Pillet 7 years ago
committed by GitHub
parent
commit
e8f0791e85
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 30
      src/bridge/LibcoreBridge.js
  2. 2
      src/commands/libcoreSignAndBroadcast.js

30
src/bridge/LibcoreBridge.js

@ -1,6 +1,7 @@
// @flow // @flow
import React from 'react' import React from 'react'
import { map } from 'rxjs/operators' import { map } from 'rxjs/operators'
import type { Account } from '@ledgerhq/live-common/lib/types'
import { decodeAccount, encodeAccount } from 'reducers/accounts' import { decodeAccount, encodeAccount } from 'reducers/accounts'
import FeesBitcoinKind from 'components/FeesField/BitcoinKind' import FeesBitcoinKind from 'components/FeesField/BitcoinKind'
import libcoreScanAccounts from 'commands/libcoreScanAccounts' import libcoreScanAccounts from 'commands/libcoreScanAccounts'
@ -61,15 +62,31 @@ const LibcoreBridge: WalletBridge<Transaction> = {
const rawAccount = encodeAccount(account) const rawAccount = encodeAccount(account)
const rawSyncedAccount = await libcoreSyncAccount.send({ rawAccount }).toPromise() const rawSyncedAccount = await libcoreSyncAccount.send({ rawAccount }).toPromise()
const syncedAccount = decodeAccount(rawSyncedAccount) const syncedAccount = decodeAccount(rawSyncedAccount)
next(account => ({ next(account => {
...account, const accountOps = account.operations
const syncedOps = syncedAccount.operations
const patch: $Shape<Account> = {
freshAddress: syncedAccount.freshAddress, freshAddress: syncedAccount.freshAddress,
freshAddressPath: syncedAccount.freshAddressPath, freshAddressPath: syncedAccount.freshAddressPath,
balance: syncedAccount.balance, balance: syncedAccount.balance,
blockHeight: syncedAccount.blockHeight, blockHeight: syncedAccount.blockHeight,
operations: syncedAccount.operations, // TODO: is a simple replace enough?
lastSyncDate: new Date(), lastSyncDate: new Date(),
})) }
const hasChanged =
accountOps.length !== syncedOps.length || // size change, we do a full refresh for now...
(accountOps.length > 0 && syncedOps.length > 0 && accountOps[0].id !== syncedOps[0].id) // if same size, only check if the last item has changed.
if (hasChanged) {
patch.operations = syncedAccount.operations
patch.pendingOperations = [] // For now, we assume a change will clean the pendings.
}
return {
...account,
...patch,
}
})
complete() complete()
} catch (e) { } catch (e) {
error(e) error(e)
@ -136,6 +153,11 @@ const LibcoreBridge: WalletBridge<Transaction> = {
return op return op
}, },
addPendingOperation: (account, operation) => ({
...account,
pendingOperations: [operation].concat(account.pendingOperations),
}),
} }
export default LibcoreBridge export default LibcoreBridge

2
src/commands/libcoreSignAndBroadcast.js

@ -105,7 +105,7 @@ export async function doSignAndBroadcast({
id: txHash, id: txHash,
hash: txHash, hash: txHash,
type: 'OUT', type: 'OUT',
value: amount, value: transaction.amount,
fee: 0, fee: 0,
blockHash: null, blockHash: null,
blockHeight: null, blockHeight: null,

Loading…
Cancel
Save