@ -17,12 +17,11 @@ import getAddressCommand from 'commands/getAddress'
import signTransactionCommand from 'commands/signTransaction'
import signTransactionCommand from 'commands/signTransaction'
import { getAccountPlaceholderName , getNewAccountPlaceholderName } from 'helpers/accountName'
import { getAccountPlaceholderName , getNewAccountPlaceholderName } from 'helpers/accountName'
import { createCustomErrorClass } from 'helpers/errors'
import { createCustomErrorClass } from 'helpers/errors'
import { ETHAddressNonEIP } from 'config/errors'
import type { EditProps , WalletBridge } from './types'
import type { EditProps , WalletBridge } from './types'
const NotEnoughBalance = createCustomErrorClass ( 'NotEnoughBalance' )
const NotEnoughBalance = createCustomErrorClass ( 'NotEnoughBalance' )
// TODO in future it would be neat to support eip55
type Transaction = {
type Transaction = {
recipient : string ,
recipient : string ,
amount : BigNumber ,
amount : BigNumber ,
@ -101,6 +100,16 @@ const txToOps = (account: Account) => (tx: Tx): Operation[] => {
}
}
function isRecipientValid ( currency , recipient ) {
function isRecipientValid ( currency , recipient ) {
if ( ! recipient . match ( /^0x[0-9a-fA-F]{40}$/ ) ) return false
// To handle non-eip55 addresses we stop validation here if we detect
// address is either full upper or full lower.
// see https://github.com/LedgerHQ/ledger-live-desktop/issues/1397
const slice = recipient . substr ( 2 )
const isFullUpper = slice === slice . toUpperCase ( )
const isFullLower = slice === slice . toLowerCase ( )
if ( isFullUpper || isFullLower ) return true
try {
try {
return eip55 . verify ( recipient )
return eip55 . verify ( recipient )
} catch ( error ) {
} catch ( error ) {
@ -108,6 +117,18 @@ function isRecipientValid(currency, recipient) {
}
}
}
}
// Returns a warning if we detect a non-eip address
function getRecipientWarning ( currency , recipient ) {
if ( ! recipient . match ( /^0x[0-9a-fA-F]{40}$/ ) ) return null
const slice = recipient . substr ( 2 )
const isFullUpper = slice === slice . toUpperCase ( )
const isFullLower = slice === slice . toLowerCase ( )
if ( isFullUpper || isFullLower ) {
return new ETHAddressNonEIP ( )
}
return null
}
function mergeOps ( existing : Operation [ ] , newFetched : Operation [ ] ) {
function mergeOps ( existing : Operation [ ] , newFetched : Operation [ ] ) {
const ids = newFetched . map ( o => o . id )
const ids = newFetched . map ( o => o . id )
const all = newFetched . concat ( existing . filter ( o => ! ids . includes ( o . id ) ) )
const all = newFetched . concat ( existing . filter ( o => ! ids . includes ( o . id ) ) )
@ -378,6 +399,8 @@ const EthereumBridge: WalletBridge<Transaction> = {
pullMoreOperations : ( ) => Promise . resolve ( a => a ) , // NOT IMPLEMENTED
pullMoreOperations : ( ) => Promise . resolve ( a => a ) , // NOT IMPLEMENTED
isRecipientValid : ( currency , recipient ) => Promise . resolve ( isRecipientValid ( currency , recipient ) ) ,
isRecipientValid : ( currency , recipient ) => Promise . resolve ( isRecipientValid ( currency , recipient ) ) ,
getRecipientWarning : ( currency , recipient ) =>
Promise . resolve ( getRecipientWarning ( currency , recipient ) ) ,
createTransaction : ( ) => ( {
createTransaction : ( ) => ( {
amount : BigNumber ( 0 ) ,
amount : BigNumber ( 0 ) ,