2017-09-12 11:22:23 +02:00
|
|
|
const abi = require('human-standard-token-abi')
|
2018-05-14 15:30:50 +02:00
|
|
|
const pify = require('pify')
|
2017-07-20 21:38:38 +02:00
|
|
|
const getBuyEthUrl = require('../../app/scripts/lib/buy-eth-url')
|
2018-01-16 21:14:03 +01:00
|
|
|
const { getTokenAddressFromTokenObject } = require('./util')
|
2018-04-27 21:03:00 +02:00
|
|
|
const {
|
|
|
|
calcGasTotal,
|
|
|
|
calcTokenBalance,
|
2018-05-22 10:10:06 +02:00
|
|
|
estimateGas,
|
2018-06-20 17:48:23 +02:00
|
|
|
} = require('./components/send/send.utils')
|
2017-10-25 19:49:09 +02:00
|
|
|
const ethUtil = require('ethereumjs-util')
|
2018-03-16 01:29:45 +01:00
|
|
|
const { fetchLocale } = require('../i18n-helper')
|
2018-04-12 23:06:59 +02:00
|
|
|
const log = require('loglevel')
|
2018-07-24 05:25:04 +02:00
|
|
|
const { ENVIRONMENT_TYPE_NOTIFICATION } = require('../../app/scripts/lib/enums')
|
|
|
|
const { hasUnconfirmedTransactions } = require('./helpers/confirm-transaction/util')
|
2018-08-01 00:30:40 +02:00
|
|
|
const WebcamUtils = require('../lib/webcam-utils')
|
2017-04-05 03:23:46 +02:00
|
|
|
|
2016-04-14 00:28:44 +02:00
|
|
|
var actions = {
|
2016-10-20 21:07:53 +02:00
|
|
|
_setBackgroundConnection: _setBackgroundConnection,
|
|
|
|
|
2016-04-25 21:20:33 +02:00
|
|
|
GO_HOME: 'GO_HOME',
|
|
|
|
goHome: goHome,
|
2017-08-08 22:37:16 +02:00
|
|
|
// modal state
|
|
|
|
MODAL_OPEN: 'UI_MODAL_OPEN',
|
|
|
|
MODAL_CLOSE: 'UI_MODAL_CLOSE',
|
|
|
|
showModal: showModal,
|
|
|
|
hideModal: hideModal,
|
2017-08-02 22:03:36 +02:00
|
|
|
// sidebar state
|
|
|
|
SIDEBAR_OPEN: 'UI_SIDEBAR_OPEN',
|
|
|
|
SIDEBAR_CLOSE: 'UI_SIDEBAR_CLOSE',
|
2017-08-02 22:32:02 +02:00
|
|
|
showSidebar: showSidebar,
|
|
|
|
hideSidebar: hideSidebar,
|
2018-07-19 08:31:02 +02:00
|
|
|
// sidebar state
|
|
|
|
ALERT_OPEN: 'UI_ALERT_OPEN',
|
|
|
|
ALERT_CLOSE: 'UI_ALERT_CLOSE',
|
|
|
|
showAlert: showAlert,
|
|
|
|
hideAlert: hideAlert,
|
2018-07-25 02:32:20 +02:00
|
|
|
QR_CODE_DETECTED: 'UI_QR_CODE_DETECTED',
|
|
|
|
qrCodeDetected,
|
2017-08-13 22:15:21 +02:00
|
|
|
// network dropdown open
|
|
|
|
NETWORK_DROPDOWN_OPEN: 'UI_NETWORK_DROPDOWN_OPEN',
|
|
|
|
NETWORK_DROPDOWN_CLOSE: 'UI_NETWORK_DROPDOWN_CLOSE',
|
|
|
|
showNetworkDropdown: showNetworkDropdown,
|
|
|
|
hideNetworkDropdown: hideNetworkDropdown,
|
2018-03-16 01:29:45 +01:00
|
|
|
// menu state/
|
2016-06-02 01:30:14 +02:00
|
|
|
getNetworkStatus: 'getNetworkStatus',
|
2016-12-01 04:34:17 +01:00
|
|
|
// transition state
|
|
|
|
TRANSITION_FORWARD: 'TRANSITION_FORWARD',
|
|
|
|
TRANSITION_BACKWARD: 'TRANSITION_BACKWARD',
|
|
|
|
transitionForward,
|
|
|
|
transitionBackward,
|
2016-04-14 00:28:44 +02:00
|
|
|
// remote state
|
|
|
|
UPDATE_METAMASK_STATE: 'UPDATE_METAMASK_STATE',
|
|
|
|
updateMetamaskState: updateMetamaskState,
|
2016-12-07 23:34:15 +01:00
|
|
|
// notices
|
|
|
|
MARK_NOTICE_READ: 'MARK_NOTICE_READ',
|
|
|
|
markNoticeRead: markNoticeRead,
|
|
|
|
SHOW_NOTICE: 'SHOW_NOTICE',
|
|
|
|
showNotice: showNotice,
|
|
|
|
CLEAR_NOTICES: 'CLEAR_NOTICES',
|
|
|
|
clearNotices: clearNotices,
|
2016-12-20 22:53:14 +01:00
|
|
|
markAccountsFound,
|
2016-04-14 00:28:44 +02:00
|
|
|
// intialize screen
|
|
|
|
CREATE_NEW_VAULT_IN_PROGRESS: 'CREATE_NEW_VAULT_IN_PROGRESS',
|
|
|
|
SHOW_CREATE_VAULT: 'SHOW_CREATE_VAULT',
|
|
|
|
SHOW_RESTORE_VAULT: 'SHOW_RESTORE_VAULT',
|
2016-12-20 00:46:09 +01:00
|
|
|
FORGOT_PASSWORD: 'FORGOT_PASSWORD',
|
|
|
|
forgotPassword: forgotPassword,
|
2018-02-08 01:38:55 +01:00
|
|
|
markPasswordForgotten,
|
|
|
|
unMarkPasswordForgotten,
|
2016-04-14 00:28:44 +02:00
|
|
|
SHOW_INIT_MENU: 'SHOW_INIT_MENU',
|
|
|
|
SHOW_NEW_VAULT_SEED: 'SHOW_NEW_VAULT_SEED',
|
|
|
|
SHOW_INFO_PAGE: 'SHOW_INFO_PAGE',
|
2017-01-17 22:47:30 +01:00
|
|
|
SHOW_IMPORT_PAGE: 'SHOW_IMPORT_PAGE',
|
2018-01-10 19:25:38 +01:00
|
|
|
SHOW_NEW_ACCOUNT_PAGE: 'SHOW_NEW_ACCOUNT_PAGE',
|
|
|
|
SET_NEW_ACCOUNT_FORM: 'SET_NEW_ACCOUNT_FORM',
|
2016-04-14 00:28:44 +02:00
|
|
|
unlockMetamask: unlockMetamask,
|
|
|
|
unlockFailed: unlockFailed,
|
2018-01-30 03:44:43 +01:00
|
|
|
unlockSucceeded,
|
2016-04-14 00:28:44 +02:00
|
|
|
showCreateVault: showCreateVault,
|
|
|
|
showRestoreVault: showRestoreVault,
|
|
|
|
showInitializeMenu: showInitializeMenu,
|
2017-01-17 22:47:30 +01:00
|
|
|
showImportPage,
|
2018-01-10 19:25:38 +01:00
|
|
|
showNewAccountPage,
|
|
|
|
setNewAccountForm,
|
2016-11-01 19:25:38 +01:00
|
|
|
createNewVaultAndKeychain: createNewVaultAndKeychain,
|
|
|
|
createNewVaultAndRestore: createNewVaultAndRestore,
|
2016-04-14 00:28:44 +02:00
|
|
|
createNewVaultInProgress: createNewVaultInProgress,
|
2016-10-28 21:10:35 +02:00
|
|
|
addNewKeyring,
|
2017-01-19 00:17:08 +01:00
|
|
|
importNewAccount,
|
2016-10-28 21:10:35 +02:00
|
|
|
addNewAccount,
|
2018-06-10 09:52:32 +02:00
|
|
|
connectHardware,
|
2018-07-12 03:21:36 +02:00
|
|
|
checkHardwareStatus,
|
|
|
|
forgetDevice,
|
2018-08-11 03:54:34 +02:00
|
|
|
unlockHardwareWalletAccount,
|
2016-11-04 20:00:56 +01:00
|
|
|
NEW_ACCOUNT_SCREEN: 'NEW_ACCOUNT_SCREEN',
|
|
|
|
navigateToNewAccountScreen,
|
2018-01-31 09:33:15 +01:00
|
|
|
resetAccount,
|
2018-07-11 06:20:40 +02:00
|
|
|
removeAccount,
|
2016-04-14 00:28:44 +02:00
|
|
|
showNewVaultSeed: showNewVaultSeed,
|
|
|
|
showInfoPage: showInfoPage,
|
2018-03-08 18:31:21 +01:00
|
|
|
CLOSE_WELCOME_SCREEN: 'CLOSE_WELCOME_SCREEN',
|
|
|
|
closeWelcomeScreen,
|
2016-11-02 06:19:04 +01:00
|
|
|
// seed recovery actions
|
|
|
|
REVEAL_SEED_CONFIRMATION: 'REVEAL_SEED_CONFIRMATION',
|
|
|
|
revealSeedConfirmation: revealSeedConfirmation,
|
|
|
|
requestRevealSeed: requestRevealSeed,
|
2018-05-14 15:30:50 +02:00
|
|
|
requestRevealSeedWords,
|
2016-04-14 00:28:44 +02:00
|
|
|
// unlock screen
|
|
|
|
UNLOCK_IN_PROGRESS: 'UNLOCK_IN_PROGRESS',
|
|
|
|
UNLOCK_FAILED: 'UNLOCK_FAILED',
|
2018-01-30 03:44:43 +01:00
|
|
|
UNLOCK_SUCCEEDED: 'UNLOCK_SUCCEEDED',
|
2016-04-14 00:28:44 +02:00
|
|
|
UNLOCK_METAMASK: 'UNLOCK_METAMASK',
|
|
|
|
LOCK_METAMASK: 'LOCK_METAMASK',
|
|
|
|
tryUnlockMetamask: tryUnlockMetamask,
|
|
|
|
lockMetamask: lockMetamask,
|
|
|
|
unlockInProgress: unlockInProgress,
|
|
|
|
// error handling
|
|
|
|
displayWarning: displayWarning,
|
|
|
|
DISPLAY_WARNING: 'DISPLAY_WARNING',
|
|
|
|
HIDE_WARNING: 'HIDE_WARNING',
|
|
|
|
hideWarning: hideWarning,
|
|
|
|
// accounts screen
|
|
|
|
SET_SELECTED_ACCOUNT: 'SET_SELECTED_ACCOUNT',
|
2017-09-06 12:17:49 +02:00
|
|
|
SET_SELECTED_TOKEN: 'SET_SELECTED_TOKEN',
|
|
|
|
setSelectedToken,
|
2016-04-14 00:28:44 +02:00
|
|
|
SHOW_ACCOUNT_DETAIL: 'SHOW_ACCOUNT_DETAIL',
|
|
|
|
SHOW_ACCOUNTS_PAGE: 'SHOW_ACCOUNTS_PAGE',
|
|
|
|
SHOW_CONF_TX_PAGE: 'SHOW_CONF_TX_PAGE',
|
2016-05-03 23:32:22 +02:00
|
|
|
SHOW_CONF_MSG_PAGE: 'SHOW_CONF_MSG_PAGE',
|
2016-07-22 19:15:39 +02:00
|
|
|
SET_CURRENT_FIAT: 'SET_CURRENT_FIAT',
|
2018-08-01 00:30:40 +02:00
|
|
|
showQrScanner,
|
|
|
|
setCurrentCurrency,
|
2017-06-14 23:21:50 +02:00
|
|
|
setCurrentAccountTab,
|
2016-04-14 00:28:44 +02:00
|
|
|
// account detail screen
|
|
|
|
SHOW_SEND_PAGE: 'SHOW_SEND_PAGE',
|
|
|
|
showSendPage: showSendPage,
|
2017-09-07 13:24:03 +02:00
|
|
|
SHOW_SEND_TOKEN_PAGE: 'SHOW_SEND_TOKEN_PAGE',
|
|
|
|
showSendTokenPage,
|
2017-03-10 00:10:27 +01:00
|
|
|
ADD_TO_ADDRESS_BOOK: 'ADD_TO_ADDRESS_BOOK',
|
|
|
|
addToAddressBook: addToAddressBook,
|
2016-04-14 00:28:44 +02:00
|
|
|
REQUEST_ACCOUNT_EXPORT: 'REQUEST_ACCOUNT_EXPORT',
|
|
|
|
requestExportAccount: requestExportAccount,
|
|
|
|
EXPORT_ACCOUNT: 'EXPORT_ACCOUNT',
|
|
|
|
exportAccount: exportAccount,
|
|
|
|
SHOW_PRIVATE_KEY: 'SHOW_PRIVATE_KEY',
|
|
|
|
showPrivateKey: showPrivateKey,
|
2017-09-27 01:03:33 +02:00
|
|
|
exportAccountComplete,
|
2018-04-19 05:33:51 +02:00
|
|
|
SET_ACCOUNT_LABEL: 'SET_ACCOUNT_LABEL',
|
|
|
|
setAccountLabel,
|
2018-08-08 20:34:52 +02:00
|
|
|
updateNetworkNonce,
|
|
|
|
SET_NETWORK_NONCE: 'SET_NETWORK_NONCE',
|
2016-04-14 00:28:44 +02:00
|
|
|
// tx conf screen
|
|
|
|
COMPLETED_TX: 'COMPLETED_TX',
|
|
|
|
TRANSACTION_ERROR: 'TRANSACTION_ERROR',
|
|
|
|
NEXT_TX: 'NEXT_TX',
|
|
|
|
PREVIOUS_TX: 'PREV_TX',
|
2017-11-08 17:44:48 +01:00
|
|
|
EDIT_TX: 'EDIT_TX',
|
2016-05-03 23:32:22 +02:00
|
|
|
signMsg: signMsg,
|
|
|
|
cancelMsg: cancelMsg,
|
2017-02-23 01:23:13 +01:00
|
|
|
signPersonalMsg,
|
|
|
|
cancelPersonalMsg,
|
2017-09-29 18:24:08 +02:00
|
|
|
signTypedMsg,
|
|
|
|
cancelTypedMsg,
|
2016-04-14 00:28:44 +02:00
|
|
|
sendTx: sendTx,
|
2016-05-06 23:46:04 +02:00
|
|
|
signTx: signTx,
|
2017-09-12 11:22:23 +02:00
|
|
|
signTokenTx: signTokenTx,
|
2017-12-20 18:17:16 +01:00
|
|
|
updateTransaction,
|
2017-02-28 03:26:04 +01:00
|
|
|
updateAndApproveTx,
|
2016-04-14 00:28:44 +02:00
|
|
|
cancelTx: cancelTx,
|
|
|
|
completedTx: completedTx,
|
|
|
|
txError: txError,
|
|
|
|
nextTx: nextTx,
|
2017-11-08 17:44:48 +01:00
|
|
|
editTx,
|
2016-04-14 00:28:44 +02:00
|
|
|
previousTx: previousTx,
|
2017-08-15 06:29:21 +02:00
|
|
|
cancelAllTx: cancelAllTx,
|
2016-05-26 23:32:45 +02:00
|
|
|
viewPendingTx: viewPendingTx,
|
|
|
|
VIEW_PENDING_TX: 'VIEW_PENDING_TX',
|
2017-11-08 17:44:48 +01:00
|
|
|
updateTransactionParams,
|
|
|
|
UPDATE_TRANSACTION_PARAMS: 'UPDATE_TRANSACTION_PARAMS',
|
2017-09-22 06:15:26 +02:00
|
|
|
// send screen
|
2017-10-12 18:42:14 +02:00
|
|
|
UPDATE_GAS_LIMIT: 'UPDATE_GAS_LIMIT',
|
|
|
|
UPDATE_GAS_PRICE: 'UPDATE_GAS_PRICE',
|
2017-10-17 19:22:23 +02:00
|
|
|
UPDATE_GAS_TOTAL: 'UPDATE_GAS_TOTAL',
|
|
|
|
UPDATE_SEND_FROM: 'UPDATE_SEND_FROM',
|
2018-07-17 00:31:36 +02:00
|
|
|
UPDATE_SEND_HEX_DATA: 'UPDATE_SEND_HEX_DATA',
|
2017-10-30 18:48:50 +01:00
|
|
|
UPDATE_SEND_TOKEN_BALANCE: 'UPDATE_SEND_TOKEN_BALANCE',
|
2017-10-17 19:22:23 +02:00
|
|
|
UPDATE_SEND_TO: 'UPDATE_SEND_TO',
|
|
|
|
UPDATE_SEND_AMOUNT: 'UPDATE_SEND_AMOUNT',
|
|
|
|
UPDATE_SEND_MEMO: 'UPDATE_SEND_MEMO',
|
2017-10-17 22:13:20 +02:00
|
|
|
UPDATE_SEND_ERRORS: 'UPDATE_SEND_ERRORS',
|
2017-11-16 19:14:25 +01:00
|
|
|
UPDATE_MAX_MODE: 'UPDATE_MAX_MODE',
|
2017-11-10 04:49:16 +01:00
|
|
|
UPDATE_SEND: 'UPDATE_SEND',
|
2017-10-21 04:05:22 +02:00
|
|
|
CLEAR_SEND: 'CLEAR_SEND',
|
2018-04-07 00:29:51 +02:00
|
|
|
OPEN_FROM_DROPDOWN: 'OPEN_FROM_DROPDOWN',
|
|
|
|
CLOSE_FROM_DROPDOWN: 'CLOSE_FROM_DROPDOWN',
|
2018-06-19 17:53:33 +02:00
|
|
|
GAS_LOADING_STARTED: 'GAS_LOADING_STARTED',
|
|
|
|
GAS_LOADING_FINISHED: 'GAS_LOADING_FINISHED',
|
2018-05-20 02:37:44 +02:00
|
|
|
setGasLimit,
|
|
|
|
setGasPrice,
|
|
|
|
updateGasData,
|
2018-04-27 21:03:00 +02:00
|
|
|
setGasTotal,
|
|
|
|
setSendTokenBalance,
|
2017-10-30 18:48:50 +01:00
|
|
|
updateSendTokenBalance,
|
2017-10-17 19:22:23 +02:00
|
|
|
updateSendFrom,
|
2018-07-17 00:31:36 +02:00
|
|
|
updateSendHexData,
|
2017-10-17 19:22:23 +02:00
|
|
|
updateSendTo,
|
|
|
|
updateSendAmount,
|
|
|
|
updateSendMemo,
|
2017-11-16 19:14:25 +01:00
|
|
|
setMaxModeTo,
|
2017-11-10 04:49:16 +01:00
|
|
|
updateSend,
|
2018-04-27 21:03:00 +02:00
|
|
|
updateSendErrors,
|
2017-10-21 04:05:22 +02:00
|
|
|
clearSend,
|
2017-10-12 19:29:03 +02:00
|
|
|
setSelectedAddress,
|
2018-06-19 17:53:33 +02:00
|
|
|
gasLoadingStarted,
|
|
|
|
gasLoadingFinished,
|
2016-04-14 00:28:44 +02:00
|
|
|
// app messages
|
2016-10-31 19:35:09 +01:00
|
|
|
confirmSeedWords: confirmSeedWords,
|
2016-04-14 00:28:44 +02:00
|
|
|
showAccountDetail: showAccountDetail,
|
|
|
|
BACK_TO_ACCOUNT_DETAIL: 'BACK_TO_ACCOUNT_DETAIL',
|
|
|
|
backToAccountDetail: backToAccountDetail,
|
|
|
|
showAccountsPage: showAccountsPage,
|
|
|
|
showConfTxPage: showConfTxPage,
|
|
|
|
// config screen
|
|
|
|
SHOW_CONFIG_PAGE: 'SHOW_CONFIG_PAGE',
|
|
|
|
SET_RPC_TARGET: 'SET_RPC_TARGET',
|
2017-03-07 19:25:50 +01:00
|
|
|
SET_DEFAULT_RPC_TARGET: 'SET_DEFAULT_RPC_TARGET',
|
2016-05-11 00:37:13 +02:00
|
|
|
SET_PROVIDER_TYPE: 'SET_PROVIDER_TYPE',
|
2017-06-15 05:42:48 +02:00
|
|
|
showConfigPage,
|
|
|
|
SHOW_ADD_TOKEN_PAGE: 'SHOW_ADD_TOKEN_PAGE',
|
2018-08-07 23:40:45 +02:00
|
|
|
SHOW_ADD_SUGGESTED_TOKEN_PAGE: 'SHOW_ADD_SUGGESTED_TOKEN_PAGE',
|
2017-06-15 05:42:48 +02:00
|
|
|
showAddTokenPage,
|
2018-08-07 23:40:45 +02:00
|
|
|
showAddSuggestedTokenPage,
|
2017-06-16 01:22:53 +02:00
|
|
|
addToken,
|
2017-09-22 03:44:52 +02:00
|
|
|
addTokens,
|
2017-10-03 19:25:52 +02:00
|
|
|
removeToken,
|
|
|
|
updateTokens,
|
2018-08-04 01:24:12 +02:00
|
|
|
removeSuggestedTokens,
|
2017-10-03 19:25:52 +02:00
|
|
|
UPDATE_TOKENS: 'UPDATE_TOKENS',
|
2016-04-14 00:28:44 +02:00
|
|
|
setRpcTarget: setRpcTarget,
|
2016-05-11 00:37:13 +02:00
|
|
|
setProviderType: setProviderType,
|
2018-08-14 01:29:43 +02:00
|
|
|
SET_HARDWARE_WALLET_DEFAULT_HD_PATH: 'SET_HARDWARE_WALLET_DEFAULT_HD_PATH',
|
|
|
|
setHardwareWalletDefaultHdPath,
|
2017-10-05 01:12:07 +02:00
|
|
|
updateProviderType,
|
2016-04-14 00:28:44 +02:00
|
|
|
// loading overlay
|
|
|
|
SHOW_LOADING: 'SHOW_LOADING_INDICATION',
|
|
|
|
HIDE_LOADING: 'HIDE_LOADING_INDICATION',
|
|
|
|
showLoadingIndication: showLoadingIndication,
|
|
|
|
hideLoadingIndication: hideLoadingIndication,
|
2016-08-10 22:43:01 +02:00
|
|
|
// buy Eth with coinbase
|
2017-09-19 00:41:25 +02:00
|
|
|
onboardingBuyEthView,
|
|
|
|
ONBOARDING_BUY_ETH_VIEW: 'ONBOARDING_BUY_ETH_VIEW',
|
2016-08-10 22:43:01 +02:00
|
|
|
BUY_ETH: 'BUY_ETH',
|
|
|
|
buyEth: buyEth,
|
2016-08-13 00:41:59 +02:00
|
|
|
buyEthView: buyEthView,
|
2017-09-25 23:51:49 +02:00
|
|
|
buyWithShapeShift,
|
2016-08-13 00:41:59 +02:00
|
|
|
BUY_ETH_VIEW: 'BUY_ETH_VIEW',
|
2016-08-10 22:43:01 +02:00
|
|
|
COINBASE_SUBVIEW: 'COINBASE_SUBVIEW',
|
|
|
|
coinBaseSubview: coinBaseSubview,
|
|
|
|
SHAPESHIFT_SUBVIEW: 'SHAPESHIFT_SUBVIEW',
|
|
|
|
shapeShiftSubview: shapeShiftSubview,
|
|
|
|
PAIR_UPDATE: 'PAIR_UPDATE',
|
|
|
|
pairUpdate: pairUpdate,
|
|
|
|
coinShiftRquest: coinShiftRquest,
|
|
|
|
SHOW_SUB_LOADING_INDICATION: 'SHOW_SUB_LOADING_INDICATION',
|
|
|
|
showSubLoadingIndication: showSubLoadingIndication,
|
|
|
|
HIDE_SUB_LOADING_INDICATION: 'HIDE_SUB_LOADING_INDICATION',
|
|
|
|
hideSubLoadingIndication: hideSubLoadingIndication,
|
2016-08-13 00:41:59 +02:00
|
|
|
// QR STUFF:
|
|
|
|
SHOW_QR: 'SHOW_QR',
|
2016-09-13 02:27:14 +02:00
|
|
|
showQrView: showQrView,
|
2016-08-18 19:40:35 +02:00
|
|
|
reshowQrCode: reshowQrCode,
|
|
|
|
SHOW_QR_VIEW: 'SHOW_QR_VIEW',
|
2016-08-24 02:17:08 +02:00
|
|
|
// FORGOT PASSWORD:
|
|
|
|
BACK_TO_INIT_MENU: 'BACK_TO_INIT_MENU',
|
|
|
|
goBackToInitView: goBackToInitView,
|
|
|
|
RECOVERY_IN_PROGRESS: 'RECOVERY_IN_PROGRESS',
|
|
|
|
BACK_TO_UNLOCK_VIEW: 'BACK_TO_UNLOCK_VIEW',
|
|
|
|
backToUnlockView: backToUnlockView,
|
2016-10-15 19:48:12 +02:00
|
|
|
// SHOWING KEYCHAIN
|
|
|
|
SHOW_NEW_KEYCHAIN: 'SHOW_NEW_KEYCHAIN',
|
|
|
|
showNewKeychain: showNewKeychain,
|
|
|
|
|
2017-01-03 19:39:34 +01:00
|
|
|
callBackgroundThenUpdate,
|
2017-02-03 01:46:56 +01:00
|
|
|
forceUpdateMetamaskState,
|
2017-10-16 07:28:25 +02:00
|
|
|
|
|
|
|
TOGGLE_ACCOUNT_MENU: 'TOGGLE_ACCOUNT_MENU',
|
|
|
|
toggleAccountMenu,
|
2017-11-02 03:30:33 +01:00
|
|
|
|
|
|
|
useEtherscanProvider,
|
2017-11-24 02:33:44 +01:00
|
|
|
|
2017-11-24 18:35:17 +01:00
|
|
|
SET_USE_BLOCKIE: 'SET_USE_BLOCKIE',
|
|
|
|
setUseBlockie,
|
2017-12-22 19:43:02 +01:00
|
|
|
|
2018-03-16 01:29:45 +01:00
|
|
|
// locale
|
|
|
|
SET_CURRENT_LOCALE: 'SET_CURRENT_LOCALE',
|
|
|
|
SET_LOCALE_MESSAGES: 'SET_LOCALE_MESSAGES',
|
|
|
|
setCurrentLocale,
|
|
|
|
updateCurrentLocale,
|
|
|
|
setLocaleMessages,
|
|
|
|
//
|
2017-11-14 17:04:55 +01:00
|
|
|
// Feature Flags
|
|
|
|
setFeatureFlag,
|
|
|
|
updateFeatureFlags,
|
|
|
|
UPDATE_FEATURE_FLAGS: 'UPDATE_FEATURE_FLAGS',
|
2017-12-22 19:43:02 +01:00
|
|
|
|
2018-02-12 18:45:53 +01:00
|
|
|
setMouseUserState,
|
|
|
|
SET_MOUSE_USER_STATE: 'SET_MOUSE_USER_STATE',
|
|
|
|
|
2017-12-22 19:43:02 +01:00
|
|
|
// Network
|
|
|
|
updateNetworkEndpointType,
|
|
|
|
UPDATE_NETWORK_ENDPOINT_TYPE: 'UPDATE_NETWORK_ENDPOINT_TYPE',
|
|
|
|
|
2017-12-07 04:20:11 +01:00
|
|
|
retryTransaction,
|
2018-05-20 08:04:19 +02:00
|
|
|
SET_PENDING_TOKENS: 'SET_PENDING_TOKENS',
|
|
|
|
CLEAR_PENDING_TOKENS: 'CLEAR_PENDING_TOKENS',
|
|
|
|
setPendingTokens,
|
|
|
|
clearPendingTokens,
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = actions
|
|
|
|
|
2016-10-20 18:58:33 +02:00
|
|
|
var background = null
|
2016-11-11 19:26:12 +01:00
|
|
|
function _setBackgroundConnection (backgroundConnection) {
|
2016-10-20 18:58:33 +02:00
|
|
|
background = backgroundConnection
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function goHome () {
|
2016-04-25 21:20:33 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.GO_HOME,
|
2016-04-25 21:20:33 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-04-14 00:28:44 +02:00
|
|
|
// async actions
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function tryUnlockMetamask (password) {
|
2018-03-08 16:29:29 +01:00
|
|
|
return dispatch => {
|
2016-09-09 04:53:54 +02:00
|
|
|
dispatch(actions.showLoadingIndication())
|
2016-05-25 21:39:12 +02:00
|
|
|
dispatch(actions.unlockInProgress())
|
2017-02-23 23:23:45 +01:00
|
|
|
log.debug(`background.submitPassword`)
|
2018-03-03 22:08:10 +01:00
|
|
|
|
2018-03-08 16:29:29 +01:00
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
background.submitPassword(password, error => {
|
|
|
|
if (error) {
|
|
|
|
return reject(error)
|
|
|
|
}
|
2018-03-03 22:08:10 +01:00
|
|
|
|
2018-03-08 16:29:29 +01:00
|
|
|
resolve()
|
|
|
|
})
|
2016-04-14 00:28:44 +02:00
|
|
|
})
|
2018-03-08 16:29:29 +01:00
|
|
|
.then(() => {
|
2018-01-30 03:44:43 +01:00
|
|
|
dispatch(actions.unlockSucceeded())
|
2018-03-08 16:29:29 +01:00
|
|
|
return forceUpdateMetamaskState(dispatch)
|
|
|
|
})
|
|
|
|
.then(() => {
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
background.verifySeedPhrase(err => {
|
|
|
|
if (err) {
|
|
|
|
dispatch(actions.displayWarning(err.message))
|
2018-05-14 15:30:50 +02:00
|
|
|
return reject(err)
|
2018-03-08 16:29:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
resolve()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
|
|
|
.then(() => {
|
2016-12-01 04:34:17 +01:00
|
|
|
dispatch(actions.transitionForward())
|
2018-03-08 16:29:29 +01:00
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
})
|
|
|
|
.catch(err => {
|
|
|
|
dispatch(actions.unlockFailed(err.message))
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
2018-05-14 15:30:50 +02:00
|
|
|
return Promise.reject(err)
|
2018-03-08 16:29:29 +01:00
|
|
|
})
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-12-19 23:55:52 +01:00
|
|
|
function transitionForward () {
|
2016-12-01 04:34:17 +01:00
|
|
|
return {
|
|
|
|
type: this.TRANSITION_FORWARD,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-12-19 23:55:52 +01:00
|
|
|
function transitionBackward () {
|
2016-12-01 04:34:17 +01:00
|
|
|
return {
|
|
|
|
type: this.TRANSITION_BACKWARD,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-05-14 15:30:50 +02:00
|
|
|
function confirmSeedWords () {
|
2017-11-29 05:24:35 +01:00
|
|
|
return dispatch => {
|
2018-05-14 15:30:50 +02:00
|
|
|
dispatch(actions.showLoadingIndication())
|
|
|
|
log.debug(`background.clearSeedWordCache`)
|
2017-08-23 13:04:11 +02:00
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
background.clearSeedWordCache((err, account) => {
|
2018-05-14 15:30:50 +02:00
|
|
|
dispatch(actions.hideLoadingIndication())
|
2017-08-23 13:04:11 +02:00
|
|
|
if (err) {
|
|
|
|
dispatch(actions.displayWarning(err.message))
|
2017-11-29 05:24:35 +01:00
|
|
|
return reject(err)
|
2017-08-23 13:04:11 +02:00
|
|
|
}
|
2016-10-31 19:35:09 +01:00
|
|
|
|
2017-08-23 13:04:11 +02:00
|
|
|
log.info('Seed word cache cleared. ' + account)
|
2017-08-30 10:30:55 +02:00
|
|
|
dispatch(actions.showAccountsPage())
|
2017-08-23 13:04:11 +02:00
|
|
|
resolve(account)
|
|
|
|
})
|
2016-10-31 19:35:09 +01:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-11-01 19:25:38 +01:00
|
|
|
function createNewVaultAndRestore (password, seed) {
|
2016-04-14 00:28:44 +02:00
|
|
|
return (dispatch) => {
|
2016-11-01 19:25:38 +01:00
|
|
|
dispatch(actions.showLoadingIndication())
|
2017-02-23 23:23:45 +01:00
|
|
|
log.debug(`background.createNewVaultAndRestore`)
|
2017-10-21 07:31:59 +02:00
|
|
|
|
|
|
|
return new Promise((resolve, reject) => {
|
2018-03-08 16:29:29 +01:00
|
|
|
background.createNewVaultAndRestore(password, seed, err => {
|
2017-10-21 07:31:59 +02:00
|
|
|
if (err) {
|
|
|
|
return reject(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
resolve()
|
|
|
|
})
|
2016-11-01 19:25:38 +01:00
|
|
|
})
|
2018-03-08 16:29:29 +01:00
|
|
|
.then(() => dispatch(actions.unMarkPasswordForgotten()))
|
|
|
|
.then(() => {
|
|
|
|
dispatch(actions.showAccountsPage())
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
})
|
|
|
|
.catch(err => {
|
|
|
|
dispatch(actions.displayWarning(err.message))
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
})
|
2016-11-01 19:25:38 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-11-22 00:49:03 +01:00
|
|
|
function createNewVaultAndKeychain (password) {
|
2018-03-08 16:29:29 +01:00
|
|
|
return dispatch => {
|
2017-01-25 00:33:33 +01:00
|
|
|
dispatch(actions.showLoadingIndication())
|
2017-02-23 23:23:45 +01:00
|
|
|
log.debug(`background.createNewVaultAndKeychain`)
|
2017-08-21 13:56:09 +02:00
|
|
|
|
|
|
|
return new Promise((resolve, reject) => {
|
2018-03-08 16:29:29 +01:00
|
|
|
background.createNewVaultAndKeychain(password, err => {
|
2017-01-25 00:33:33 +01:00
|
|
|
if (err) {
|
2017-08-21 13:56:09 +02:00
|
|
|
dispatch(actions.displayWarning(err.message))
|
|
|
|
return reject(err)
|
2017-01-25 00:33:33 +01:00
|
|
|
}
|
2018-03-08 16:29:29 +01:00
|
|
|
|
2017-08-21 13:56:09 +02:00
|
|
|
log.debug(`background.placeSeedWords`)
|
2018-03-08 16:29:29 +01:00
|
|
|
|
2017-08-21 13:56:09 +02:00
|
|
|
background.placeSeedWords((err) => {
|
|
|
|
if (err) {
|
|
|
|
dispatch(actions.displayWarning(err.message))
|
|
|
|
return reject(err)
|
|
|
|
}
|
2018-03-08 16:29:29 +01:00
|
|
|
|
2017-08-21 13:56:09 +02:00
|
|
|
resolve()
|
|
|
|
})
|
2017-01-25 00:33:33 +01:00
|
|
|
})
|
|
|
|
})
|
2018-03-08 16:29:29 +01:00
|
|
|
.then(() => forceUpdateMetamaskState(dispatch))
|
|
|
|
.then(() => dispatch(actions.hideLoadingIndication()))
|
|
|
|
.catch(() => dispatch(actions.hideLoadingIndication()))
|
2017-01-25 00:33:33 +01:00
|
|
|
}
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
|
2016-11-02 06:19:04 +01:00
|
|
|
function revealSeedConfirmation () {
|
|
|
|
return {
|
|
|
|
type: this.REVEAL_SEED_CONFIRMATION,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-05-14 15:30:50 +02:00
|
|
|
function verifyPassword (password) {
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
background.submitPassword(password, error => {
|
|
|
|
if (error) {
|
|
|
|
return reject(error)
|
|
|
|
}
|
|
|
|
|
|
|
|
resolve(true)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
function verifySeedPhrase () {
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
background.verifySeedPhrase((error, seedWords) => {
|
|
|
|
if (error) {
|
|
|
|
return reject(error)
|
|
|
|
}
|
|
|
|
|
|
|
|
resolve(seedWords)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2016-11-02 06:19:04 +01:00
|
|
|
function requestRevealSeed (password) {
|
2018-03-08 16:29:29 +01:00
|
|
|
return dispatch => {
|
2016-11-02 06:19:04 +01:00
|
|
|
dispatch(actions.showLoadingIndication())
|
2017-02-23 23:23:45 +01:00
|
|
|
log.debug(`background.submitPassword`)
|
2018-03-08 16:29:29 +01:00
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
background.submitPassword(password, err => {
|
|
|
|
if (err) {
|
|
|
|
dispatch(actions.displayWarning(err.message))
|
|
|
|
return reject(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
log.debug(`background.placeSeedWords`)
|
|
|
|
background.placeSeedWords((err, result) => {
|
|
|
|
if (err) {
|
|
|
|
dispatch(actions.displayWarning(err.message))
|
|
|
|
return reject(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
dispatch(actions.showNewVaultSeed(result))
|
2018-05-14 15:30:50 +02:00
|
|
|
dispatch(actions.hideLoadingIndication())
|
2018-03-08 16:29:29 +01:00
|
|
|
resolve()
|
|
|
|
})
|
2016-11-22 05:08:36 +01:00
|
|
|
})
|
2016-11-02 06:19:04 +01:00
|
|
|
})
|
2018-05-14 15:30:50 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function requestRevealSeedWords (password) {
|
|
|
|
return async dispatch => {
|
|
|
|
dispatch(actions.showLoadingIndication())
|
|
|
|
log.debug(`background.submitPassword`)
|
|
|
|
|
|
|
|
try {
|
|
|
|
await verifyPassword(password)
|
|
|
|
const seedWords = await verifySeedPhrase()
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
return seedWords
|
|
|
|
} catch (error) {
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
dispatch(actions.displayWarning(error.message))
|
|
|
|
throw new Error(error.message)
|
|
|
|
}
|
2016-11-02 06:19:04 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-01-31 09:33:15 +01:00
|
|
|
function resetAccount () {
|
2018-05-31 01:17:40 +02:00
|
|
|
return dispatch => {
|
|
|
|
dispatch(actions.showLoadingIndication())
|
2018-01-31 09:33:15 +01:00
|
|
|
|
2018-05-31 01:17:40 +02:00
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
background.resetAccount((err, account) => {
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
if (err) {
|
|
|
|
dispatch(actions.displayWarning(err.message))
|
|
|
|
return reject(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
log.info('Transaction history reset for ' + account)
|
|
|
|
dispatch(actions.showAccountsPage())
|
|
|
|
resolve(account)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
2018-01-31 09:33:15 +01:00
|
|
|
}
|
|
|
|
|
2018-07-11 06:20:40 +02:00
|
|
|
function removeAccount (address) {
|
|
|
|
return dispatch => {
|
|
|
|
dispatch(actions.showLoadingIndication())
|
|
|
|
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
background.removeAccount(address, (err, account) => {
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
if (err) {
|
|
|
|
dispatch(actions.displayWarning(err.message))
|
|
|
|
return reject(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
log.info('Account removed: ' + account)
|
|
|
|
dispatch(actions.showAccountsPage())
|
|
|
|
resolve()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-10-21 01:44:31 +02:00
|
|
|
function addNewKeyring (type, opts) {
|
2017-01-18 01:22:22 +01:00
|
|
|
return (dispatch) => {
|
|
|
|
dispatch(actions.showLoadingIndication())
|
2017-02-23 23:23:45 +01:00
|
|
|
log.debug(`background.addNewKeyring`)
|
2017-01-27 07:30:12 +01:00
|
|
|
background.addNewKeyring(type, opts, (err) => {
|
2017-01-18 01:22:22 +01:00
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
if (err) return dispatch(actions.displayWarning(err.message))
|
|
|
|
dispatch(actions.showAccountsPage())
|
|
|
|
})
|
|
|
|
}
|
2016-10-21 01:44:31 +02:00
|
|
|
}
|
|
|
|
|
2017-01-19 00:17:08 +01:00
|
|
|
function importNewAccount (strategy, args) {
|
2018-05-14 15:30:50 +02:00
|
|
|
return async (dispatch) => {
|
|
|
|
let newState
|
|
|
|
dispatch(actions.showLoadingIndication('This may take a while, please be patient.'))
|
|
|
|
try {
|
|
|
|
log.debug(`background.importAccountWithStrategy`)
|
|
|
|
await pify(background.importAccountWithStrategy).call(background, strategy, args)
|
|
|
|
log.debug(`background.getState`)
|
|
|
|
newState = await pify(background.getState).call(background)
|
|
|
|
} catch (err) {
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
dispatch(actions.displayWarning(err.message))
|
|
|
|
throw err
|
|
|
|
}
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
dispatch(actions.updateMetamaskState(newState))
|
2018-05-30 21:13:45 +02:00
|
|
|
if (newState.selectedAddress) {
|
|
|
|
dispatch({
|
|
|
|
type: actions.SHOW_ACCOUNT_DETAIL,
|
|
|
|
value: newState.selectedAddress,
|
|
|
|
})
|
|
|
|
}
|
2018-05-14 15:30:50 +02:00
|
|
|
return newState
|
2017-01-19 00:17:08 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-04-27 06:05:45 +02:00
|
|
|
function navigateToNewAccountScreen () {
|
2016-11-04 20:00:56 +01:00
|
|
|
return {
|
2016-11-04 20:31:03 +01:00
|
|
|
type: this.NEW_ACCOUNT_SCREEN,
|
2016-11-04 20:00:56 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-01-24 21:06:59 +01:00
|
|
|
function addNewAccount () {
|
2017-02-23 23:23:45 +01:00
|
|
|
log.debug(`background.addNewAccount`)
|
2017-09-22 23:00:00 +02:00
|
|
|
return (dispatch, getState) => {
|
|
|
|
const oldIdentities = getState().metamask.identities
|
2017-09-22 08:59:27 +02:00
|
|
|
dispatch(actions.showLoadingIndication())
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
background.addNewAccount((err, { identities: newIdentities}) => {
|
|
|
|
if (err) {
|
|
|
|
dispatch(actions.displayWarning(err.message))
|
|
|
|
return reject(err)
|
|
|
|
}
|
|
|
|
const newAccountAddress = Object.keys(newIdentities).find(address => !oldIdentities[address])
|
|
|
|
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
|
|
|
|
forceUpdateMetamaskState(dispatch)
|
|
|
|
return resolve(newAccountAddress)
|
|
|
|
})
|
2017-11-02 13:15:59 +01:00
|
|
|
})
|
2017-09-22 08:59:27 +02:00
|
|
|
}
|
2016-10-28 21:10:35 +02:00
|
|
|
}
|
|
|
|
|
2018-08-14 01:29:43 +02:00
|
|
|
function checkHardwareStatus (deviceName, hdPath) {
|
|
|
|
log.debug(`background.checkHardwareStatus`, deviceName, hdPath)
|
2018-07-12 03:21:36 +02:00
|
|
|
return (dispatch, getState) => {
|
|
|
|
dispatch(actions.showLoadingIndication())
|
|
|
|
return new Promise((resolve, reject) => {
|
2018-08-14 01:29:43 +02:00
|
|
|
background.checkHardwareStatus(deviceName, hdPath, (err, unlocked) => {
|
2018-07-12 03:21:36 +02:00
|
|
|
if (err) {
|
|
|
|
log.error(err)
|
|
|
|
dispatch(actions.displayWarning(err.message))
|
|
|
|
return reject(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
|
|
|
|
forceUpdateMetamaskState(dispatch)
|
|
|
|
return resolve(unlocked)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function forgetDevice (deviceName) {
|
|
|
|
log.debug(`background.forgetDevice`, deviceName)
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
dispatch(actions.showLoadingIndication())
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
background.forgetDevice(deviceName, (err, response) => {
|
|
|
|
if (err) {
|
|
|
|
log.error(err)
|
|
|
|
dispatch(actions.displayWarning(err.message))
|
|
|
|
return reject(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
|
|
|
|
forceUpdateMetamaskState(dispatch)
|
|
|
|
return resolve()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-14 01:29:43 +02:00
|
|
|
function connectHardware (deviceName, page, hdPath) {
|
|
|
|
log.debug(`background.connectHardware`, deviceName, page, hdPath)
|
2018-06-10 09:52:32 +02:00
|
|
|
return (dispatch, getState) => {
|
|
|
|
dispatch(actions.showLoadingIndication())
|
|
|
|
return new Promise((resolve, reject) => {
|
2018-08-14 01:29:43 +02:00
|
|
|
background.connectHardware(deviceName, page, hdPath, (err, accounts) => {
|
2018-06-10 09:52:32 +02:00
|
|
|
if (err) {
|
|
|
|
log.error(err)
|
|
|
|
dispatch(actions.displayWarning(err.message))
|
|
|
|
return reject(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
|
|
|
|
forceUpdateMetamaskState(dispatch)
|
|
|
|
return resolve(accounts)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-14 01:29:43 +02:00
|
|
|
function unlockHardwareWalletAccount (index, deviceName, hdPath) {
|
|
|
|
log.debug(`background.unlockHardwareWalletAccount`, index, deviceName, hdPath)
|
2018-06-10 09:52:32 +02:00
|
|
|
return (dispatch, getState) => {
|
|
|
|
dispatch(actions.showLoadingIndication())
|
|
|
|
return new Promise((resolve, reject) => {
|
2018-08-14 01:29:43 +02:00
|
|
|
background.unlockHardwareWalletAccount(index, deviceName, hdPath, (err, accounts) => {
|
2018-06-10 09:52:32 +02:00
|
|
|
if (err) {
|
|
|
|
log.error(err)
|
|
|
|
dispatch(actions.displayWarning(err.message))
|
|
|
|
return reject(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
return resolve()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function showInfoPage () {
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.SHOW_INFO_PAGE,
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-01 00:30:40 +02:00
|
|
|
function showQrScanner (ROUTE) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
return WebcamUtils.checkStatus()
|
|
|
|
.then(status => {
|
|
|
|
if (!status.environmentReady) {
|
|
|
|
// We need to switch to fullscreen mode to ask for permission
|
|
|
|
global.platform.openExtensionInBrowser(`${ROUTE}`, `scan=true`)
|
|
|
|
} else {
|
|
|
|
dispatch(actions.showModal({
|
|
|
|
name: 'QR_SCANNER',
|
|
|
|
}))
|
|
|
|
}
|
|
|
|
}).catch(e => {
|
|
|
|
dispatch(actions.showModal({
|
|
|
|
name: 'QR_SCANNER',
|
|
|
|
error: true,
|
|
|
|
errorType: e.type,
|
|
|
|
}))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-03-15 01:06:16 +01:00
|
|
|
function setCurrentCurrency (currencyCode) {
|
2016-07-21 18:30:58 +02:00
|
|
|
return (dispatch) => {
|
2017-08-29 14:54:58 +02:00
|
|
|
dispatch(actions.showLoadingIndication())
|
2017-03-15 01:06:16 +01:00
|
|
|
log.debug(`background.setCurrentCurrency`)
|
2017-02-03 08:32:24 +01:00
|
|
|
background.setCurrentCurrency(currencyCode, (err, data) => {
|
2017-08-29 14:54:58 +02:00
|
|
|
dispatch(actions.hideLoadingIndication())
|
2017-02-03 08:32:24 +01:00
|
|
|
if (err) {
|
2017-06-14 23:21:50 +02:00
|
|
|
log.error(err.stack)
|
2017-02-03 08:32:24 +01:00
|
|
|
return dispatch(actions.displayWarning(err.message))
|
|
|
|
}
|
2016-07-21 18:30:58 +02:00
|
|
|
dispatch({
|
2017-08-29 14:54:58 +02:00
|
|
|
type: actions.SET_CURRENT_FIAT,
|
2016-07-21 19:15:34 +02:00
|
|
|
value: {
|
2017-03-15 01:06:16 +01:00
|
|
|
currentCurrency: data.currentCurrency,
|
2016-07-21 19:15:34 +02:00
|
|
|
conversionRate: data.conversionRate,
|
2016-07-21 23:08:26 +02:00
|
|
|
conversionDate: data.conversionDate,
|
2016-07-22 19:15:39 +02:00
|
|
|
},
|
2016-07-21 18:30:58 +02:00
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function signMsg (msgData) {
|
2017-02-23 23:23:45 +01:00
|
|
|
log.debug('action - signMsg')
|
2018-07-24 05:25:04 +02:00
|
|
|
return (dispatch, getState) => {
|
2016-05-25 21:39:12 +02:00
|
|
|
dispatch(actions.showLoadingIndication())
|
2016-04-14 00:28:44 +02:00
|
|
|
|
2017-12-05 04:27:42 +01:00
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
log.debug(`actions calling background.signMessage`)
|
|
|
|
background.signMessage(msgData, (err, newState) => {
|
|
|
|
log.debug('signMessage called back')
|
|
|
|
dispatch(actions.updateMetamaskState(newState))
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
2016-04-14 00:28:44 +02:00
|
|
|
|
2017-12-05 04:27:42 +01:00
|
|
|
if (err) {
|
|
|
|
log.error(err)
|
|
|
|
dispatch(actions.displayWarning(err.message))
|
|
|
|
return reject(err)
|
|
|
|
}
|
2017-02-23 23:23:45 +01:00
|
|
|
|
2017-12-05 04:27:42 +01:00
|
|
|
dispatch(actions.completedTx(msgData.metamaskId))
|
2018-07-24 05:25:04 +02:00
|
|
|
|
|
|
|
if (global.METAMASK_UI_TYPE === ENVIRONMENT_TYPE_NOTIFICATION &&
|
|
|
|
!hasUnconfirmedTransactions(getState())) {
|
|
|
|
return global.platform.closeCurrentWindow()
|
|
|
|
}
|
|
|
|
|
2017-12-05 04:27:42 +01:00
|
|
|
return resolve(msgData)
|
|
|
|
})
|
2016-04-14 00:28:44 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-02-23 01:23:13 +01:00
|
|
|
function signPersonalMsg (msgData) {
|
2017-02-23 23:23:45 +01:00
|
|
|
log.debug('action - signPersonalMsg')
|
2018-07-24 05:25:04 +02:00
|
|
|
return (dispatch, getState) => {
|
2017-02-23 01:23:13 +01:00
|
|
|
dispatch(actions.showLoadingIndication())
|
|
|
|
|
2017-12-05 04:27:42 +01:00
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
log.debug(`actions calling background.signPersonalMessage`)
|
|
|
|
background.signPersonalMessage(msgData, (err, newState) => {
|
|
|
|
log.debug('signPersonalMessage called back')
|
|
|
|
dispatch(actions.updateMetamaskState(newState))
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
2017-02-23 01:23:13 +01:00
|
|
|
|
2017-12-05 04:27:42 +01:00
|
|
|
if (err) {
|
|
|
|
log.error(err)
|
|
|
|
dispatch(actions.displayWarning(err.message))
|
|
|
|
return reject(err)
|
|
|
|
}
|
2017-02-23 23:23:45 +01:00
|
|
|
|
2017-12-05 04:27:42 +01:00
|
|
|
dispatch(actions.completedTx(msgData.metamaskId))
|
2018-07-24 05:25:04 +02:00
|
|
|
|
|
|
|
if (global.METAMASK_UI_TYPE === ENVIRONMENT_TYPE_NOTIFICATION &&
|
|
|
|
!hasUnconfirmedTransactions(getState())) {
|
|
|
|
return global.platform.closeCurrentWindow()
|
|
|
|
}
|
|
|
|
|
2017-12-05 04:27:42 +01:00
|
|
|
return resolve(msgData)
|
|
|
|
})
|
2016-04-14 00:28:44 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-09-29 18:24:08 +02:00
|
|
|
function signTypedMsg (msgData) {
|
|
|
|
log.debug('action - signTypedMsg')
|
2018-07-24 05:25:04 +02:00
|
|
|
return (dispatch, getState) => {
|
2017-09-29 18:24:08 +02:00
|
|
|
dispatch(actions.showLoadingIndication())
|
|
|
|
|
2017-12-05 04:27:42 +01:00
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
log.debug(`actions calling background.signTypedMessage`)
|
|
|
|
background.signTypedMessage(msgData, (err, newState) => {
|
|
|
|
log.debug('signTypedMessage called back')
|
|
|
|
dispatch(actions.updateMetamaskState(newState))
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
2017-09-29 18:24:08 +02:00
|
|
|
|
2017-12-05 04:27:42 +01:00
|
|
|
if (err) {
|
|
|
|
log.error(err)
|
|
|
|
dispatch(actions.displayWarning(err.message))
|
|
|
|
return reject(err)
|
|
|
|
}
|
2017-09-29 18:24:08 +02:00
|
|
|
|
2017-12-05 04:27:42 +01:00
|
|
|
dispatch(actions.completedTx(msgData.metamaskId))
|
2018-07-24 05:25:04 +02:00
|
|
|
|
|
|
|
if (global.METAMASK_UI_TYPE === ENVIRONMENT_TYPE_NOTIFICATION &&
|
|
|
|
!hasUnconfirmedTransactions(getState())) {
|
|
|
|
return global.platform.closeCurrentWindow()
|
|
|
|
}
|
|
|
|
|
2017-12-05 04:27:42 +01:00
|
|
|
return resolve(msgData)
|
|
|
|
})
|
2017-09-29 18:24:08 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function signTx (txData) {
|
2016-05-06 23:46:04 +02:00
|
|
|
return (dispatch) => {
|
2017-05-08 21:29:08 +02:00
|
|
|
global.ethQuery.sendTransaction(txData, (err, data) => {
|
2018-06-23 08:52:45 +02:00
|
|
|
if (err) {
|
|
|
|
return dispatch(actions.displayWarning(err.message))
|
|
|
|
}
|
2016-05-06 23:46:04 +02:00
|
|
|
})
|
2017-08-30 05:16:30 +02:00
|
|
|
dispatch(actions.showConfTxPage({}))
|
2016-05-06 23:46:04 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-05-20 02:37:44 +02:00
|
|
|
function setGasLimit (gasLimit) {
|
2017-10-12 18:42:14 +02:00
|
|
|
return {
|
|
|
|
type: actions.UPDATE_GAS_LIMIT,
|
|
|
|
value: gasLimit,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-05-20 02:37:44 +02:00
|
|
|
function setGasPrice (gasPrice) {
|
2017-10-12 18:42:14 +02:00
|
|
|
return {
|
|
|
|
type: actions.UPDATE_GAS_PRICE,
|
|
|
|
value: gasPrice,
|
|
|
|
}
|
|
|
|
}
|
2017-09-22 06:15:26 +02:00
|
|
|
|
2018-04-27 21:03:00 +02:00
|
|
|
function setGasTotal (gasTotal) {
|
2017-10-17 19:22:23 +02:00
|
|
|
return {
|
|
|
|
type: actions.UPDATE_GAS_TOTAL,
|
|
|
|
value: gasTotal,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-05-22 17:16:53 +02:00
|
|
|
function updateGasData ({
|
|
|
|
blockGasLimit,
|
|
|
|
recentBlocks,
|
|
|
|
selectedAddress,
|
|
|
|
selectedToken,
|
|
|
|
to,
|
2018-05-23 18:43:25 +02:00
|
|
|
value,
|
2018-05-22 17:16:53 +02:00
|
|
|
}) {
|
2018-04-27 21:03:00 +02:00
|
|
|
return (dispatch) => {
|
2018-06-19 17:53:33 +02:00
|
|
|
dispatch(actions.gasLoadingStarted())
|
2018-06-29 02:10:06 +02:00
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
background.getGasPrice((err, data) => {
|
2018-07-05 01:56:02 +02:00
|
|
|
if (err) return reject(err)
|
2018-06-29 02:10:06 +02:00
|
|
|
return resolve(data)
|
|
|
|
})
|
|
|
|
})
|
2018-06-28 17:47:44 +02:00
|
|
|
.then(estimateGasPrice => {
|
2018-07-05 01:56:02 +02:00
|
|
|
return Promise.all([
|
|
|
|
Promise.resolve(estimateGasPrice),
|
|
|
|
estimateGas({
|
|
|
|
estimateGasMethod: background.estimateGas,
|
|
|
|
blockGasLimit,
|
|
|
|
selectedAddress,
|
|
|
|
selectedToken,
|
|
|
|
to,
|
|
|
|
value,
|
|
|
|
estimateGasPrice,
|
|
|
|
}),
|
|
|
|
])
|
2018-06-28 17:47:44 +02:00
|
|
|
})
|
2018-07-05 01:56:02 +02:00
|
|
|
.then(([gasPrice, gas]) => {
|
2018-05-22 10:10:06 +02:00
|
|
|
dispatch(actions.setGasPrice(gasPrice))
|
|
|
|
dispatch(actions.setGasLimit(gas))
|
2018-05-17 17:14:46 +02:00
|
|
|
return calcGasTotal(gas, gasPrice)
|
|
|
|
})
|
|
|
|
.then((gasEstimate) => {
|
|
|
|
dispatch(actions.setGasTotal(gasEstimate))
|
2018-04-27 21:03:00 +02:00
|
|
|
dispatch(updateSendErrors({ gasLoadingError: null }))
|
2018-06-19 17:53:33 +02:00
|
|
|
dispatch(actions.gasLoadingFinished())
|
2018-04-27 21:03:00 +02:00
|
|
|
})
|
|
|
|
.catch(err => {
|
|
|
|
log.error(err)
|
|
|
|
dispatch(updateSendErrors({ gasLoadingError: 'gasLoadingError' }))
|
2018-06-19 17:53:33 +02:00
|
|
|
dispatch(actions.gasLoadingFinished())
|
2018-04-27 21:03:00 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-06-19 17:53:33 +02:00
|
|
|
function gasLoadingStarted () {
|
|
|
|
return {
|
|
|
|
type: actions.GAS_LOADING_STARTED,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function gasLoadingFinished () {
|
|
|
|
return {
|
|
|
|
type: actions.GAS_LOADING_FINISHED,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-04-27 21:03:00 +02:00
|
|
|
function updateSendTokenBalance ({
|
|
|
|
selectedToken,
|
|
|
|
tokenContract,
|
|
|
|
address,
|
|
|
|
}) {
|
|
|
|
return (dispatch) => {
|
|
|
|
const tokenBalancePromise = tokenContract
|
|
|
|
? tokenContract.balanceOf(address)
|
|
|
|
: Promise.resolve()
|
|
|
|
return tokenBalancePromise
|
|
|
|
.then(usersToken => {
|
|
|
|
if (usersToken) {
|
|
|
|
const newTokenBalance = calcTokenBalance({ selectedToken, usersToken })
|
2018-05-23 21:26:13 +02:00
|
|
|
dispatch(setSendTokenBalance(newTokenBalance.toString(10)))
|
2018-04-27 21:03:00 +02:00
|
|
|
}
|
|
|
|
})
|
|
|
|
.catch(err => {
|
|
|
|
log.error(err)
|
|
|
|
updateSendErrors({ tokenBalance: 'tokenBalanceError' })
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function updateSendErrors (errorObject) {
|
|
|
|
return {
|
|
|
|
type: actions.UPDATE_SEND_ERRORS,
|
|
|
|
value: errorObject,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function setSendTokenBalance (tokenBalance) {
|
2017-10-30 18:48:50 +01:00
|
|
|
return {
|
|
|
|
type: actions.UPDATE_SEND_TOKEN_BALANCE,
|
|
|
|
value: tokenBalance,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-10-17 19:22:23 +02:00
|
|
|
function updateSendFrom (from) {
|
|
|
|
return {
|
|
|
|
type: actions.UPDATE_SEND_FROM,
|
|
|
|
value: from,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-07-17 00:31:36 +02:00
|
|
|
function updateSendHexData (value) {
|
|
|
|
return {
|
|
|
|
type: actions.UPDATE_SEND_HEX_DATA,
|
|
|
|
value,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-03-26 15:30:54 +02:00
|
|
|
function updateSendTo (to, nickname = '') {
|
2017-10-17 19:22:23 +02:00
|
|
|
return {
|
|
|
|
type: actions.UPDATE_SEND_TO,
|
2018-03-26 15:30:54 +02:00
|
|
|
value: { to, nickname },
|
2017-10-17 19:22:23 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function updateSendAmount (amount) {
|
|
|
|
return {
|
|
|
|
type: actions.UPDATE_SEND_AMOUNT,
|
|
|
|
value: amount,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function updateSendMemo (memo) {
|
|
|
|
return {
|
|
|
|
type: actions.UPDATE_SEND_MEMO,
|
|
|
|
value: memo,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-11-16 19:14:25 +01:00
|
|
|
function setMaxModeTo (bool) {
|
|
|
|
return {
|
|
|
|
type: actions.UPDATE_MAX_MODE,
|
|
|
|
value: bool,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-11-10 04:49:16 +01:00
|
|
|
function updateSend (newSend) {
|
|
|
|
return {
|
|
|
|
type: actions.UPDATE_SEND,
|
|
|
|
value: newSend,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-10-21 04:05:22 +02:00
|
|
|
function clearSend () {
|
|
|
|
return {
|
2017-11-02 13:15:59 +01:00
|
|
|
type: actions.CLEAR_SEND,
|
2017-10-21 04:05:22 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-10-17 19:22:23 +02:00
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function sendTx (txData) {
|
2017-02-28 23:45:21 +01:00
|
|
|
log.info(`actions - sendTx: ${JSON.stringify(txData.txParams)}`)
|
2018-07-24 05:25:04 +02:00
|
|
|
return (dispatch, getState) => {
|
2017-02-23 23:23:45 +01:00
|
|
|
log.debug(`actions calling background.approveTransaction`)
|
2016-10-20 18:58:33 +02:00
|
|
|
background.approveTransaction(txData.id, (err) => {
|
2016-04-14 00:28:44 +02:00
|
|
|
if (err) {
|
2016-05-25 21:39:12 +02:00
|
|
|
dispatch(actions.txError(err))
|
2017-06-14 23:21:50 +02:00
|
|
|
return log.error(err.message)
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
2016-05-25 21:39:12 +02:00
|
|
|
dispatch(actions.completedTx(txData.id))
|
2018-07-24 05:25:04 +02:00
|
|
|
|
|
|
|
if (global.METAMASK_UI_TYPE === ENVIRONMENT_TYPE_NOTIFICATION &&
|
|
|
|
!hasUnconfirmedTransactions(getState())) {
|
|
|
|
return global.platform.closeCurrentWindow()
|
|
|
|
}
|
2016-04-14 00:28:44 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-09-12 11:22:23 +02:00
|
|
|
function signTokenTx (tokenAddress, toAddress, amount, txData) {
|
|
|
|
return dispatch => {
|
|
|
|
dispatch(actions.showLoadingIndication())
|
|
|
|
const token = global.eth.contract(abi).at(tokenAddress)
|
2017-10-25 19:49:09 +02:00
|
|
|
token.transfer(toAddress, ethUtil.addHexPrefix(amount), txData)
|
2017-09-12 11:22:23 +02:00
|
|
|
.catch(err => {
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
dispatch(actions.displayWarning(err.message))
|
|
|
|
})
|
|
|
|
dispatch(actions.showConfTxPage({}))
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-12-20 18:17:16 +01:00
|
|
|
function updateTransaction (txData) {
|
|
|
|
log.info('actions: updateTx: ' + JSON.stringify(txData))
|
2018-06-23 08:52:45 +02:00
|
|
|
return dispatch => {
|
2017-12-20 18:17:16 +01:00
|
|
|
log.debug(`actions calling background.updateTx`)
|
2018-06-23 08:52:45 +02:00
|
|
|
dispatch(actions.showLoadingIndication())
|
|
|
|
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
background.updateTransaction(txData, (err) => {
|
|
|
|
dispatch(actions.updateTransactionParams(txData.id, txData.txParams))
|
|
|
|
if (err) {
|
|
|
|
dispatch(actions.txError(err))
|
|
|
|
dispatch(actions.goHome())
|
|
|
|
log.error(err.message)
|
|
|
|
return reject(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
resolve(txData)
|
|
|
|
})
|
2016-04-14 00:28:44 +02:00
|
|
|
})
|
2018-06-23 08:52:45 +02:00
|
|
|
.then(() => updateMetamaskStateFromBackground())
|
|
|
|
.then(newState => dispatch(actions.updateMetamaskState(newState)))
|
|
|
|
.then(() => {
|
|
|
|
dispatch(actions.showConfTxPage({ id: txData.id }))
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
return txData
|
|
|
|
})
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-02-28 03:26:04 +01:00
|
|
|
function updateAndApproveTx (txData) {
|
2017-02-28 23:45:21 +01:00
|
|
|
log.info('actions: updateAndApproveTx: ' + JSON.stringify(txData))
|
2018-07-24 05:25:04 +02:00
|
|
|
return (dispatch, getState) => {
|
2017-02-28 03:26:04 +01:00
|
|
|
log.debug(`actions calling background.updateAndApproveTx`)
|
2018-06-23 08:52:45 +02:00
|
|
|
dispatch(actions.showLoadingIndication())
|
2017-11-29 05:24:35 +01:00
|
|
|
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
background.updateAndApproveTransaction(txData, err => {
|
|
|
|
dispatch(actions.updateTransactionParams(txData.id, txData.txParams))
|
|
|
|
dispatch(actions.clearSend())
|
|
|
|
|
|
|
|
if (err) {
|
|
|
|
dispatch(actions.txError(err))
|
|
|
|
dispatch(actions.goHome())
|
|
|
|
log.error(err.message)
|
|
|
|
reject(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
resolve(txData)
|
|
|
|
})
|
2016-04-14 00:28:44 +02:00
|
|
|
})
|
2018-06-23 08:52:45 +02:00
|
|
|
.then(() => updateMetamaskStateFromBackground())
|
|
|
|
.then(newState => dispatch(actions.updateMetamaskState(newState)))
|
|
|
|
.then(() => {
|
|
|
|
dispatch(actions.clearSend())
|
|
|
|
dispatch(actions.completedTx(txData.id))
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
2018-07-24 05:25:04 +02:00
|
|
|
|
|
|
|
if (global.METAMASK_UI_TYPE === ENVIRONMENT_TYPE_NOTIFICATION &&
|
|
|
|
!hasUnconfirmedTransactions(getState())) {
|
|
|
|
return global.platform.closeCurrentWindow()
|
|
|
|
}
|
|
|
|
|
2018-06-23 08:52:45 +02:00
|
|
|
return txData
|
|
|
|
})
|
2018-08-28 21:18:57 +02:00
|
|
|
.catch((err) => {
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
return Promise.reject(err)
|
|
|
|
})
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function completedTx (id) {
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.COMPLETED_TX,
|
2017-02-24 01:00:43 +01:00
|
|
|
value: id,
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-11-08 17:44:48 +01:00
|
|
|
function updateTransactionParams (id, txParams) {
|
|
|
|
return {
|
|
|
|
type: actions.UPDATE_TRANSACTION_PARAMS,
|
|
|
|
id,
|
|
|
|
value: txParams,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function txError (err) {
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.TRANSACTION_ERROR,
|
2016-04-14 00:28:44 +02:00
|
|
|
message: err.message,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function cancelMsg (msgData) {
|
2018-07-24 05:25:04 +02:00
|
|
|
return (dispatch, getState) => {
|
2017-12-05 04:27:42 +01:00
|
|
|
dispatch(actions.showLoadingIndication())
|
|
|
|
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
log.debug(`background.cancelMessage`)
|
|
|
|
background.cancelMessage(msgData.id, (err, newState) => {
|
|
|
|
dispatch(actions.updateMetamaskState(newState))
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
|
|
|
|
if (err) {
|
|
|
|
return reject(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
dispatch(actions.completedTx(msgData.id))
|
2018-07-24 05:25:04 +02:00
|
|
|
|
|
|
|
if (global.METAMASK_UI_TYPE === ENVIRONMENT_TYPE_NOTIFICATION &&
|
|
|
|
!hasUnconfirmedTransactions(getState())) {
|
|
|
|
return global.platform.closeCurrentWindow()
|
|
|
|
}
|
|
|
|
|
2017-12-05 04:27:42 +01:00
|
|
|
return resolve(msgData)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
2016-05-03 23:32:22 +02:00
|
|
|
}
|
|
|
|
|
2017-02-23 01:23:13 +01:00
|
|
|
function cancelPersonalMsg (msgData) {
|
2018-07-24 05:25:04 +02:00
|
|
|
return (dispatch, getState) => {
|
2017-12-05 04:27:42 +01:00
|
|
|
dispatch(actions.showLoadingIndication())
|
|
|
|
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
const id = msgData.id
|
|
|
|
background.cancelPersonalMessage(id, (err, newState) => {
|
|
|
|
dispatch(actions.updateMetamaskState(newState))
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
|
|
|
|
if (err) {
|
|
|
|
return reject(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
dispatch(actions.completedTx(id))
|
2018-07-24 05:25:04 +02:00
|
|
|
|
|
|
|
if (global.METAMASK_UI_TYPE === ENVIRONMENT_TYPE_NOTIFICATION &&
|
|
|
|
!hasUnconfirmedTransactions(getState())) {
|
|
|
|
return global.platform.closeCurrentWindow()
|
|
|
|
}
|
|
|
|
|
2017-12-05 04:27:42 +01:00
|
|
|
return resolve(msgData)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
2017-02-23 01:23:13 +01:00
|
|
|
}
|
|
|
|
|
2017-09-29 18:24:08 +02:00
|
|
|
function cancelTypedMsg (msgData) {
|
2018-07-24 05:25:04 +02:00
|
|
|
return (dispatch, getState) => {
|
2017-12-05 04:27:42 +01:00
|
|
|
dispatch(actions.showLoadingIndication())
|
|
|
|
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
const id = msgData.id
|
|
|
|
background.cancelTypedMessage(id, (err, newState) => {
|
|
|
|
dispatch(actions.updateMetamaskState(newState))
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
|
|
|
|
if (err) {
|
|
|
|
return reject(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
dispatch(actions.completedTx(id))
|
2018-07-24 05:25:04 +02:00
|
|
|
|
|
|
|
if (global.METAMASK_UI_TYPE === ENVIRONMENT_TYPE_NOTIFICATION &&
|
|
|
|
!hasUnconfirmedTransactions(getState())) {
|
|
|
|
return global.platform.closeCurrentWindow()
|
|
|
|
}
|
|
|
|
|
2017-12-05 04:27:42 +01:00
|
|
|
return resolve(msgData)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
2017-09-29 18:24:08 +02:00
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function cancelTx (txData) {
|
2018-07-24 05:25:04 +02:00
|
|
|
return (dispatch, getState) => {
|
2017-08-04 03:20:01 +02:00
|
|
|
log.debug(`background.cancelTransaction`)
|
2018-06-23 08:52:45 +02:00
|
|
|
dispatch(actions.showLoadingIndication())
|
|
|
|
|
2017-11-29 05:24:35 +01:00
|
|
|
return new Promise((resolve, reject) => {
|
2018-06-23 08:52:45 +02:00
|
|
|
background.cancelTransaction(txData.id, err => {
|
|
|
|
if (err) {
|
|
|
|
return reject(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
resolve()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
.then(() => updateMetamaskStateFromBackground())
|
|
|
|
.then(newState => dispatch(actions.updateMetamaskState(newState)))
|
|
|
|
.then(() => {
|
2018-01-30 03:22:52 +01:00
|
|
|
dispatch(actions.clearSend())
|
2017-11-29 05:24:35 +01:00
|
|
|
dispatch(actions.completedTx(txData.id))
|
2018-06-23 08:52:45 +02:00
|
|
|
dispatch(actions.hideLoadingIndication())
|
2018-07-24 05:25:04 +02:00
|
|
|
|
|
|
|
if (global.METAMASK_UI_TYPE === ENVIRONMENT_TYPE_NOTIFICATION &&
|
|
|
|
!hasUnconfirmedTransactions(getState())) {
|
|
|
|
return global.platform.closeCurrentWindow()
|
|
|
|
}
|
|
|
|
|
2018-06-23 08:52:45 +02:00
|
|
|
return txData
|
2017-11-29 05:24:35 +01:00
|
|
|
})
|
2017-08-04 03:20:01 +02:00
|
|
|
}
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
|
2017-08-15 06:29:21 +02:00
|
|
|
function cancelAllTx (txsData) {
|
|
|
|
return (dispatch) => {
|
2017-08-15 06:51:39 +02:00
|
|
|
txsData.forEach((txData, i) => {
|
|
|
|
background.cancelTransaction(txData.id, () => {
|
|
|
|
dispatch(actions.completedTx(txData.id))
|
|
|
|
i === txsData.length - 1 ? dispatch(actions.goHome()) : null
|
|
|
|
})
|
|
|
|
})
|
2017-08-15 06:29:21 +02:00
|
|
|
}
|
|
|
|
}
|
2016-04-14 00:28:44 +02:00
|
|
|
//
|
|
|
|
// initialize screen
|
|
|
|
//
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function showCreateVault () {
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.SHOW_CREATE_VAULT,
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function showRestoreVault () {
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.SHOW_RESTORE_VAULT,
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-02-08 01:38:55 +01:00
|
|
|
function markPasswordForgotten () {
|
|
|
|
return (dispatch) => {
|
|
|
|
return background.markPasswordForgotten(() => {
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
dispatch(actions.forgotPassword())
|
|
|
|
forceUpdateMetamaskState(dispatch)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function unMarkPasswordForgotten () {
|
2018-03-08 16:29:29 +01:00
|
|
|
return dispatch => {
|
|
|
|
return new Promise(resolve => {
|
|
|
|
background.unMarkPasswordForgotten(() => {
|
|
|
|
dispatch(actions.forgotPassword(false))
|
|
|
|
resolve()
|
|
|
|
})
|
2018-02-08 01:38:55 +01:00
|
|
|
})
|
2018-03-08 16:29:29 +01:00
|
|
|
.then(() => forceUpdateMetamaskState(dispatch))
|
2018-02-08 01:38:55 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-03-03 03:14:05 +01:00
|
|
|
function forgotPassword (forgotPasswordState = true) {
|
2016-12-20 00:46:09 +01:00
|
|
|
return {
|
|
|
|
type: actions.FORGOT_PASSWORD,
|
2018-03-03 03:14:05 +01:00
|
|
|
value: forgotPasswordState,
|
2016-12-20 00:46:09 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function showInitializeMenu () {
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.SHOW_INIT_MENU,
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-01-17 22:47:30 +01:00
|
|
|
function showImportPage () {
|
|
|
|
return {
|
|
|
|
type: actions.SHOW_IMPORT_PAGE,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-01-10 19:25:38 +01:00
|
|
|
function showNewAccountPage (formToSelect) {
|
|
|
|
return {
|
|
|
|
type: actions.SHOW_NEW_ACCOUNT_PAGE,
|
|
|
|
formToSelect,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function setNewAccountForm (formToSelect) {
|
|
|
|
return {
|
|
|
|
type: actions.SET_NEW_ACCOUNT_FORM,
|
|
|
|
formToSelect,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function createNewVaultInProgress () {
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.CREATE_NEW_VAULT_IN_PROGRESS,
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function showNewVaultSeed (seed) {
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.SHOW_NEW_VAULT_SEED,
|
2016-04-14 00:28:44 +02:00
|
|
|
value: seed,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-03-08 18:31:21 +01:00
|
|
|
function closeWelcomeScreen () {
|
|
|
|
return {
|
|
|
|
type: actions.CLOSE_WELCOME_SCREEN,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-08-24 02:17:08 +02:00
|
|
|
function backToUnlockView () {
|
|
|
|
return {
|
|
|
|
type: actions.BACK_TO_UNLOCK_VIEW,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-10-15 19:48:12 +02:00
|
|
|
function showNewKeychain () {
|
|
|
|
return {
|
2016-10-20 20:33:18 +02:00
|
|
|
type: actions.SHOW_NEW_KEYCHAIN,
|
2016-10-15 19:48:12 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-04-14 00:28:44 +02:00
|
|
|
//
|
|
|
|
// unlock screen
|
|
|
|
//
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function unlockInProgress () {
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.UNLOCK_IN_PROGRESS,
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-11-02 01:00:17 +01:00
|
|
|
function unlockFailed (message) {
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.UNLOCK_FAILED,
|
2016-11-02 01:00:17 +01:00
|
|
|
value: message,
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-01-30 03:44:43 +01:00
|
|
|
function unlockSucceeded (message) {
|
|
|
|
return {
|
|
|
|
type: actions.UNLOCK_SUCCEEDED,
|
|
|
|
value: message,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function unlockMetamask (account) {
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.UNLOCK_METAMASK,
|
2016-05-13 10:13:14 +02:00
|
|
|
value: account,
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function updateMetamaskState (newState) {
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.UPDATE_METAMASK_STATE,
|
2016-04-14 00:28:44 +02:00
|
|
|
value: newState,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-10-27 08:02:56 +02:00
|
|
|
const backgroundSetLocked = () => {
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
background.setLocked(error => {
|
|
|
|
if (error) {
|
|
|
|
return reject(error)
|
|
|
|
}
|
|
|
|
|
|
|
|
resolve()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
const updateMetamaskStateFromBackground = () => {
|
|
|
|
log.debug(`background.getState`)
|
|
|
|
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
background.getState((error, newState) => {
|
|
|
|
if (error) {
|
|
|
|
return reject(error)
|
|
|
|
}
|
|
|
|
|
|
|
|
resolve(newState)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function lockMetamask () {
|
2017-02-23 23:23:45 +01:00
|
|
|
log.debug(`background.setLocked`)
|
2017-10-27 08:02:56 +02:00
|
|
|
|
|
|
|
return dispatch => {
|
|
|
|
dispatch(actions.showLoadingIndication())
|
|
|
|
|
|
|
|
return backgroundSetLocked()
|
|
|
|
.then(() => updateMetamaskStateFromBackground())
|
|
|
|
.catch(error => {
|
|
|
|
dispatch(actions.displayWarning(error.message))
|
|
|
|
return Promise.reject(error)
|
|
|
|
})
|
|
|
|
.then(newState => {
|
|
|
|
dispatch(actions.updateMetamaskState(newState))
|
2018-01-12 00:49:10 +01:00
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
dispatch({ type: actions.LOCK_METAMASK })
|
|
|
|
})
|
|
|
|
.catch(() => {
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
2017-10-27 08:02:56 +02:00
|
|
|
dispatch({ type: actions.LOCK_METAMASK })
|
|
|
|
})
|
|
|
|
}
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
|
2017-06-14 23:21:50 +02:00
|
|
|
function setCurrentAccountTab (newTabName) {
|
|
|
|
log.debug(`background.setCurrentAccountTab: ${newTabName}`)
|
|
|
|
return callBackgroundThenUpdateNoSpinner(background.setCurrentAccountTab, newTabName)
|
|
|
|
}
|
|
|
|
|
2017-09-06 12:17:49 +02:00
|
|
|
function setSelectedToken (tokenAddress) {
|
|
|
|
return {
|
|
|
|
type: actions.SET_SELECTED_TOKEN,
|
|
|
|
value: tokenAddress || null,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-10-12 19:29:03 +02:00
|
|
|
function setSelectedAddress (address) {
|
|
|
|
return (dispatch) => {
|
|
|
|
dispatch(actions.showLoadingIndication())
|
|
|
|
log.debug(`background.setSelectedAddress`)
|
|
|
|
background.setSelectedAddress(address, (err) => {
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
if (err) {
|
|
|
|
return dispatch(actions.displayWarning(err.message))
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function showAccountDetail (address) {
|
2016-04-25 23:14:34 +02:00
|
|
|
return (dispatch) => {
|
2016-05-25 21:39:12 +02:00
|
|
|
dispatch(actions.showLoadingIndication())
|
2017-02-23 23:23:45 +01:00
|
|
|
log.debug(`background.setSelectedAddress`)
|
2018-07-27 01:28:12 +02:00
|
|
|
background.setSelectedAddress(address, (err, tokens) => {
|
2016-05-25 21:39:12 +02:00
|
|
|
dispatch(actions.hideLoadingIndication())
|
2016-06-21 22:56:04 +02:00
|
|
|
if (err) {
|
2016-11-08 01:02:02 +01:00
|
|
|
return dispatch(actions.displayWarning(err.message))
|
2016-06-21 22:56:04 +02:00
|
|
|
}
|
2018-07-27 01:28:12 +02:00
|
|
|
dispatch(updateTokens(tokens))
|
2016-05-13 10:13:14 +02:00
|
|
|
dispatch({
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.SHOW_ACCOUNT_DETAIL,
|
2017-01-31 00:08:31 +01:00
|
|
|
value: address,
|
2016-05-13 10:13:14 +02:00
|
|
|
})
|
2017-09-15 15:38:09 +02:00
|
|
|
dispatch(actions.setSelectedToken())
|
2016-04-25 23:14:34 +02:00
|
|
|
})
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function backToAccountDetail (address) {
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.BACK_TO_ACCOUNT_DETAIL,
|
2016-04-14 00:28:44 +02:00
|
|
|
value: address,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function showAccountsPage () {
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.SHOW_ACCOUNTS_PAGE,
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-08-30 05:16:30 +02:00
|
|
|
function showConfTxPage ({transForward = true, id}) {
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.SHOW_CONF_TX_PAGE,
|
2017-08-30 05:16:30 +02:00
|
|
|
transForward,
|
|
|
|
id,
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function nextTx () {
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.NEXT_TX,
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function viewPendingTx (txId) {
|
2016-05-26 23:32:45 +02:00
|
|
|
return {
|
|
|
|
type: actions.VIEW_PENDING_TX,
|
|
|
|
value: txId,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function previousTx () {
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.PREVIOUS_TX,
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-11-08 17:44:48 +01:00
|
|
|
function editTx (txId) {
|
|
|
|
return {
|
|
|
|
type: actions.EDIT_TX,
|
|
|
|
value: txId,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function showConfigPage (transitionForward = true) {
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.SHOW_CONFIG_PAGE,
|
2016-06-03 01:52:18 +02:00
|
|
|
value: transitionForward,
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-11-15 18:39:03 +01:00
|
|
|
function showAddTokenPage (transitionForward = true) {
|
2017-06-15 05:42:48 +02:00
|
|
|
return {
|
|
|
|
type: actions.SHOW_ADD_TOKEN_PAGE,
|
2017-11-15 18:39:03 +01:00
|
|
|
value: transitionForward,
|
2017-06-15 05:42:48 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-07 23:40:45 +02:00
|
|
|
function showAddSuggestedTokenPage (transitionForward = true) {
|
|
|
|
return {
|
|
|
|
type: actions.SHOW_ADD_SUGGESTED_TOKEN_PAGE,
|
|
|
|
value: transitionForward,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-23 20:54:40 +02:00
|
|
|
function addToken (address, symbol, decimals, image) {
|
2017-06-16 01:22:53 +02:00
|
|
|
return (dispatch) => {
|
|
|
|
dispatch(actions.showLoadingIndication())
|
2017-09-22 03:44:52 +02:00
|
|
|
return new Promise((resolve, reject) => {
|
2018-08-23 20:54:40 +02:00
|
|
|
background.addToken(address, symbol, decimals, image, (err, tokens) => {
|
2017-09-22 03:44:52 +02:00
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
if (err) {
|
|
|
|
dispatch(actions.displayWarning(err.message))
|
|
|
|
reject(err)
|
|
|
|
}
|
2017-10-03 19:25:52 +02:00
|
|
|
dispatch(actions.updateTokens(tokens))
|
|
|
|
resolve(tokens)
|
|
|
|
})
|
2017-06-16 01:22:53 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-10-03 19:25:52 +02:00
|
|
|
function removeToken (address) {
|
|
|
|
return (dispatch) => {
|
|
|
|
dispatch(actions.showLoadingIndication())
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
background.removeToken(address, (err, tokens) => {
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
if (err) {
|
|
|
|
dispatch(actions.displayWarning(err.message))
|
|
|
|
reject(err)
|
|
|
|
}
|
|
|
|
dispatch(actions.updateTokens(tokens))
|
|
|
|
resolve(tokens)
|
2017-09-22 03:44:52 +02:00
|
|
|
})
|
2017-06-16 01:22:53 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-09-22 03:44:52 +02:00
|
|
|
function addTokens (tokens) {
|
|
|
|
return dispatch => {
|
|
|
|
if (Array.isArray(tokens)) {
|
2018-01-16 21:14:03 +01:00
|
|
|
dispatch(actions.setSelectedToken(getTokenAddressFromTokenObject(tokens[0])))
|
2017-09-22 03:44:52 +02:00
|
|
|
return Promise.all(tokens.map(({ address, symbol, decimals }) => (
|
|
|
|
dispatch(addToken(address, symbol, decimals))
|
|
|
|
)))
|
|
|
|
} else {
|
2018-01-16 21:14:03 +01:00
|
|
|
dispatch(actions.setSelectedToken(getTokenAddressFromTokenObject(tokens)))
|
2017-09-22 03:44:52 +02:00
|
|
|
return Promise.all(
|
|
|
|
Object
|
|
|
|
.entries(tokens)
|
|
|
|
.map(([_, { address, symbol, decimals }]) => (
|
|
|
|
dispatch(addToken(address, symbol, decimals))
|
|
|
|
))
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-04 01:24:12 +02:00
|
|
|
function removeSuggestedTokens () {
|
|
|
|
return (dispatch) => {
|
|
|
|
dispatch(actions.showLoadingIndication())
|
2018-08-17 01:19:19 +02:00
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
background.removeSuggestedTokens((err, suggestedTokens) => {
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
if (err) {
|
|
|
|
dispatch(actions.displayWarning(err.message))
|
|
|
|
}
|
|
|
|
dispatch(actions.clearPendingTokens())
|
|
|
|
if (global.METAMASK_UI_TYPE === ENVIRONMENT_TYPE_NOTIFICATION) {
|
|
|
|
return global.platform.closeCurrentWindow()
|
|
|
|
}
|
|
|
|
resolve(suggestedTokens)
|
|
|
|
})
|
2018-08-04 01:24:12 +02:00
|
|
|
})
|
2018-08-17 01:19:19 +02:00
|
|
|
.then(() => updateMetamaskStateFromBackground())
|
|
|
|
.then(suggestedTokens => dispatch(actions.updateMetamaskState({...suggestedTokens})))
|
2018-08-04 01:24:12 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-08 01:12:16 +02:00
|
|
|
function updateTokens (newTokens) {
|
2018-08-04 01:24:12 +02:00
|
|
|
return {
|
2018-08-08 01:12:16 +02:00
|
|
|
type: actions.UPDATE_TOKENS,
|
|
|
|
newTokens,
|
2018-08-04 01:24:12 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-08 01:12:16 +02:00
|
|
|
function clearPendingTokens () {
|
2017-10-03 19:25:52 +02:00
|
|
|
return {
|
2018-08-08 01:12:16 +02:00
|
|
|
type: actions.CLEAR_PENDING_TOKENS,
|
2017-10-03 19:25:52 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-08-24 02:17:08 +02:00
|
|
|
function goBackToInitView () {
|
|
|
|
return {
|
|
|
|
type: actions.BACK_TO_INIT_MENU,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-12-07 23:34:15 +01:00
|
|
|
//
|
|
|
|
// notice
|
|
|
|
//
|
|
|
|
|
|
|
|
function markNoticeRead (notice) {
|
|
|
|
return (dispatch) => {
|
2017-08-22 14:59:44 +02:00
|
|
|
dispatch(actions.showLoadingIndication())
|
2017-02-23 23:23:45 +01:00
|
|
|
log.debug(`background.markNoticeRead`)
|
2017-08-22 14:59:44 +02:00
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
background.markNoticeRead(notice, (err, notice) => {
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
if (err) {
|
|
|
|
dispatch(actions.displayWarning(err))
|
|
|
|
return reject(err)
|
2016-12-07 23:34:15 +01:00
|
|
|
}
|
2018-04-02 11:59:49 +02:00
|
|
|
|
2017-08-22 14:59:44 +02:00
|
|
|
if (notice) {
|
|
|
|
dispatch(actions.showNotice(notice))
|
2018-04-02 11:59:49 +02:00
|
|
|
resolve(true)
|
2017-08-22 14:59:44 +02:00
|
|
|
} else {
|
|
|
|
dispatch(actions.clearNotices())
|
2018-04-02 11:59:49 +02:00
|
|
|
resolve(false)
|
2017-08-22 14:59:44 +02:00
|
|
|
}
|
|
|
|
})
|
2016-12-07 23:34:15 +01:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function showNotice (notice) {
|
|
|
|
return {
|
|
|
|
type: actions.SHOW_NOTICE,
|
|
|
|
value: notice,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function clearNotices () {
|
|
|
|
return {
|
|
|
|
type: actions.CLEAR_NOTICES,
|
|
|
|
}
|
2016-08-24 02:17:08 +02:00
|
|
|
}
|
|
|
|
|
2017-04-27 06:05:45 +02:00
|
|
|
function markAccountsFound () {
|
2017-02-23 23:23:45 +01:00
|
|
|
log.debug(`background.markAccountsFound`)
|
2017-01-03 19:42:09 +01:00
|
|
|
return callBackgroundThenUpdate(background.markAccountsFound)
|
2016-12-20 22:53:14 +01:00
|
|
|
}
|
|
|
|
|
2017-12-07 04:55:47 +01:00
|
|
|
function retryTransaction (txId) {
|
2017-12-07 04:20:11 +01:00
|
|
|
log.debug(`background.retryTransaction`)
|
2018-05-29 19:23:06 +02:00
|
|
|
let newTxId
|
|
|
|
|
2017-12-07 05:09:32 +01:00
|
|
|
return (dispatch) => {
|
2018-05-29 19:23:06 +02:00
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
background.retryTransaction(txId, (err, newState) => {
|
|
|
|
if (err) {
|
|
|
|
dispatch(actions.displayWarning(err.message))
|
|
|
|
reject(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
const { selectedAddressTxList } = newState
|
|
|
|
const { id } = selectedAddressTxList[selectedAddressTxList.length - 1]
|
|
|
|
newTxId = id
|
|
|
|
resolve(newState)
|
|
|
|
})
|
2017-12-07 05:09:32 +01:00
|
|
|
})
|
2018-05-29 19:23:06 +02:00
|
|
|
.then(newState => dispatch(actions.updateMetamaskState(newState)))
|
|
|
|
.then(() => newTxId)
|
2017-12-07 05:09:32 +01:00
|
|
|
}
|
2017-12-07 04:20:11 +01:00
|
|
|
}
|
|
|
|
|
2016-04-14 00:28:44 +02:00
|
|
|
//
|
|
|
|
// config
|
|
|
|
//
|
|
|
|
|
2017-09-30 01:35:58 +02:00
|
|
|
function setProviderType (type) {
|
2017-03-08 18:06:41 +01:00
|
|
|
return (dispatch) => {
|
2018-03-30 19:59:39 +02:00
|
|
|
log.debug(`background.setProviderType`, type)
|
2017-09-30 01:35:58 +02:00
|
|
|
background.setProviderType(type, (err, result) => {
|
2017-03-08 18:06:41 +01:00
|
|
|
if (err) {
|
2017-03-08 18:35:31 +01:00
|
|
|
log.error(err)
|
2017-09-30 01:35:58 +02:00
|
|
|
return dispatch(self.displayWarning('Had a problem changing networks!'))
|
2017-03-08 18:06:41 +01:00
|
|
|
}
|
2017-10-05 01:12:07 +02:00
|
|
|
dispatch(actions.updateProviderType(type))
|
|
|
|
dispatch(actions.setSelectedToken())
|
2017-03-08 18:06:41 +01:00
|
|
|
})
|
2017-10-26 03:23:46 +02:00
|
|
|
|
2017-10-05 01:12:07 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-11-02 13:15:59 +01:00
|
|
|
function updateProviderType (type) {
|
2017-10-05 01:12:07 +02:00
|
|
|
return {
|
|
|
|
type: actions.SET_PROVIDER_TYPE,
|
|
|
|
value: type,
|
2017-03-07 19:25:50 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function setRpcTarget (newRpc) {
|
2017-03-08 18:08:28 +01:00
|
|
|
return (dispatch) => {
|
2018-03-30 19:59:39 +02:00
|
|
|
log.debug(`background.setRpcTarget: ${newRpc}`)
|
2017-03-08 18:08:28 +01:00
|
|
|
background.setCustomRpc(newRpc, (err, result) => {
|
|
|
|
if (err) {
|
2017-03-08 18:35:31 +01:00
|
|
|
log.error(err)
|
2017-03-08 18:08:28 +01:00
|
|
|
return dispatch(self.displayWarning('Had a problem changing networks!'))
|
|
|
|
}
|
2018-03-30 19:59:39 +02:00
|
|
|
dispatch(actions.setSelectedToken())
|
2017-03-08 18:08:28 +01:00
|
|
|
})
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-03-21 14:57:49 +01:00
|
|
|
// Calls the addressBookController to add a new address.
|
2017-10-17 17:46:36 +02:00
|
|
|
function addToAddressBook (recipient, nickname = '') {
|
2017-03-10 00:10:27 +01:00
|
|
|
log.debug(`background.addToAddressBook`)
|
|
|
|
return (dispatch) => {
|
|
|
|
background.setAddressBook(recipient, nickname, (err, result) => {
|
|
|
|
if (err) {
|
|
|
|
log.error(err)
|
|
|
|
return dispatch(self.displayWarning('Address book failed to update'))
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function useEtherscanProvider () {
|
2017-02-23 23:23:45 +01:00
|
|
|
log.debug(`background.useEtherscanProvider`)
|
2016-10-20 18:58:33 +02:00
|
|
|
background.useEtherscanProvider()
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.USE_ETHERSCAN_PROVIDER,
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-08-13 22:15:21 +02:00
|
|
|
function showNetworkDropdown () {
|
|
|
|
return {
|
|
|
|
type: actions.NETWORK_DROPDOWN_OPEN,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function hideNetworkDropdown () {
|
|
|
|
return {
|
|
|
|
type: actions.NETWORK_DROPDOWN_CLOSE,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-08-21 03:32:58 +02:00
|
|
|
function showModal (payload) {
|
2017-08-08 22:37:16 +02:00
|
|
|
return {
|
|
|
|
type: actions.MODAL_OPEN,
|
2017-08-21 03:32:58 +02:00
|
|
|
payload,
|
2017-08-08 22:37:16 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-08-21 03:32:58 +02:00
|
|
|
function hideModal (payload) {
|
2017-08-08 22:37:16 +02:00
|
|
|
return {
|
|
|
|
type: actions.MODAL_CLOSE,
|
2017-08-21 03:32:58 +02:00
|
|
|
payload,
|
2017-08-08 22:37:16 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-23 04:27:35 +02:00
|
|
|
function showSidebar ({ transitionName, type }) {
|
2017-08-02 22:32:02 +02:00
|
|
|
return {
|
|
|
|
type: actions.SIDEBAR_OPEN,
|
2018-08-23 04:27:35 +02:00
|
|
|
value: {
|
|
|
|
transitionName,
|
|
|
|
type,
|
|
|
|
},
|
2017-08-02 22:32:02 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function hideSidebar () {
|
|
|
|
return {
|
|
|
|
type: actions.SIDEBAR_CLOSE,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-07-19 08:31:02 +02:00
|
|
|
function showAlert (msg) {
|
|
|
|
return {
|
|
|
|
type: actions.ALERT_OPEN,
|
|
|
|
value: msg,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function hideAlert () {
|
|
|
|
return {
|
|
|
|
type: actions.ALERT_CLOSE,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-08 21:42:25 +02:00
|
|
|
/**
|
|
|
|
* This action will receive two types of values via qrCodeData
|
|
|
|
* an object with the following structure {type, values}
|
|
|
|
* or null (used to clear the previous value)
|
|
|
|
*/
|
2018-07-25 02:32:20 +02:00
|
|
|
function qrCodeDetected (qrCodeData) {
|
|
|
|
return {
|
|
|
|
type: actions.QR_CODE_DETECTED,
|
|
|
|
value: qrCodeData,
|
|
|
|
}
|
|
|
|
}
|
2017-08-02 22:32:02 +02:00
|
|
|
|
2017-01-19 01:45:39 +01:00
|
|
|
function showLoadingIndication (message) {
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.SHOW_LOADING,
|
2017-01-19 01:45:39 +01:00
|
|
|
value: message,
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-14 01:29:43 +02:00
|
|
|
function setHardwareWalletDefaultHdPath ({ device, path }) {
|
|
|
|
return {
|
|
|
|
type: actions.SET_HARDWARE_WALLET_DEFAULT_HD_PATH,
|
|
|
|
value: {device, path},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function hideLoadingIndication () {
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.HIDE_LOADING,
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-08-10 22:43:01 +02:00
|
|
|
function showSubLoadingIndication () {
|
|
|
|
return {
|
|
|
|
type: actions.SHOW_SUB_LOADING_INDICATION,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function hideSubLoadingIndication () {
|
|
|
|
return {
|
|
|
|
type: actions.HIDE_SUB_LOADING_INDICATION,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function displayWarning (text) {
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.DISPLAY_WARNING,
|
2016-04-14 00:28:44 +02:00
|
|
|
value: text,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function hideWarning () {
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.HIDE_WARNING,
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function requestExportAccount () {
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.REQUEST_ACCOUNT_EXPORT,
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-03-21 16:53:34 +01:00
|
|
|
function exportAccount (password, address) {
|
2016-04-14 00:28:44 +02:00
|
|
|
var self = this
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
return function (dispatch) {
|
2016-04-14 00:28:44 +02:00
|
|
|
dispatch(self.showLoadingIndication())
|
|
|
|
|
2017-03-21 16:53:34 +01:00
|
|
|
log.debug(`background.submitPassword`)
|
2017-09-27 01:03:33 +02:00
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
background.submitPassword(password, function (err) {
|
2017-03-21 16:53:34 +01:00
|
|
|
if (err) {
|
2017-09-27 01:03:33 +02:00
|
|
|
log.error('Error in submiting password.')
|
|
|
|
dispatch(self.hideLoadingIndication())
|
|
|
|
dispatch(self.displayWarning('Incorrect Password.'))
|
|
|
|
return reject(err)
|
2017-03-21 16:53:34 +01:00
|
|
|
}
|
2017-09-27 01:03:33 +02:00
|
|
|
log.debug(`background.exportAccount`)
|
|
|
|
return background.exportAccount(address, function (err, result) {
|
|
|
|
dispatch(self.hideLoadingIndication())
|
2017-03-21 16:53:34 +01:00
|
|
|
|
2017-09-27 01:03:33 +02:00
|
|
|
if (err) {
|
|
|
|
log.error(err)
|
|
|
|
dispatch(self.displayWarning('Had a problem exporting the account.'))
|
|
|
|
return reject(err)
|
|
|
|
}
|
2017-03-21 16:53:34 +01:00
|
|
|
|
2017-11-15 18:39:03 +01:00
|
|
|
// dispatch(self.exportAccountComplete())
|
|
|
|
dispatch(self.showPrivateKey(result))
|
2017-09-27 01:03:33 +02:00
|
|
|
|
|
|
|
return resolve(result)
|
|
|
|
})
|
2017-03-21 16:53:34 +01:00
|
|
|
})
|
2016-04-14 00:28:44 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-11-02 13:15:59 +01:00
|
|
|
function exportAccountComplete () {
|
2017-09-27 01:03:33 +02:00
|
|
|
return {
|
|
|
|
type: actions.EXPORT_ACCOUNT,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function showPrivateKey (key) {
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.SHOW_PRIVATE_KEY,
|
2016-04-14 00:28:44 +02:00
|
|
|
value: key,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-04-19 05:33:51 +02:00
|
|
|
function setAccountLabel (account, label) {
|
2016-05-21 01:18:54 +02:00
|
|
|
return (dispatch) => {
|
2016-05-25 21:39:12 +02:00
|
|
|
dispatch(actions.showLoadingIndication())
|
2018-04-19 05:33:51 +02:00
|
|
|
log.debug(`background.setAccountLabel`)
|
2017-10-26 03:23:46 +02:00
|
|
|
|
|
|
|
return new Promise((resolve, reject) => {
|
2018-04-19 05:33:51 +02:00
|
|
|
background.setAccountLabel(account, label, (err) => {
|
2017-10-26 03:23:46 +02:00
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
|
|
|
|
if (err) {
|
|
|
|
dispatch(actions.displayWarning(err.message))
|
|
|
|
reject(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
dispatch({
|
2018-04-19 05:33:51 +02:00
|
|
|
type: actions.SET_ACCOUNT_LABEL,
|
2017-10-26 03:23:46 +02:00
|
|
|
value: { account, label },
|
|
|
|
})
|
|
|
|
|
|
|
|
resolve(account)
|
2016-05-21 01:18:54 +02:00
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 22:18:32 +02:00
|
|
|
function showSendPage () {
|
2016-04-14 00:28:44 +02:00
|
|
|
return {
|
2016-05-25 21:39:12 +02:00
|
|
|
type: actions.SHOW_SEND_PAGE,
|
2016-04-14 00:28:44 +02:00
|
|
|
}
|
|
|
|
}
|
2016-08-10 22:43:01 +02:00
|
|
|
|
2017-09-07 13:24:03 +02:00
|
|
|
function showSendTokenPage () {
|
|
|
|
return {
|
|
|
|
type: actions.SHOW_SEND_TOKEN_PAGE,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-04-05 03:23:46 +02:00
|
|
|
function buyEth (opts) {
|
2016-08-10 22:43:01 +02:00
|
|
|
return (dispatch) => {
|
2017-04-05 03:23:46 +02:00
|
|
|
const url = getBuyEthUrl(opts)
|
|
|
|
global.platform.openWindow({ url })
|
2016-08-10 22:43:01 +02:00
|
|
|
dispatch({
|
|
|
|
type: actions.BUY_ETH,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-09-19 00:41:25 +02:00
|
|
|
function onboardingBuyEthView (address) {
|
|
|
|
return {
|
|
|
|
type: actions.ONBOARDING_BUY_ETH_VIEW,
|
|
|
|
value: address,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-08-13 00:41:59 +02:00
|
|
|
function buyEthView (address) {
|
2016-08-10 22:43:01 +02:00
|
|
|
return {
|
2016-08-13 00:41:59 +02:00
|
|
|
type: actions.BUY_ETH_VIEW,
|
|
|
|
value: address,
|
2016-08-10 22:43:01 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function coinBaseSubview () {
|
|
|
|
return {
|
|
|
|
type: actions.COINBASE_SUBVIEW,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function pairUpdate (coin) {
|
|
|
|
return (dispatch) => {
|
|
|
|
dispatch(actions.showSubLoadingIndication())
|
|
|
|
dispatch(actions.hideWarning())
|
|
|
|
shapeShiftRequest('marketinfo', {pair: `${coin.toLowerCase()}_eth`}, (mktResponse) => {
|
|
|
|
dispatch(actions.hideSubLoadingIndication())
|
2018-03-05 18:53:00 +01:00
|
|
|
if (mktResponse.error) return dispatch(actions.displayWarning(mktResponse.error))
|
2016-08-10 22:43:01 +02:00
|
|
|
dispatch({
|
|
|
|
type: actions.PAIR_UPDATE,
|
|
|
|
value: {
|
|
|
|
marketinfo: mktResponse,
|
|
|
|
},
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function shapeShiftSubview (network) {
|
2016-08-15 03:39:19 +02:00
|
|
|
var pair = 'btc_eth'
|
2016-08-10 22:43:01 +02:00
|
|
|
return (dispatch) => {
|
|
|
|
dispatch(actions.showSubLoadingIndication())
|
|
|
|
shapeShiftRequest('marketinfo', {pair}, (mktResponse) => {
|
|
|
|
shapeShiftRequest('getcoins', {}, (response) => {
|
|
|
|
dispatch(actions.hideSubLoadingIndication())
|
2016-11-08 01:02:02 +01:00
|
|
|
if (mktResponse.error) return dispatch(actions.displayWarning(mktResponse.error))
|
2016-08-10 22:43:01 +02:00
|
|
|
dispatch({
|
|
|
|
type: actions.SHAPESHIFT_SUBVIEW,
|
|
|
|
value: {
|
|
|
|
marketinfo: mktResponse,
|
|
|
|
coinOptions: response,
|
|
|
|
},
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-08-13 02:43:24 +02:00
|
|
|
function coinShiftRquest (data, marketData) {
|
2016-08-10 22:43:01 +02:00
|
|
|
return (dispatch) => {
|
2016-08-13 00:41:59 +02:00
|
|
|
dispatch(actions.showLoadingIndication())
|
2016-08-10 22:43:01 +02:00
|
|
|
shapeShiftRequest('shift', { method: 'POST', data}, (response) => {
|
2017-02-04 05:45:20 +01:00
|
|
|
dispatch(actions.hideLoadingIndication())
|
2016-11-08 01:02:02 +01:00
|
|
|
if (response.error) return dispatch(actions.displayWarning(response.error))
|
2016-08-13 02:43:24 +02:00
|
|
|
var message = `
|
2018-01-12 20:48:18 +01:00
|
|
|
Deposit your ${response.depositType} to the address below:`
|
2017-02-23 23:23:45 +01:00
|
|
|
log.debug(`background.createShapeShiftTx`)
|
2016-10-20 18:58:33 +02:00
|
|
|
background.createShapeShiftTx(response.deposit, response.depositType)
|
2016-09-13 02:27:14 +02:00
|
|
|
dispatch(actions.showQrView(response.deposit, [message].concat(marketData)))
|
2016-08-13 00:41:59 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-09-25 23:51:49 +02:00
|
|
|
function buyWithShapeShift (data) {
|
|
|
|
return dispatch => new Promise((resolve, reject) => {
|
|
|
|
shapeShiftRequest('shift', { method: 'POST', data}, (response) => {
|
|
|
|
if (response.error) {
|
|
|
|
return reject(response.error)
|
|
|
|
}
|
|
|
|
background.createShapeShiftTx(response.deposit, response.depositType)
|
|
|
|
return resolve(response)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2016-09-13 02:27:14 +02:00
|
|
|
function showQrView (data, message) {
|
|
|
|
return {
|
|
|
|
type: actions.SHOW_QR_VIEW,
|
|
|
|
value: {
|
|
|
|
message: message,
|
|
|
|
data: data,
|
|
|
|
},
|
2016-08-10 22:43:01 +02:00
|
|
|
}
|
|
|
|
}
|
2016-08-18 19:40:35 +02:00
|
|
|
function reshowQrCode (data, coin) {
|
|
|
|
return (dispatch) => {
|
|
|
|
dispatch(actions.showLoadingIndication())
|
|
|
|
shapeShiftRequest('marketinfo', {pair: `${coin.toLowerCase()}_eth`}, (mktResponse) => {
|
2016-11-08 01:02:02 +01:00
|
|
|
if (mktResponse.error) return dispatch(actions.displayWarning(mktResponse.error))
|
2017-12-22 19:43:02 +01:00
|
|
|
|
2016-08-19 00:20:26 +02:00
|
|
|
var message = [
|
2018-01-12 20:48:18 +01:00
|
|
|
`Deposit your ${coin} to the address below:`,
|
2016-08-18 19:40:35 +02:00
|
|
|
`Deposit Limit: ${mktResponse.limit}`,
|
|
|
|
`Deposit Minimum:${mktResponse.minimum}`,
|
|
|
|
]
|
|
|
|
|
2016-09-13 02:27:14 +02:00
|
|
|
dispatch(actions.hideLoadingIndication())
|
2017-11-15 18:39:03 +01:00
|
|
|
return dispatch(actions.showQrView(data, message))
|
|
|
|
// return dispatch(actions.showModal({
|
|
|
|
// name: 'SHAPESHIFT_DEPOSIT_TX',
|
|
|
|
// Qr: { data, message },
|
|
|
|
// }))
|
2016-08-18 19:40:35 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
2016-08-13 00:41:59 +02:00
|
|
|
|
2016-08-10 22:43:01 +02:00
|
|
|
function shapeShiftRequest (query, options, cb) {
|
|
|
|
var queryResponse, method
|
|
|
|
!options ? options = {} : null
|
|
|
|
options.method ? method = options.method : method = 'GET'
|
|
|
|
|
|
|
|
var requestListner = function (request) {
|
2017-09-25 23:51:49 +02:00
|
|
|
try {
|
|
|
|
queryResponse = JSON.parse(this.responseText)
|
|
|
|
cb ? cb(queryResponse) : null
|
|
|
|
return queryResponse
|
|
|
|
} catch (e) {
|
|
|
|
cb ? cb({error: e}) : null
|
|
|
|
return e
|
|
|
|
}
|
2016-08-10 22:43:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
var shapShiftReq = new XMLHttpRequest()
|
|
|
|
shapShiftReq.addEventListener('load', requestListner)
|
|
|
|
shapShiftReq.open(method, `https://shapeshift.io/${query}/${options.pair ? options.pair : ''}`, true)
|
|
|
|
|
|
|
|
if (options.method === 'POST') {
|
|
|
|
var jsonObj = JSON.stringify(options.data)
|
|
|
|
shapShiftReq.setRequestHeader('Content-Type', 'application/json')
|
|
|
|
return shapShiftReq.send(jsonObj)
|
|
|
|
} else {
|
|
|
|
return shapShiftReq.send()
|
|
|
|
}
|
|
|
|
}
|
2017-01-03 19:39:34 +01:00
|
|
|
|
2017-12-20 19:22:50 +01:00
|
|
|
function setFeatureFlag (feature, activated, notificationType) {
|
2017-11-14 17:04:55 +01:00
|
|
|
return (dispatch) => {
|
|
|
|
dispatch(actions.showLoadingIndication())
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
background.setFeatureFlag(feature, activated, (err, updatedFeatureFlags) => {
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
if (err) {
|
|
|
|
dispatch(actions.displayWarning(err.message))
|
2017-12-22 19:43:02 +01:00
|
|
|
return reject(err)
|
2017-11-14 17:04:55 +01:00
|
|
|
}
|
|
|
|
dispatch(actions.updateFeatureFlags(updatedFeatureFlags))
|
2017-12-20 19:22:50 +01:00
|
|
|
notificationType && dispatch(actions.showModal({ name: notificationType }))
|
2017-11-14 17:04:55 +01:00
|
|
|
resolve(updatedFeatureFlags)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function updateFeatureFlags (updatedFeatureFlags) {
|
|
|
|
return {
|
|
|
|
type: actions.UPDATE_FEATURE_FLAGS,
|
|
|
|
value: updatedFeatureFlags,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-08 20:34:52 +02:00
|
|
|
function setNetworkNonce (networkNonce) {
|
|
|
|
return {
|
|
|
|
type: actions.SET_NETWORK_NONCE,
|
|
|
|
value: networkNonce,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function updateNetworkNonce (address) {
|
|
|
|
return (dispatch) => {
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
global.ethQuery.getTransactionCount(address, (err, data) => {
|
|
|
|
dispatch(setNetworkNonce(data))
|
|
|
|
resolve(data)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-02-12 18:45:53 +01:00
|
|
|
function setMouseUserState (isMouseUser) {
|
|
|
|
return {
|
|
|
|
type: actions.SET_MOUSE_USER_STATE,
|
|
|
|
value: isMouseUser,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-01-03 19:39:34 +01:00
|
|
|
// Call Background Then Update
|
|
|
|
//
|
|
|
|
// A function generator for a common pattern wherein:
|
|
|
|
// We show loading indication.
|
|
|
|
// We call a background method.
|
|
|
|
// We hide loading indication.
|
|
|
|
// If it errored, we show a warning.
|
|
|
|
// If it didn't, we update the state.
|
2017-06-14 23:21:50 +02:00
|
|
|
function callBackgroundThenUpdateNoSpinner (method, ...args) {
|
|
|
|
return (dispatch) => {
|
|
|
|
method.call(background, ...args, (err) => {
|
|
|
|
if (err) {
|
|
|
|
return dispatch(actions.displayWarning(err.message))
|
|
|
|
}
|
|
|
|
forceUpdateMetamaskState(dispatch)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-01-03 19:39:34 +01:00
|
|
|
function callBackgroundThenUpdate (method, ...args) {
|
|
|
|
return (dispatch) => {
|
|
|
|
dispatch(actions.showLoadingIndication())
|
2017-02-03 01:46:56 +01:00
|
|
|
method.call(background, ...args, (err) => {
|
2017-01-03 19:39:34 +01:00
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
if (err) {
|
|
|
|
return dispatch(actions.displayWarning(err.message))
|
|
|
|
}
|
2017-02-03 01:46:56 +01:00
|
|
|
forceUpdateMetamaskState(dispatch)
|
2017-01-03 19:39:34 +01:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
2017-02-03 01:46:56 +01:00
|
|
|
|
2017-04-27 06:05:45 +02:00
|
|
|
function forceUpdateMetamaskState (dispatch) {
|
2017-02-23 23:23:45 +01:00
|
|
|
log.debug(`background.getState`)
|
2018-03-08 16:29:29 +01:00
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
background.getState((err, newState) => {
|
|
|
|
if (err) {
|
|
|
|
dispatch(actions.displayWarning(err.message))
|
|
|
|
return reject(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
dispatch(actions.updateMetamaskState(newState))
|
2017-11-29 05:24:35 +01:00
|
|
|
resolve(newState)
|
2018-03-08 16:29:29 +01:00
|
|
|
})
|
2017-02-03 01:46:56 +01:00
|
|
|
})
|
2017-02-04 05:45:20 +01:00
|
|
|
}
|
2017-10-16 07:28:25 +02:00
|
|
|
|
|
|
|
function toggleAccountMenu () {
|
|
|
|
return {
|
|
|
|
type: actions.TOGGLE_ACCOUNT_MENU,
|
|
|
|
}
|
|
|
|
}
|
2017-11-24 02:33:44 +01:00
|
|
|
|
2017-11-24 18:35:17 +01:00
|
|
|
function setUseBlockie (val) {
|
|
|
|
return (dispatch) => {
|
|
|
|
dispatch(actions.showLoadingIndication())
|
|
|
|
log.debug(`background.setUseBlockie`)
|
|
|
|
background.setUseBlockie(val, (err) => {
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
if (err) {
|
|
|
|
return dispatch(actions.displayWarning(err.message))
|
|
|
|
}
|
|
|
|
})
|
|
|
|
dispatch({
|
|
|
|
type: actions.SET_USE_BLOCKIE,
|
2017-11-25 23:47:34 +01:00
|
|
|
value: val,
|
2017-11-24 18:35:17 +01:00
|
|
|
})
|
2017-11-24 02:33:44 +01:00
|
|
|
}
|
2017-11-25 23:47:34 +01:00
|
|
|
}
|
2017-12-22 19:43:02 +01:00
|
|
|
|
2018-03-16 01:29:45 +01:00
|
|
|
function updateCurrentLocale (key) {
|
|
|
|
return (dispatch) => {
|
|
|
|
dispatch(actions.showLoadingIndication())
|
|
|
|
fetchLocale(key)
|
|
|
|
.then((localeMessages) => {
|
2018-03-28 03:21:46 +02:00
|
|
|
log.debug(`background.setCurrentLocale`)
|
2018-03-16 01:29:45 +01:00
|
|
|
background.setCurrentLocale(key, (err) => {
|
|
|
|
dispatch(actions.hideLoadingIndication())
|
|
|
|
if (err) {
|
|
|
|
return dispatch(actions.displayWarning(err.message))
|
|
|
|
}
|
|
|
|
dispatch(actions.setCurrentLocale(key))
|
|
|
|
dispatch(actions.setLocaleMessages(localeMessages))
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function setCurrentLocale (key) {
|
|
|
|
return {
|
|
|
|
type: actions.SET_CURRENT_LOCALE,
|
|
|
|
value: key,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function setLocaleMessages (localeMessages) {
|
|
|
|
return {
|
|
|
|
type: actions.SET_LOCALE_MESSAGES,
|
|
|
|
value: localeMessages,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-12-22 19:43:02 +01:00
|
|
|
function updateNetworkEndpointType (networkEndpointType) {
|
|
|
|
return {
|
|
|
|
type: actions.UPDATE_NETWORK_ENDPOINT_TYPE,
|
|
|
|
value: networkEndpointType,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-05-20 08:04:19 +02:00
|
|
|
function setPendingTokens (pendingTokens) {
|
|
|
|
const { customToken = {}, selectedTokens = {} } = pendingTokens
|
|
|
|
const { address, symbol, decimals } = customToken
|
|
|
|
const tokens = address && symbol && decimals
|
|
|
|
? { ...selectedTokens, [address]: { ...customToken, isCustom: true } }
|
|
|
|
: selectedTokens
|
|
|
|
|
|
|
|
return {
|
|
|
|
type: actions.SET_PENDING_TOKENS,
|
|
|
|
payload: tokens,
|
2017-12-22 19:43:02 +01:00
|
|
|
}
|
|
|
|
}
|