mirror of
https://github.com/status-im/status-react.git
synced 2025-01-11 19:44:47 +00:00
Use correct chain name if custom network added
Signed-off-by: Goran Jovic <goranjovic@gmail.com>
This commit is contained in:
parent
30a79c88bb
commit
44f1ca474b
@ -14,9 +14,8 @@
|
|||||||
;;TODO(goranjovic): currently we only allow tokens which are enabled in Manage assets here
|
;;TODO(goranjovic): currently we only allow tokens which are enabled in Manage assets here
|
||||||
;; because balances are only fetched for them. Revisit this decision with regard to battery/network consequences
|
;; because balances are only fetched for them. Revisit this decision with regard to battery/network consequences
|
||||||
;; if we were to update all balances.
|
;; if we were to update all balances.
|
||||||
(defn- allowed-assets [network account]
|
(defn- allowed-assets [chain account]
|
||||||
(let [chain (keyword (ethereum/network-names network))
|
(let [visible-token-symbols (get-in account [:settings :wallet :visible-tokens chain])]
|
||||||
visible-token-symbols (get-in account [:settings :wallet :visible-tokens chain])]
|
|
||||||
(->> (tokens/tokens-for chain)
|
(->> (tokens/tokens-for chain)
|
||||||
(filter #(not (:nft? %)))
|
(filter #(not (:nft? %)))
|
||||||
(filter #(contains? visible-token-symbols (:symbol %)))
|
(filter #(contains? visible-token-symbols (:symbol %)))
|
||||||
@ -26,19 +25,19 @@
|
|||||||
|
|
||||||
(defn- generate-context
|
(defn- generate-context
|
||||||
"Generates context for jail call"
|
"Generates context for jail call"
|
||||||
[account current-account-id chat-id group-chat? to network]
|
[account current-account-id chat-id group-chat? to chain]
|
||||||
(merge {:platform platform/os
|
(merge {:platform platform/os
|
||||||
:network (ethereum/network-names network)
|
:network chain
|
||||||
:from current-account-id
|
:from current-account-id
|
||||||
:to to
|
:to to
|
||||||
:allowed-assets (clj->js (allowed-assets network account))
|
:allowed-assets (clj->js (allowed-assets chain account))
|
||||||
:chat {:chat-id chat-id
|
:chat {:chat-id chat-id
|
||||||
:group-chat (boolean group-chat?)}}
|
:group-chat (boolean group-chat?)}}
|
||||||
i18n/delimeters))
|
i18n/delimeters))
|
||||||
|
|
||||||
(defn request-command-message-data
|
(defn request-command-message-data
|
||||||
"Requests command message data from jail"
|
"Requests command message data from jail"
|
||||||
[{:contacts/keys [contacts] :account/keys [account] :keys [network] :as db}
|
[{:contacts/keys [contacts] :account/keys [account] :keys [chain] :as db}
|
||||||
{{:keys [command command-scope-bitmask bot params type]} :content
|
{{:keys [command command-scope-bitmask bot params type]} :content
|
||||||
:keys [chat-id group-id] :as message}
|
:keys [chat-id group-id] :as message}
|
||||||
{:keys [data-type] :as opts}]
|
{:keys [data-type] :as opts}]
|
||||||
@ -51,7 +50,7 @@
|
|||||||
to (get-in contacts [chat-id :address])
|
to (get-in contacts [chat-id :address])
|
||||||
address (get-in db [:account/account :address])
|
address (get-in db [:account/account :address])
|
||||||
jail-params {:parameters params
|
jail-params {:parameters params
|
||||||
:context (generate-context account address chat-id (models.message/group-message? message) to network)}]
|
:context (generate-context account address chat-id (models.message/group-message? message) to chain)}]
|
||||||
{:db db
|
{:db db
|
||||||
:call-jail [{:jail-id bot
|
:call-jail [{:jail-id bot
|
||||||
:path path
|
:path path
|
||||||
|
@ -15,7 +15,7 @@
|
|||||||
:from-chat? true)))
|
:from-chat? true)))
|
||||||
|
|
||||||
(defn send-shortcut-fx [{:account/keys [account] :as db} contact params]
|
(defn send-shortcut-fx [{:account/keys [account] :as db} contact params]
|
||||||
(let [chain (keyword (ethereum/network-names (:network db)))
|
(let [chain (keyword (:chain db))
|
||||||
symbol (-> params :asset keyword)
|
symbol (-> params :asset keyword)
|
||||||
{:keys [decimals]} (tokens/asset-for chain symbol)]
|
{:keys [decimals]} (tokens/asset-for chain symbol)]
|
||||||
(merge {:db (-> db
|
(merge {:db (-> db
|
||||||
|
@ -386,7 +386,7 @@
|
|||||||
:keys [prefill prefillBotDb]
|
:keys [prefill prefillBotDb]
|
||||||
:as request}
|
:as request}
|
||||||
{:keys [params command handler-data content-type]}
|
{:keys [params command handler-data content-type]}
|
||||||
network
|
chain
|
||||||
currency
|
currency
|
||||||
prices
|
prices
|
||||||
tx-hash]
|
tx-hash]
|
||||||
@ -405,7 +405,7 @@
|
|||||||
:prefill-bot-db prefillBotDb}
|
:prefill-bot-db prefillBotDb}
|
||||||
{:params (cond-> params
|
{:params (cond-> params
|
||||||
(= (:name command) constants/command-send)
|
(= (:name command) constants/command-send)
|
||||||
(assoc :network (ethereum/network-names network)
|
(assoc :network chain
|
||||||
:fiat-amount (money/fiat-amount-value (:amount params)
|
:fiat-amount (money/fiat-amount-value (:amount params)
|
||||||
(-> params :asset keyword)
|
(-> params :asset keyword)
|
||||||
currency
|
currency
|
||||||
@ -444,7 +444,7 @@
|
|||||||
:dispatch [:update-transactions]}]))))
|
:dispatch [:update-transactions]}]))))
|
||||||
|
|
||||||
(defn send-command
|
(defn send-command
|
||||||
[{{:keys [current-public-key chats network prices] :as db} :db :keys [now] :as cofx} params]
|
[{{:keys [current-public-key chats chain prices] :as db} :db :keys [now] :as cofx} params]
|
||||||
(let [{{:keys [handler-data to-message command] :as content} :command chat-id :chat-id} params
|
(let [{{:keys [handler-data to-message command] :as content} :command chat-id :chat-id} params
|
||||||
;; We send commands to deleted chats as well, i.e. signed later transactions
|
;; We send commands to deleted chats as well, i.e. signed later transactions
|
||||||
chat (or (get chats chat-id) {:chat-id chat-id})
|
chat (or (get chats chat-id) {:chat-id chat-id})
|
||||||
@ -454,7 +454,7 @@
|
|||||||
currency (-> (currency-settings/get-user-currency db) name string/upper-case keyword)]
|
currency (-> (currency-settings/get-user-currency db) name string/upper-case keyword)]
|
||||||
(handlers-macro/merge-fx cofx
|
(handlers-macro/merge-fx cofx
|
||||||
(upsert-and-send (prepare-command-message current-public-key chat now request content
|
(upsert-and-send (prepare-command-message current-public-key chat now request content
|
||||||
network currency prices tx-hash))
|
chain currency prices tx-hash))
|
||||||
(console-events/console-respond-command-messages command handler-data)
|
(console-events/console-respond-command-messages command handler-data)
|
||||||
(requests-events/request-answered chat-id to-message)
|
(requests-events/request-answered chat-id to-message)
|
||||||
(update-transactions command-name tx-hash {:with-delay? false}))))
|
(update-transactions command-name tx-hash {:with-delay? false}))))
|
||||||
@ -470,7 +470,7 @@
|
|||||||
(merge {:dispatch-n dn} (dissoc fx :dispatch-n) (dissoc command :dispatch-n)))))
|
(merge {:dispatch-n dn} (dissoc fx :dispatch-n) (dissoc command :dispatch-n)))))
|
||||||
|
|
||||||
(defn invoke-command-handlers
|
(defn invoke-command-handlers
|
||||||
[{{:contacts/keys [contacts] :keys [network] :as db} :db}
|
[{{:contacts/keys [contacts] :keys [chain] :as db} :db}
|
||||||
{{:keys [command params id]} :command
|
{{:keys [command params id]} :command
|
||||||
:keys [chat-id address]
|
:keys [chat-id address]
|
||||||
:as orig-params}]
|
:as orig-params}]
|
||||||
@ -484,7 +484,7 @@
|
|||||||
:context (cond-> {:from address
|
:context (cond-> {:from address
|
||||||
:to to
|
:to to
|
||||||
:current-account (get db :account/account)
|
:current-account (get db :account/account)
|
||||||
:network (ethereum/network-names network)
|
:network chain
|
||||||
:message-id id}
|
:message-id id}
|
||||||
(:async-handler command)
|
(:async-handler command)
|
||||||
(assoc :orig-params orig-params))}]
|
(assoc :orig-params orig-params))}]
|
||||||
|
@ -131,6 +131,7 @@
|
|||||||
;;;;NETWORK
|
;;;;NETWORK
|
||||||
|
|
||||||
(spec/def ::network (spec/nilable string?))
|
(spec/def ::network (spec/nilable string?))
|
||||||
|
(spec/def ::chain (spec/nilable string?))
|
||||||
(spec/def ::peers-count (spec/nilable integer?))
|
(spec/def ::peers-count (spec/nilable integer?))
|
||||||
(spec/def ::peers-summary (spec/nilable vector?))
|
(spec/def ::peers-summary (spec/nilable vector?))
|
||||||
(spec/def :inbox/fetching? (spec/nilable boolean?))
|
(spec/def :inbox/fetching? (spec/nilable boolean?))
|
||||||
@ -225,6 +226,7 @@
|
|||||||
::sync-state
|
::sync-state
|
||||||
::sync-data
|
::sync-data
|
||||||
::network
|
::network
|
||||||
|
::chain
|
||||||
:navigation/view-id
|
:navigation/view-id
|
||||||
:navigation/navigation-stack
|
:navigation/navigation-stack
|
||||||
:navigation/prev-tab-view-id
|
:navigation/prev-tab-view-id
|
||||||
|
@ -337,7 +337,9 @@
|
|||||||
status-module-initialized? status-node-started? device-UUID]
|
status-module-initialized? status-node-started? device-UUID]
|
||||||
:or [network (get app-db :network)]} [_ address]]
|
:or [network (get app-db :network)]} [_ address]]
|
||||||
(let [console-contact (get contacts constants/console-chat-id)
|
(let [console-contact (get contacts constants/console-chat-id)
|
||||||
current-account (accounts address)]
|
current-account (accounts address)
|
||||||
|
account-network-id (get current-account :network network)
|
||||||
|
account-network (get-in current-account [:networks account-network-id])]
|
||||||
(cond-> (assoc app-db
|
(cond-> (assoc app-db
|
||||||
:access-scope->commands-responses access-scope->commands-responses
|
:access-scope->commands-responses access-scope->commands-responses
|
||||||
:current-public-key (:public-key current-account)
|
:current-public-key (:public-key current-account)
|
||||||
@ -350,6 +352,7 @@
|
|||||||
:account/account current-account
|
:account/account current-account
|
||||||
:network-status network-status
|
:network-status network-status
|
||||||
:network network
|
:network network
|
||||||
|
:chain (ethereum/network->chain-name account-network)
|
||||||
:peers-summary peers-summary
|
:peers-summary peers-summary
|
||||||
:peers-count peers-count
|
:peers-count peers-count
|
||||||
:device-UUID device-UUID)
|
:device-UUID device-UUID)
|
||||||
|
@ -39,7 +39,7 @@
|
|||||||
(fn [current-account]
|
(fn [current-account]
|
||||||
(get (:networks current-account) (:network current-account))))
|
(get (:networks current-account) (:network current-account))))
|
||||||
|
|
||||||
(reg-sub :network-name (comp ethereum/network-names :network))
|
(reg-sub :network-name :chain)
|
||||||
|
|
||||||
(reg-sub :sync-state :sync-state)
|
(reg-sub :sync-state :sync-state)
|
||||||
(reg-sub :network-status :network-status)
|
(reg-sub :network-status :network-status)
|
||||||
|
@ -51,8 +51,8 @@
|
|||||||
(clj->js {:from from :to to :value value :gas gas :gasPrice gas-price})
|
(clj->js {:from from :to to :value value :gas gas :gasPrice gas-price})
|
||||||
#()))
|
#()))
|
||||||
|
|
||||||
(defn- send-tokens [{:keys [web3 from to value gas gas-price symbol network]}]
|
(defn- send-tokens [{:keys [web3 from to value gas gas-price symbol chain]}]
|
||||||
(let [contract (:address (tokens/symbol->token (keyword (ethereum/network-names network)) symbol))]
|
(let [contract (:address (tokens/symbol->token (keyword chain) symbol))]
|
||||||
(erc20/transfer web3 contract from to value {:gas gas :gasPrice gas-price} #())))
|
(erc20/transfer web3 contract from to value {:gas gas :gasPrice gas-price} #())))
|
||||||
|
|
||||||
(re-frame/reg-fx
|
(re-frame/reg-fx
|
||||||
@ -277,8 +277,8 @@
|
|||||||
(dissoc :message-id :id)))
|
(dissoc :message-id :id)))
|
||||||
|
|
||||||
(defn prepare-unconfirmed-status-transaction [db now hash transaction]
|
(defn prepare-unconfirmed-status-transaction [db now hash transaction]
|
||||||
(let [network (:network db)
|
(let [chain (:chain db)
|
||||||
token (tokens/symbol->token (keyword (ethereum/network-names network)) (:symbol transaction))]
|
token (tokens/symbol->token (keyword chain) (:symbol transaction))]
|
||||||
(-> transaction
|
(-> transaction
|
||||||
(assoc :confirmations "0"
|
(assoc :confirmations "0"
|
||||||
:timestamp (str now)
|
:timestamp (str now)
|
||||||
@ -342,9 +342,8 @@
|
|||||||
|
|
||||||
(handlers/register-handler-fx
|
(handlers/register-handler-fx
|
||||||
:wallet/sign-transaction
|
:wallet/sign-transaction
|
||||||
(fn [{{:keys [web3] :as db} :db} [_ later?]]
|
(fn [{{:keys [web3 chain] :as db} :db} [_ later?]]
|
||||||
(let [db' (assoc-in db [:wallet :send-transaction :wrong-password?] false)
|
(let [db' (assoc-in db [:wallet :send-transaction :wrong-password?] false)
|
||||||
network (:network db)
|
|
||||||
{:keys [amount id password to symbol method gas gas-price]} (get-in db [:wallet :send-transaction])]
|
{:keys [amount id password to symbol method gas gas-price]} (get-in db [:wallet :send-transaction])]
|
||||||
(if id
|
(if id
|
||||||
{::accept-transaction {:id id
|
{::accept-transaction {:id id
|
||||||
@ -363,7 +362,8 @@
|
|||||||
:gas-price gas-price
|
:gas-price gas-price
|
||||||
:symbol symbol
|
:symbol symbol
|
||||||
:method method
|
:method method
|
||||||
:network network}}))))
|
:chain chain}}))))
|
||||||
|
|
||||||
(handlers/register-handler-fx
|
(handlers/register-handler-fx
|
||||||
:wallet/sign-message-modal
|
:wallet/sign-message-modal
|
||||||
(fn [{db :db} _]
|
(fn [{db :db} _]
|
||||||
|
@ -12,14 +12,6 @@
|
|||||||
:testnet {:id 3 :name "Ropsten"}
|
:testnet {:id 3 :name "Ropsten"}
|
||||||
:rinkeby {:id 4 :name "Rinkeby"}})
|
:rinkeby {:id 4 :name "Rinkeby"}})
|
||||||
|
|
||||||
(def network-names
|
|
||||||
{"mainnet" "mainnet"
|
|
||||||
"mainnet_rpc" "mainnet"
|
|
||||||
"testnet" "testnet"
|
|
||||||
"testnet_rpc" "testnet"
|
|
||||||
"rinkeby" "rinkeby"
|
|
||||||
"rinkeby_rpc" "rinkeby"})
|
|
||||||
|
|
||||||
(defn chain-id->chain-keyword [i]
|
(defn chain-id->chain-keyword [i]
|
||||||
(some #(when (= i (:id (val %))) (key %)) chains))
|
(some #(when (= i (:id (val %))) (key %)) chains))
|
||||||
|
|
||||||
@ -72,6 +64,11 @@
|
|||||||
(defn network->chain-keyword [network]
|
(defn network->chain-keyword [network]
|
||||||
(chain-id->chain-keyword (network->chain-id network)))
|
(chain-id->chain-keyword (network->chain-id network)))
|
||||||
|
|
||||||
|
(defn network->chain-name [network]
|
||||||
|
(-> network
|
||||||
|
network->chain-keyword
|
||||||
|
name))
|
||||||
|
|
||||||
(defn sha3 [s]
|
(defn sha3 [s]
|
||||||
(.sha3 dependencies/Web3.prototype (str s)))
|
(.sha3 dependencies/Web3.prototype (str s)))
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user