mirror of
https://github.com/status-im/status-mobile.git
synced 2025-01-12 17:54:32 +00:00
Add reading nodes from contract
This PR is part of network incentivisation. It adds a way for a client to pull nodes from a contract. This is done by selecting the `eth.contract` fleet. If that is selected on login it will fetch nodes from a contract and pass them to status-go. If these can't be fetched, it will default to `eth.beta`. Currently contract information are hard-coded, but eventually the user will be able to add their own (probably). Toggled off in release. Signed-off-by: Andrea Maria Piana <andrea.maria.piana@gmail.com>
This commit is contained in:
parent
c2fc510c8e
commit
f8674c0ee1
1
.env
1
.env
@ -19,3 +19,4 @@ RN_BRIDGE_THRESHOLD_WARNINGS=0
|
|||||||
RPC_NETWORKS_ONLY=0
|
RPC_NETWORKS_ONLY=0
|
||||||
STICKERS_ENABLED=1
|
STICKERS_ENABLED=1
|
||||||
PARTITIONED_TOPIC=0
|
PARTITIONED_TOPIC=0
|
||||||
|
CONTRACT_NODES=1
|
||||||
|
1
.env.e2e
1
.env.e2e
@ -16,3 +16,4 @@ POW_TIME=1
|
|||||||
RN_BRIDGE_THRESHOLD_WARNINGS=0
|
RN_BRIDGE_THRESHOLD_WARNINGS=0
|
||||||
STICKERS_ENABLED=0
|
STICKERS_ENABLED=0
|
||||||
PARTITIONED_TOPIC=0
|
PARTITIONED_TOPIC=0
|
||||||
|
CONTRACT_NODES=1
|
||||||
|
@ -19,3 +19,4 @@ RN_BRIDGE_THRESHOLD_WARNINGS=0
|
|||||||
RPC_NETWORKS_ONLY=0
|
RPC_NETWORKS_ONLY=0
|
||||||
STICKERS_ENABLED=1
|
STICKERS_ENABLED=1
|
||||||
PARTITIONED_TOPIC=0
|
PARTITIONED_TOPIC=0
|
||||||
|
CONTRACT_NODES=1
|
||||||
|
@ -17,3 +17,4 @@ RN_BRIDGE_THRESHOLD_WARNINGS=0
|
|||||||
RPC_NETWORKS_ONLY=0
|
RPC_NETWORKS_ONLY=0
|
||||||
STICKERS_ENABLED=0
|
STICKERS_ENABLED=0
|
||||||
PARTITIONED_TOPIC=0
|
PARTITIONED_TOPIC=0
|
||||||
|
CONTRACT_NODES=1
|
||||||
|
@ -16,3 +16,4 @@ POW_TIME=1
|
|||||||
RN_BRIDGE_THRESHOLD_WARNINGS=0
|
RN_BRIDGE_THRESHOLD_WARNINGS=0
|
||||||
STICKERS_ENABLED=0
|
STICKERS_ENABLED=0
|
||||||
PARTITIONED_TOPIC=0
|
PARTITIONED_TOPIC=0
|
||||||
|
CONTRACT_NODES=1
|
||||||
|
@ -1 +1 @@
|
|||||||
0.23.0-beta.8-chaos
|
0.23.0-beta.10
|
||||||
|
@ -1047,6 +1047,27 @@ class StatusModule extends ReactContextBaseJavaModule implements LifecycleEventL
|
|||||||
StatusThreadPoolExecutor.getInstance().execute(r);
|
StatusThreadPoolExecutor.getInstance().execute(r);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ReactMethod
|
||||||
|
public void getNodesFromContract(final String rpcEndpoint, final String contractAddress, final Callback callback) {
|
||||||
|
Log.d(TAG, "getNodesFromContract");
|
||||||
|
if (!checkAvailability()) {
|
||||||
|
callback.invoke(false);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
Runnable r = new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
String res = Statusgo.getNodesFromContract(rpcEndpoint, contractAddress);
|
||||||
|
|
||||||
|
Log.d(TAG, res);
|
||||||
|
callback.invoke(res);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
StatusThreadPoolExecutor.getInstance().execute(r);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public @Nullable
|
public @Nullable
|
||||||
Map<String, Object> getConstants() {
|
Map<String, Object> getConstants() {
|
||||||
|
@ -436,6 +436,16 @@ void RCTStatus::updateMailservers(QString enodes, double callbackId) {
|
|||||||
}, enodes, callbackId);
|
}, enodes, callbackId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void RCTStatus::getNodesFromContract(QString url, QString address, double callbackId) {
|
||||||
|
Q_D(RCTStatus);
|
||||||
|
qCDebug(RCTSTATUS) << "::getNodesFromContract call - callbackId:" << callbackId;
|
||||||
|
QtConcurrent::run([&](QString url, QString address, double callbackId) {
|
||||||
|
const char* result = GetNodesFromContract(url.toUtf8().data(), address.toUtf8().data());
|
||||||
|
logStatusGoResult("::getNodesFromContract GetNodesFromContract", result);
|
||||||
|
d->bridge->invokePromiseCallback(callbackId, QVariantList{result});
|
||||||
|
}, url, address, callbackId);
|
||||||
|
}
|
||||||
|
|
||||||
void RCTStatus::chaosModeUpdate(bool on, double callbackId) {
|
void RCTStatus::chaosModeUpdate(bool on, double callbackId) {
|
||||||
Q_D(RCTStatus);
|
Q_D(RCTStatus);
|
||||||
qCDebug(RCTSTATUS) << "::chaosModeUpdate call - callbackId:" << callbackId;
|
qCDebug(RCTSTATUS) << "::chaosModeUpdate call - callbackId:" << callbackId;
|
||||||
|
@ -51,6 +51,7 @@ public:
|
|||||||
Q_INVOKABLE void enableInstallation(QString installationId, double callbackId);
|
Q_INVOKABLE void enableInstallation(QString installationId, double callbackId);
|
||||||
Q_INVOKABLE void disableInstallation(QString installationId, double callbackId);
|
Q_INVOKABLE void disableInstallation(QString installationId, double callbackId);
|
||||||
Q_INVOKABLE void updateMailservers(QString enodes, double callbackId);
|
Q_INVOKABLE void updateMailservers(QString enodes, double callbackId);
|
||||||
|
Q_INVOKABLE void getNodesFromContract(QString url, QString address, double callbackId);
|
||||||
Q_INVOKABLE void chaosModeUpdate(bool on, double callbackId);
|
Q_INVOKABLE void chaosModeUpdate(bool on, double callbackId);
|
||||||
|
|
||||||
Q_INVOKABLE void setAdjustResize();
|
Q_INVOKABLE void setAdjustResize();
|
||||||
|
@ -254,6 +254,17 @@ RCT_EXPORT_METHOD(updateMailservers:(NSString *)enodes
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//////////////////////////////////////////////////////////////////// getNodesFromContract
|
||||||
|
RCT_EXPORT_METHOD(getNodesFromContract:(NSString *)url
|
||||||
|
address:(NSString *) address
|
||||||
|
callback:(RCTResponseSenderBlock)callback) {
|
||||||
|
NSString* result = StatusgoGetNodesFromContract(url, address);
|
||||||
|
callback(@[result]);
|
||||||
|
#if DEBUG
|
||||||
|
NSLog(@"GetNodesFromContract() method called");
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////// chaosModeUpdate
|
//////////////////////////////////////////////////////////////////// chaosModeUpdate
|
||||||
RCT_EXPORT_METHOD(chaosModeUpdate:(BOOL)on
|
RCT_EXPORT_METHOD(chaosModeUpdate:(BOOL)on
|
||||||
callback:(RCTResponseSenderBlock)callback) {
|
callback:(RCTResponseSenderBlock)callback) {
|
||||||
|
@ -89,6 +89,11 @@
|
|||||||
"node-01.do-ams3.eth.test": "enode://1d193635e015918fb85bbaf774863d12f65d70c6977506187ef04420d74ec06c9e8f0dcb57ea042f85df87433dab17a1260ed8dde1bdf9d6d5d2de4b7bf8e993@206.189.243.163:443",
|
"node-01.do-ams3.eth.test": "enode://1d193635e015918fb85bbaf774863d12f65d70c6977506187ef04420d74ec06c9e8f0dcb57ea042f85df87433dab17a1260ed8dde1bdf9d6d5d2de4b7bf8e993@206.189.243.163:443",
|
||||||
"node-01.gc-us-central1-a.eth.test": "enode://f593a27731bc0f8eb088e2d39222c2d59dfb9bf0b3950d7a828d51e8ab9e08fffbd9916a82fd993c1a080c57c2bd70ed6c36f489a969de697aff93088dbee1a9@35.194.31.108:443"
|
"node-01.gc-us-central1-a.eth.test": "enode://f593a27731bc0f8eb088e2d39222c2d59dfb9bf0b3950d7a828d51e8ab9e08fffbd9916a82fd993c1a080c57c2bd70ed6c36f489a969de697aff93088dbee1a9@35.194.31.108:443"
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"eth.contract": {
|
||||||
|
"boot": {},
|
||||||
|
"mail": {},
|
||||||
|
"whisper": {}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"meta": {
|
"meta": {
|
||||||
|
@ -67,12 +67,13 @@
|
|||||||
{})))
|
{})))
|
||||||
|
|
||||||
(fx/defn switch-chaos-mode [{:keys [db] :as cofx} chaos-mode?]
|
(fx/defn switch-chaos-mode [{:keys [db] :as cofx} chaos-mode?]
|
||||||
(let [settings (get-in db [:account/account :settings])]
|
(when (:account/account db)
|
||||||
(fx/merge cofx
|
(let [settings (get-in db [:account/account :settings])]
|
||||||
{::chaos-mode-changed chaos-mode?}
|
(fx/merge cofx
|
||||||
(accounts.update/update-settings
|
{::chaos-mode-changed chaos-mode?}
|
||||||
(assoc settings :chaos-mode? chaos-mode?)
|
(accounts.update/update-settings
|
||||||
{}))))
|
(assoc settings :chaos-mode? chaos-mode?)
|
||||||
|
{})))))
|
||||||
|
|
||||||
(fx/defn enable-notifications [cofx desktop-notifications?]
|
(fx/defn enable-notifications [cofx desktop-notifications?]
|
||||||
(accounts.update/account-update cofx
|
(accounts.update/account-update cofx
|
||||||
|
@ -4,6 +4,8 @@
|
|||||||
[status-im.data-store.core :as data-store]
|
[status-im.data-store.core :as data-store]
|
||||||
[status-im.native-module.core :as status]
|
[status-im.native-module.core :as status]
|
||||||
[status-im.ui.screens.navigation :as navigation]
|
[status-im.ui.screens.navigation :as navigation]
|
||||||
|
[status-im.utils.config :as config]
|
||||||
|
[status-im.fleet.core :as fleet]
|
||||||
[status-im.utils.fx :as fx]
|
[status-im.utils.fx :as fx]
|
||||||
[status-im.react-native.js-dependencies :as rn-dependencies]
|
[status-im.react-native.js-dependencies :as rn-dependencies]
|
||||||
[status-im.utils.keychain.core :as keychain]
|
[status-im.utils.keychain.core :as keychain]
|
||||||
@ -14,12 +16,33 @@
|
|||||||
[status-im.utils.platform :as platform]
|
[status-im.utils.platform :as platform]
|
||||||
[status-im.protocol.core :as protocol]
|
[status-im.protocol.core :as protocol]
|
||||||
[status-im.models.wallet :as models.wallet]
|
[status-im.models.wallet :as models.wallet]
|
||||||
|
[status-im.utils.handlers :as handlers]
|
||||||
[status-im.models.transactions :as transactions]
|
[status-im.models.transactions :as transactions]
|
||||||
[status-im.i18n :as i18n]
|
[status-im.i18n :as i18n]
|
||||||
[status-im.node.core :as node]
|
[status-im.node.core :as node]
|
||||||
[status-im.ui.screens.mobile-network-settings.events :as mobile-network]
|
[status-im.ui.screens.mobile-network-settings.events :as mobile-network]
|
||||||
[status-im.chaos-mode.core :as chaos-mode]))
|
[status-im.chaos-mode.core :as chaos-mode]))
|
||||||
|
|
||||||
|
(def rpc-endpoint "https://goerli.infura.io/v3/f315575765b14720b32382a61a89341a")
|
||||||
|
(def contract-address "0xfbf4c8e2B41fAfF8c616a0E49Fb4365a5355Ffaf")
|
||||||
|
(def contract-fleet? #{:eth.contract})
|
||||||
|
|
||||||
|
(defn fetch-nodes [current-fleet resolve reject]
|
||||||
|
(let [default-nodes (-> (fleet/fleets {})
|
||||||
|
(get-in [:eth.beta :mail])
|
||||||
|
vals)]
|
||||||
|
(if config/contract-nodes-enabled?
|
||||||
|
(do
|
||||||
|
(log/debug "fetching contract fleet" current-fleet)
|
||||||
|
(status/get-nodes-from-contract
|
||||||
|
rpc-endpoint
|
||||||
|
contract-address
|
||||||
|
(handlers/response-handler resolve
|
||||||
|
(fn [error]
|
||||||
|
(log/warn "could not fetch nodes from contract defaulting to eth.beta")
|
||||||
|
(resolve default-nodes)))))
|
||||||
|
(resolve default-nodes))))
|
||||||
|
|
||||||
(defn login! [address password]
|
(defn login! [address password]
|
||||||
(status/login address password #(re-frame/dispatch [:accounts.login.callback/login-success %])))
|
(status/login address password #(re-frame/dispatch [:accounts.login.callback/login-success %])))
|
||||||
|
|
||||||
@ -31,11 +54,18 @@
|
|||||||
(defn clear-web-data! []
|
(defn clear-web-data! []
|
||||||
(status/clear-web-data))
|
(status/clear-web-data))
|
||||||
|
|
||||||
(defn change-account! [address password create-database-if-not-exist?]
|
(defn change-account! [address
|
||||||
|
password
|
||||||
|
create-database-if-not-exist?
|
||||||
|
current-fleet]
|
||||||
;; No matter what is the keychain we use, as checks are done on decrypting base
|
;; No matter what is the keychain we use, as checks are done on decrypting base
|
||||||
(.. (keychain/safe-get-encryption-key)
|
(.. (keychain/safe-get-encryption-key)
|
||||||
(then #(data-store/change-account address password % create-database-if-not-exist?))
|
(then #(data-store/change-account address password % create-database-if-not-exist?))
|
||||||
(then (fn [] (re-frame/dispatch [:init.callback/account-change-success address])))
|
(then #(js/Promise. (fn [resolve reject]
|
||||||
|
(if (contract-fleet? current-fleet)
|
||||||
|
(fetch-nodes current-fleet resolve reject)
|
||||||
|
(resolve)))))
|
||||||
|
(then (fn [nodes] (re-frame/dispatch [:init.callback/account-change-success address nodes])))
|
||||||
(catch (fn [error]
|
(catch (fn [error]
|
||||||
(log/warn "Could not change account" error)
|
(log/warn "Could not change account" error)
|
||||||
;; If all else fails we fallback to showing initial error
|
;; If all else fails we fallback to showing initial error
|
||||||
@ -65,7 +95,10 @@
|
|||||||
(assoc-in [:accounts/login :processing] true)
|
(assoc-in [:accounts/login :processing] true)
|
||||||
(assoc :node/on-ready :login))
|
(assoc :node/on-ready :login))
|
||||||
:accounts.login/clear-web-data nil
|
:accounts.login/clear-web-data nil
|
||||||
:data-store/change-account [address password create-database?]})))
|
:data-store/change-account [address
|
||||||
|
password
|
||||||
|
create-database?
|
||||||
|
(get-in db [:accounts/accounts address :settings :fleet])]})))
|
||||||
|
|
||||||
(fx/defn account-and-db-password-do-not-match
|
(fx/defn account-and-db-password-do-not-match
|
||||||
[{:keys [db] :as cofx} error]
|
[{:keys [db] :as cofx} error]
|
||||||
@ -151,7 +184,15 @@
|
|||||||
|
|
||||||
:database-does-not-exist
|
:database-does-not-exist
|
||||||
(let [{:keys [address password]} (accounts.db/credentials cofx)]
|
(let [{:keys [address password]} (accounts.db/credentials cofx)]
|
||||||
{:data-store/change-account [address password true]}))
|
{:data-store/change-account [address
|
||||||
|
password
|
||||||
|
true
|
||||||
|
(get-in cofx
|
||||||
|
[:db
|
||||||
|
:accounts/accounts
|
||||||
|
address
|
||||||
|
:settings
|
||||||
|
:fleet])]}))
|
||||||
{:db (update db :accounts/login assoc
|
{:db (update db :accounts/login assoc
|
||||||
:error error
|
:error error
|
||||||
:processing false)})))))
|
:processing false)})))))
|
||||||
@ -274,6 +315,8 @@
|
|||||||
|
|
||||||
(re-frame/reg-fx
|
(re-frame/reg-fx
|
||||||
:data-store/change-account
|
:data-store/change-account
|
||||||
(fn [[address password create-database-if-not-exist?]]
|
(fn [[address password create-database-if-not-exist? current-fleet]]
|
||||||
(change-account! address (security/safe-unmask-data password)
|
(change-account! address
|
||||||
create-database-if-not-exist?)))
|
(security/safe-unmask-data password)
|
||||||
|
create-database-if-not-exist?
|
||||||
|
current-fleet)))
|
||||||
|
@ -110,10 +110,12 @@
|
|||||||
(chat-loading/initialize-chats {:from 10}))))
|
(chat-loading/initialize-chats {:from 10}))))
|
||||||
|
|
||||||
(defn account-change-success
|
(defn account-change-success
|
||||||
[{:keys [db] :as cofx} [_ address]]
|
[{:keys [db] :as cofx} [_ address nodes]]
|
||||||
(let [{:node/keys [status on-ready]} db]
|
(let [{:node/keys [status]} db]
|
||||||
(fx/merge
|
(fx/merge
|
||||||
cofx
|
cofx
|
||||||
|
(when nodes
|
||||||
|
(fleet/set-nodes :eth.contract nodes))
|
||||||
(if (= status :started)
|
(if (= status :started)
|
||||||
(accounts.login/login)
|
(accounts.login/login)
|
||||||
(node/initialize (get-in db [:accounts/login :address])))
|
(node/initialize (get-in db [:accounts/login :address])))
|
||||||
|
@ -23,10 +23,15 @@
|
|||||||
(defn fleet-supports-les? [fleet]
|
(defn fleet-supports-les? [fleet]
|
||||||
(not (nil? (some #(= fleet %) fleets-with-les))))
|
(not (nil? (some #(= fleet %) fleets-with-les))))
|
||||||
|
|
||||||
(def fleets
|
(def default-fleets (slurp "resources/config/fleets.json"))
|
||||||
(reduce merge (map #(:fleets (types/json->clj %))
|
(def default-les-fleets (slurp "resources/config/fleets-les.json"))
|
||||||
[(slurp "resources/config/fleets.json")
|
|
||||||
(slurp "resources/config/fleets-les.json")])))
|
(defn fleets [{:keys [custom-fleets]}]
|
||||||
|
(as-> [default-fleets
|
||||||
|
default-les-fleets] $
|
||||||
|
(mapv #(:fleets (types/json->clj %)) $)
|
||||||
|
(conj $ custom-fleets)
|
||||||
|
(reduce merge $)))
|
||||||
|
|
||||||
(defn format-mailserver
|
(defn format-mailserver
|
||||||
[mailserver address]
|
[mailserver address]
|
||||||
@ -42,11 +47,11 @@
|
|||||||
{}
|
{}
|
||||||
mailservers))
|
mailservers))
|
||||||
|
|
||||||
(def default-mailservers
|
(defn default-mailservers [db]
|
||||||
(reduce (fn [acc [fleet node-by-type]]
|
(reduce (fn [acc [fleet node-by-type]]
|
||||||
(assoc acc fleet (format-mailservers (:mail node-by-type))))
|
(assoc acc fleet (format-mailservers (:mail node-by-type))))
|
||||||
{}
|
{}
|
||||||
fleets))
|
(fleets db)))
|
||||||
|
|
||||||
(fx/defn show-save-confirmation
|
(fx/defn show-save-confirmation
|
||||||
[{:keys [db] :as cofx} fleet]
|
[{:keys [db] :as cofx} fleet]
|
||||||
@ -57,6 +62,30 @@
|
|||||||
:on-accept #(re-frame/dispatch [:fleet.ui/save-fleet-confirmed (keyword fleet)])
|
:on-accept #(re-frame/dispatch [:fleet.ui/save-fleet-confirmed (keyword fleet)])
|
||||||
:on-cancel nil}})
|
:on-cancel nil}})
|
||||||
|
|
||||||
|
(defn nodes->fleet [nodes]
|
||||||
|
(letfn [(format-nodes [nodes]
|
||||||
|
(reduce (fn [acc n]
|
||||||
|
(assoc acc
|
||||||
|
(keyword n)
|
||||||
|
n))
|
||||||
|
{}
|
||||||
|
nodes))]
|
||||||
|
{:boot (format-nodes nodes)
|
||||||
|
:mail (format-nodes nodes)
|
||||||
|
:whisper (format-nodes nodes)}))
|
||||||
|
|
||||||
|
(fx/defn set-nodes [{:keys [db]} fleet nodes]
|
||||||
|
{:db (-> db
|
||||||
|
(assoc-in [:custom-fleets fleet] (nodes->fleet nodes))
|
||||||
|
(assoc-in [:mailserver/mailservers fleet] (format-mailservers
|
||||||
|
(reduce
|
||||||
|
(fn [acc e]
|
||||||
|
(assoc acc
|
||||||
|
(keyword e)
|
||||||
|
e))
|
||||||
|
{}
|
||||||
|
nodes))))})
|
||||||
|
|
||||||
(fx/defn save
|
(fx/defn save
|
||||||
[{:keys [db now] :as cofx} fleet]
|
[{:keys [db now] :as cofx} fleet]
|
||||||
(let [settings (get-in db [:account/account :settings])]
|
(let [settings (get-in db [:account/account :settings])]
|
||||||
|
@ -167,7 +167,8 @@
|
|||||||
(let [{:universal-links/keys [url]
|
(let [{:universal-links/keys [url]
|
||||||
:keys [accounts/accounts accounts/create networks/networks network
|
:keys [accounts/accounts accounts/create networks/networks network
|
||||||
network-status peers-count peers-summary view-id navigation-stack
|
network-status peers-count peers-summary view-id navigation-stack
|
||||||
desktop/desktop hardwallet
|
mailserver/mailservers
|
||||||
|
desktop/desktop hardwallet custom-fleets
|
||||||
device-UUID semaphores accounts/login]
|
device-UUID semaphores accounts/login]
|
||||||
:node/keys [status on-ready]
|
:node/keys [status on-ready]
|
||||||
:or {network (get app-db :network)}} db
|
:or {network (get app-db :network)}} db
|
||||||
@ -185,11 +186,13 @@
|
|||||||
:account/account current-account
|
:account/account current-account
|
||||||
:accounts/login login
|
:accounts/login login
|
||||||
:accounts/accounts accounts
|
:accounts/accounts accounts
|
||||||
|
:mailserver/mailservers mailservers
|
||||||
:network-status network-status
|
:network-status network-status
|
||||||
:network network
|
:network network
|
||||||
:network/type (:network/type db)
|
:network/type (:network/type db)
|
||||||
:chain (ethereum/network->chain-name account-network)
|
:chain (ethereum/network->chain-name account-network)
|
||||||
:universal-links/url url
|
:universal-links/url url
|
||||||
|
:custom-fleets custom-fleets
|
||||||
:peers-summary peers-summary
|
:peers-summary peers-summary
|
||||||
:peers-count peers-count
|
:peers-count peers-count
|
||||||
:device-UUID device-UUID
|
:device-UUID device-UUID
|
||||||
|
@ -98,3 +98,5 @@
|
|||||||
(def rooted-device? native-module/rooted-device?)
|
(def rooted-device? native-module/rooted-device?)
|
||||||
|
|
||||||
(def chaos-mode-update native-module/chaos-mode-update)
|
(def chaos-mode-update native-module/chaos-mode-update)
|
||||||
|
|
||||||
|
(def get-nodes-from-contract native-module/get-nodes-from-contract)
|
||||||
|
@ -153,6 +153,10 @@
|
|||||||
(when status
|
(when status
|
||||||
(.chaosModeUpdate status on on-result)))
|
(.chaosModeUpdate status on on-result)))
|
||||||
|
|
||||||
|
(defn get-nodes-from-contract [rpc-endpoint contract-address on-result]
|
||||||
|
(when status
|
||||||
|
(.getNodesFromContract status rpc-endpoint contract-address on-result)))
|
||||||
|
|
||||||
(defn rooted-device? [callback]
|
(defn rooted-device? [callback]
|
||||||
(cond
|
(cond
|
||||||
;; we assume that iOS is safe by default
|
;; we assume that iOS is safe by default
|
||||||
|
@ -90,7 +90,7 @@
|
|||||||
(defn- get-account-node-config [db address]
|
(defn- get-account-node-config [db address]
|
||||||
(let [accounts (get db :accounts/accounts)
|
(let [accounts (get db :accounts/accounts)
|
||||||
current-fleet-key (fleet/current-fleet db address)
|
current-fleet-key (fleet/current-fleet db address)
|
||||||
current-fleet (get fleet/fleets current-fleet-key)
|
current-fleet (get (fleet/fleets db) current-fleet-key)
|
||||||
rendezvous-nodes (pick-nodes 3 (vals (:rendezvous current-fleet)))
|
rendezvous-nodes (pick-nodes 3 (vals (:rendezvous current-fleet)))
|
||||||
{:keys [network installation-id settings bootnodes networks]}
|
{:keys [network installation-id settings bootnodes networks]}
|
||||||
(merge
|
(merge
|
||||||
|
@ -47,7 +47,7 @@
|
|||||||
:transport/chats {}
|
:transport/chats {}
|
||||||
:transport/filters {}
|
:transport/filters {}
|
||||||
:transport/message-envelopes {}
|
:transport/message-envelopes {}
|
||||||
:mailserver/mailservers fleet/default-mailservers
|
:mailserver/mailservers (fleet/default-mailservers {})
|
||||||
:mailserver/topics {}
|
:mailserver/topics {}
|
||||||
:mailserver/pending-requests 0
|
:mailserver/pending-requests 0
|
||||||
:chat/cooldowns 0
|
:chat/cooldowns 0
|
||||||
|
@ -7,3 +7,8 @@
|
|||||||
:settings/current-fleet
|
:settings/current-fleet
|
||||||
(fn [db _]
|
(fn [db _]
|
||||||
(fleet/current-fleet db)))
|
(fleet/current-fleet db)))
|
||||||
|
|
||||||
|
(re-frame/reg-sub
|
||||||
|
:fleets/custom-fleets
|
||||||
|
(fn [{:keys [custom-fleets]} _]
|
||||||
|
custom-fleets))
|
||||||
|
@ -34,18 +34,19 @@
|
|||||||
[react/text {:style styles/fleet-item-name-text}
|
[react/text {:style styles/fleet-item-name-text}
|
||||||
fleet]]]])))
|
fleet]]]])))
|
||||||
|
|
||||||
(def fleets
|
(defn fleets [custom-fleets]
|
||||||
(map name (keys fleet-core/fleets)))
|
(map name (keys (fleet-core/fleets {:custom-fleets custom-fleets}))))
|
||||||
|
|
||||||
(views/defview fleet-settings []
|
(views/defview fleet-settings []
|
||||||
(views/letsubs [current-fleet [:settings/current-fleet]]
|
(views/letsubs [custom-fleets [:fleets/custom-fleets]
|
||||||
|
current-fleet [:settings/current-fleet]]
|
||||||
[react/view {:flex 1}
|
[react/view {:flex 1}
|
||||||
[status-bar/status-bar]
|
[status-bar/status-bar]
|
||||||
[toolbar/toolbar {}
|
[toolbar/toolbar {}
|
||||||
toolbar/default-nav-back
|
toolbar/default-nav-back
|
||||||
[toolbar/content-title (i18n/label :t/fleet-settings)]]
|
[toolbar/content-title (i18n/label :t/fleet-settings)]]
|
||||||
[react/view styles/wrapper
|
[react/view styles/wrapper
|
||||||
[list/flat-list {:data fleets
|
[list/flat-list {:data (fleets custom-fleets)
|
||||||
:default-separator? false
|
:default-separator? false
|
||||||
:key-fn identity
|
:key-fn identity
|
||||||
:render-fn (render-row (name current-fleet))}]]]))
|
:render-fn (render-row (name current-fleet))}]]]))
|
||||||
|
@ -33,6 +33,7 @@
|
|||||||
(def partitioned-topic-enabled? (enabled? (get-config :PARTITIONED_TOPIC "0")))
|
(def partitioned-topic-enabled? (enabled? (get-config :PARTITIONED_TOPIC "0")))
|
||||||
(def tr-to-talk-enabled? (enabled? (get-config :TRIBUTE_TO_TALK 0)))
|
(def tr-to-talk-enabled? (enabled? (get-config :TRIBUTE_TO_TALK 0)))
|
||||||
(def max-message-delivery-attempts (js/parseInt (get-config :MAX_MESSAGE_DELIVERY_ATTEMPTS "6")))
|
(def max-message-delivery-attempts (js/parseInt (get-config :MAX_MESSAGE_DELIVERY_ATTEMPTS "6")))
|
||||||
|
(def contract-nodes-enabled? (enabled? (get-config :CONTRACT_NODES "0")))
|
||||||
|
|
||||||
;; CONFIG VALUES
|
;; CONFIG VALUES
|
||||||
(def log-level
|
(def log-level
|
||||||
|
51
test/cljs/status_im/test/fleet/core.cljs
Normal file
51
test/cljs/status_im/test/fleet/core.cljs
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
(ns status-im.test.fleet.core
|
||||||
|
(:require [cljs.test :refer-macros [deftest is testing]]
|
||||||
|
[status-im.constants :as constants]
|
||||||
|
[status-im.fleet.core :as fleet]))
|
||||||
|
|
||||||
|
(deftest fleets-test
|
||||||
|
(testing "not passing any extra fleet"
|
||||||
|
(testing "it returns the default fleets"
|
||||||
|
(is (=
|
||||||
|
#{:eth.beta
|
||||||
|
:eth.staging
|
||||||
|
:eth.test
|
||||||
|
:eth.contract
|
||||||
|
:les.dev.ropsten}
|
||||||
|
(into #{}
|
||||||
|
(keys (fleet/fleets {})))))))
|
||||||
|
(testing "passing a custom fleet"
|
||||||
|
(testing "it sets the custom fleet"
|
||||||
|
(is (= {:mail {"a" "a"}
|
||||||
|
:whisper {"w" "w"}
|
||||||
|
:boot {"b" "b"}}
|
||||||
|
(:custom-fleet
|
||||||
|
(fleet/fleets {:custom-fleets {:custom-fleet
|
||||||
|
{:mail {"a" "a"}
|
||||||
|
:whisper {"w" "w"}
|
||||||
|
:boot {"b" "b"}}}})))))))
|
||||||
|
|
||||||
|
(deftest set-nodes-test
|
||||||
|
(testing "set-nodes"
|
||||||
|
(let [actual (fleet/set-nodes {:db {}} :test-fleet ["a" "b" "c"])
|
||||||
|
actual-custom-fleet (get-in actual [:db :custom-fleets])
|
||||||
|
actual-mailservers (get-in actual [:db :mailserver/mailservers :test-fleet])]
|
||||||
|
(testing "it sets the custom fleet in the db"
|
||||||
|
(is actual-custom-fleet))
|
||||||
|
(testing "it sets the custom mailservers in the db"
|
||||||
|
(is actual-mailservers))
|
||||||
|
(testing "it correctly formats mailservers"
|
||||||
|
(is (= {:a {:id :a
|
||||||
|
:name "a"
|
||||||
|
:password constants/mailserver-password
|
||||||
|
:address "a"}
|
||||||
|
:b {:id :b
|
||||||
|
:name "b"
|
||||||
|
:password constants/mailserver-password
|
||||||
|
:address "b"}
|
||||||
|
:c {:id :c
|
||||||
|
:name "c"
|
||||||
|
:password constants/mailserver-password
|
||||||
|
:address "c"}}
|
||||||
|
actual-mailservers))))))
|
||||||
|
|
@ -14,6 +14,7 @@
|
|||||||
[status-im.test.wallet.transactions.subs]
|
[status-im.test.wallet.transactions.subs]
|
||||||
[status-im.test.wallet.transactions.views]
|
[status-im.test.wallet.transactions.views]
|
||||||
[status-im.test.mailserver.core]
|
[status-im.test.mailserver.core]
|
||||||
|
[status-im.test.fleet.core]
|
||||||
[status-im.test.group-chats.core]
|
[status-im.test.group-chats.core]
|
||||||
[status-im.test.pairing.core]
|
[status-im.test.pairing.core]
|
||||||
[status-im.test.node.core]
|
[status-im.test.node.core]
|
||||||
@ -86,6 +87,7 @@
|
|||||||
'status-im.test.data-store.realm.core
|
'status-im.test.data-store.realm.core
|
||||||
'status-im.test.extensions.core
|
'status-im.test.extensions.core
|
||||||
'status-im.test.mailserver.core
|
'status-im.test.mailserver.core
|
||||||
|
'status-im.test.fleet.core
|
||||||
'status-im.test.group-chats.core
|
'status-im.test.group-chats.core
|
||||||
'status-im.test.pairing.core
|
'status-im.test.pairing.core
|
||||||
'status-im.test.node.core
|
'status-im.test.node.core
|
||||||
|
@ -104,6 +104,7 @@
|
|||||||
:last-request nil
|
:last-request nil
|
||||||
:desktop-notifications? false
|
:desktop-notifications? false
|
||||||
:settings {:web3-opt-in? true
|
:settings {:web3-opt-in? true
|
||||||
|
:fleet :eth.beta
|
||||||
:wallet {:visible-tokens {:testnet #{:STT
|
:wallet {:visible-tokens {:testnet #{:STT
|
||||||
:HND}
|
:HND}
|
||||||
:mainnet #{:SNT}
|
:mainnet #{:SNT}
|
||||||
|
@ -12,7 +12,8 @@
|
|||||||
(deftest on-password-input-submitted
|
(deftest on-password-input-submitted
|
||||||
(testing
|
(testing
|
||||||
"handling :accounts.login.ui/password-input-submitted event"
|
"handling :accounts.login.ui/password-input-submitted event"
|
||||||
(let [cofx {:db {:accounts/login {:address "address"
|
(let [cofx {:db {:accounts/accounts {"address" {:settings {:fleet "fleet"}}}
|
||||||
|
:accounts/login {:address "address"
|
||||||
:password "password"}}}
|
:password "password"}}}
|
||||||
create-database? false
|
create-database? false
|
||||||
efx (login.core/user-login cofx create-database?)]
|
efx (login.core/user-login cofx create-database?)]
|
||||||
@ -20,7 +21,7 @@
|
|||||||
(is (contains? efx :accounts.login/clear-web-data)))
|
(is (contains? efx :accounts.login/clear-web-data)))
|
||||||
(testing "Change account."
|
(testing "Change account."
|
||||||
(is (= (:data-store/change-account efx)
|
(is (= (:data-store/change-account efx)
|
||||||
["address" "password" false])))
|
["address" "password" false "fleet"])))
|
||||||
(testing "set `node/on-ready` handler"
|
(testing "set `node/on-ready` handler"
|
||||||
(is (= (get-in efx [:db :node/on-ready]) :login)))
|
(is (= (get-in efx [:db :node/on-ready]) :login)))
|
||||||
(testing "start activity indicator"
|
(testing "start activity indicator"
|
||||||
@ -142,14 +143,15 @@
|
|||||||
|
|
||||||
(deftest on-verify-account-success-after-database-does-not-exist
|
(deftest on-verify-account-success-after-database-does-not-exist
|
||||||
(testing ":accounts.login.callback/verify-success event received."
|
(testing ":accounts.login.callback/verify-success event received."
|
||||||
(let [cofx {:db {:accounts/login {:address "address"
|
(let [cofx {:db {:accounts/accounts {"address" {:settings {:fleet "fleet"}}}
|
||||||
|
:accounts/login {:address "address"
|
||||||
:password "password"}}}
|
:password "password"}}}
|
||||||
verify-result "{\"error\":\"\"}"
|
verify-result "{\"error\":\"\"}"
|
||||||
realm-error {:error :database-does-not-exist}
|
realm-error {:error :database-does-not-exist}
|
||||||
efx (login.core/verify-callback
|
efx (login.core/verify-callback
|
||||||
cofx verify-result realm-error)]
|
cofx verify-result realm-error)]
|
||||||
(testing "Change account."
|
(testing "Change account."
|
||||||
(is (= ["address" "password" true]
|
(is (= ["address" "password" true "fleet"]
|
||||||
(:data-store/change-account efx))))
|
(:data-store/change-account efx))))
|
||||||
(testing "Stop node."
|
(testing "Stop node."
|
||||||
(is (contains? efx :node/stop))))))
|
(is (contains? efx :node/stop))))))
|
||||||
|
Loading…
x
Reference in New Issue
Block a user