|
@ -34,6 +34,7 @@ import { |
|
|
NotEnoughBalance, |
|
|
NotEnoughBalance, |
|
|
FeeNotLoaded, |
|
|
FeeNotLoaded, |
|
|
NotEnoughBalanceBecauseDestinationNotCreated, |
|
|
NotEnoughBalanceBecauseDestinationNotCreated, |
|
|
|
|
|
InvalidAddressBecauseDestinationIsAlsoSource, |
|
|
} from '@ledgerhq/errors' |
|
|
} from '@ledgerhq/errors' |
|
|
import type { WalletBridge, EditProps } from './types' |
|
|
import type { WalletBridge, EditProps } from './types' |
|
|
|
|
|
|
|
@ -136,15 +137,23 @@ async function signAndBroadcast({ a, t, deviceId, isCancelled, onSigned, onOpera |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
function isRecipientValid(recipient) { |
|
|
function isRecipientValid(account, recipient) { |
|
|
try { |
|
|
try { |
|
|
bs58check.decode(recipient) |
|
|
bs58check.decode(recipient) |
|
|
return true |
|
|
|
|
|
|
|
|
return !(account && account.freshAddress === recipient) |
|
|
} catch (e) { |
|
|
} catch (e) { |
|
|
return false |
|
|
return false |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function getRecipientWarning(account, recipient) { |
|
|
|
|
|
if (account.freshAddress === recipient) { |
|
|
|
|
|
return new InvalidAddressBecauseDestinationIsAlsoSource() |
|
|
|
|
|
} |
|
|
|
|
|
return null |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
function mergeOps(existing: Operation[], newFetched: Operation[]) { |
|
|
function mergeOps(existing: Operation[], newFetched: Operation[]) { |
|
|
const ids = existing.map(o => o.id) |
|
|
const ids = existing.map(o => o.id) |
|
|
const all = existing.concat(newFetched.filter(o => !ids.includes(o.id))) |
|
|
const all = existing.concat(newFetched.filter(o => !ids.includes(o.id))) |
|
@ -270,7 +279,7 @@ const getServerInfo = (map => endpointConfig => { |
|
|
})({}) |
|
|
})({}) |
|
|
|
|
|
|
|
|
const recipientIsNew = async (endpointConfig, recipient) => { |
|
|
const recipientIsNew = async (endpointConfig, recipient) => { |
|
|
if (!isRecipientValid(recipient)) return false |
|
|
if (!isRecipientValid(null, recipient)) return false |
|
|
const api = apiForEndpointConfig(RippleAPI, endpointConfig) |
|
|
const api = apiForEndpointConfig(RippleAPI, endpointConfig) |
|
|
try { |
|
|
try { |
|
|
await api.connect() |
|
|
await api.connect() |
|
@ -505,8 +514,9 @@ const RippleJSBridge: WalletBridge<Transaction> = { |
|
|
|
|
|
|
|
|
pullMoreOperations: () => Promise.resolve(a => a), // FIXME not implemented
|
|
|
pullMoreOperations: () => Promise.resolve(a => a), // FIXME not implemented
|
|
|
|
|
|
|
|
|
isRecipientValid: (currency, recipient) => Promise.resolve(isRecipientValid(recipient)), |
|
|
isRecipientValid: (account, recipient) => Promise.resolve(isRecipientValid(account, recipient)), |
|
|
getRecipientWarning: () => Promise.resolve(null), |
|
|
getRecipientWarning: (account, recipient) => |
|
|
|
|
|
Promise.resolve(getRecipientWarning(account, recipient)), |
|
|
|
|
|
|
|
|
createTransaction: () => ({ |
|
|
createTransaction: () => ({ |
|
|
amount: BigNumber(0), |
|
|
amount: BigNumber(0), |
|
|