Merge branch 'develop' into feature/commands-validation

Former-commit-id: 68c1e99d83ad294cb085c3fa3a8127db575883d9
This commit is contained in:
Roman Volosovskyi 2016-07-08 12:40:02 +03:00
commit 79f3ed036e
13 changed files with 189 additions and 81 deletions

View File

@ -128,7 +128,12 @@ public class GethModule extends ReactContextBaseJavaModule implements LifecycleE
} }
@ReactMethod @ReactMethod
public void startNode(Callback callback) { public void startNode(Callback callback, Callback onAlreadyRunning) {
if(GethService.isRunning()){
onAlreadyRunning.invoke();
return;
}
Activity currentActivity = getCurrentActivity(); Activity currentActivity = getCurrentActivity();

View File

@ -213,7 +213,7 @@ public class GethService extends Service {
String address = data.getString("address"); String address = data.getString("address");
String password = data.getString("password"); String password = data.getString("password");
// TODO: remove third argument // TODO: remove third argument
String result = Statusgo.Login(address, password); String result = Statusgo.UnlockAccount(address, password, 0);
Log.d(TAG, "Unlocked account: " + result); Log.d(TAG, "Unlocked account: " + result);
Bundle replyData = new Bundle(); Bundle replyData = new Bundle();

View File

@ -10,7 +10,7 @@
[prismatic/schema "1.0.4"] [prismatic/schema "1.0.4"]
^{:voom {:repo "git@github.com:status-im/status-lib.git" ^{:voom {:repo "git@github.com:status-im/status-lib.git"
:branch "master"}} :branch "master"}}
[status-im/protocol "0.1.1-20160630_153846-gbf92f5f"] [status-im/protocol "0.1.1-20160706_085008-ge61756a"]
[natal-shell "0.1.6"] [natal-shell "0.1.6"]
[com.andrewmcveigh/cljs-time "0.4.0"]] [com.andrewmcveigh/cljs-time "0.4.0"]]
:plugins [[lein-cljsbuild "1.1.1"] :plugins [[lein-cljsbuild "1.1.1"]

View File

@ -24,7 +24,10 @@
[status-im.components.jail :as j] [status-im.components.jail :as j]
[status-im.utils.types :refer [json->clj]] [status-im.utils.types :refer [json->clj]]
[status-im.commands.utils :refer [generate-hiccup]] [status-im.commands.utils :refer [generate-hiccup]]
status-im.chat.handlers.commands)) status-im.chat.handlers.commands
status-im.chat.handlers.animation
status-im.chat.handlers.requests
status-im.chat.handlers.unviewed-messages))
(register-handler :set-show-actions (register-handler :set-show-actions
(fn [db [_ show-actions]] (fn [db [_ show-actions]]
@ -140,6 +143,11 @@
(fn [db [_ {:keys [chat-id msg-id]}]] (fn [db [_ {:keys [chat-id msg-id]}]]
(set-message-shown db chat-id msg-id))) (set-message-shown db chat-id msg-id)))
(defn default-delivery-status [chat-id]
(if (console? chat-id)
:seen
:pending))
(defn prepare-message (defn prepare-message
[{:keys [identity current-chat-id] :as db} _] [{:keys [identity current-chat-id] :as db} _]
(let [text (get-in db [:chats current-chat-id :input-text]) (let [text (get-in db [:chats current-chat-id :input-text])
@ -152,6 +160,7 @@
:to current-chat-id :to current-chat-id
:from identity :from identity
:content-type text-content-type :content-type text-content-type
:delivery-status (default-delivery-status current-chat-id)
:outgoing true :outgoing true
:timestamp (time/now-ms)})] :timestamp (time/now-ms)})]
(if command (if command
@ -167,6 +176,7 @@
:to chat-id :to chat-id
:content content :content content
:content-type content-type-command :content-type content-type-command
:delivery-status (default-delivery-status chat-id)
:outgoing true :outgoing true
:preview preview-string :preview preview-string
:rendered-preview preview :rendered-preview preview
@ -208,12 +218,10 @@
[{:keys [new-message current-chat-id] :as db} _] [{:keys [new-message current-chat-id] :as db} _]
(when (and new-message (not-console? current-chat-id)) (when (and new-message (not-console? current-chat-id))
(let [{:keys [group-chat]} (get-in db [:chats current-chat-id]) (let [{:keys [group-chat]} (get-in db [:chats current-chat-id])
content (:content new-message)] message (select-keys new-message [:content :msg-id])]
(if group-chat (if group-chat
(api/send-group-user-msg {:group-id current-chat-id (api/send-group-user-msg (assoc message :group-id current-chat-id))
:content content}) (api/send-user-msg (assoc message :to current-chat-id))))))
(api/send-user-msg {:to current-chat-id
:content content})))))
(defn save-message-to-realm! (defn save-message-to-realm!
[{:keys [new-message current-chat-id]} _] [{:keys [new-message current-chat-id]} _]
@ -330,6 +338,7 @@
(assoc db :loaded-chats (chats/chats-list))) (assoc db :loaded-chats (chats/chats-list)))
(register-handler :initialize-chats (register-handler :initialize-chats
(after #(dispatch [:load-unviewed-messages!]))
((enrich initialize-chats) load-chats!)) ((enrich initialize-chats) load-chats!))
(defn store-message! (defn store-message!
@ -343,14 +352,22 @@
(defn receive-message (defn receive-message
[db [_ {chat-id :from :as message}]] [db [_ {chat-id :from :as message}]]
(let [message' (check-author-direction db chat-id message)] (let [message' (-> db
(check-author-direction chat-id message)
(assoc :delivery-status :pending))]
(-> db (-> db
(add-message-to-db chat-id message') (add-message-to-db chat-id message')
(assoc :new-message message')))) (assoc :new-message message'))))
(defn dispatch-unviewed-message!
[{:keys [new-message]} [_ {chat-id :from}]]
(let [{:keys [msg-id]} new-message]
(dispatch [:add-unviewed-message chat-id msg-id])))
(register-handler :received-msg (register-handler :received-msg
[(after store-message!) [(after store-message!)
(after dispatch-request!)] (after dispatch-request!)
(after dispatch-unviewed-message!)]
receive-message) receive-message)
(register-handler :group-received-msg (register-handler :group-received-msg
@ -478,3 +495,13 @@
(dispatch [:fix-commands-suggestions-height])))))] (dispatch [:fix-commands-suggestions-height])))))]
(fn [db [_ h]] (fn [db [_ h]]
(assoc db :layout-height h))) (assoc db :layout-height h)))
(register-handler :send-seen!
(after (fn [_ [_ chat-id message-id]]
(when-not (console? chat-id))
(dispatch [:msg-seen chat-id message-id])))
(u/side-effect!
(fn [_ [_ chat-id message-id]]
(when-not (console? chat-id)
(api/send-seen chat-id message-id)))))

View File

@ -0,0 +1,44 @@
(ns status-im.chat.handlers.unviewed-messages
(:require [re-frame.core :refer [after enrich path dispatch]]
[status-im.utils.handlers :refer [register-handler]]
[status-im.persistence.realm :as realm]))
(defn delivered-messages []
(-> (realm/get-by-fields
:msgs
{:delivery-status :delivered
:outgoing false})
(realm/collection->map)))
(defn set-unviewed-messages [db]
(let [messages (->> (::raw-unviewed-messages db)
(group-by :chat-id)
(map (fn [[id messages]]
[id {:messages-ids (map :msg-id messages)
:count (count messages)}]))
(into {}))]
(-> db
(assoc :unviewed-messages messages)
(dissoc ::raw-unviewed-messages))))
(defn load-messages! [db]
(let [messages (delivered-messages)]
(assoc db ::raw-unviewed-messages messages)))
(register-handler ::set-unviewed-messages set-unviewed-messages)
(register-handler :load-unviewed-messages!
(after #(dispatch [::set-unviewed-messages]))
load-messages!)
(register-handler :add-unviewed-message
(path :unviewed-messages)
(fn [db [_ chat-id message-id]]
(-> db
(update-in [chat-id :messages-ids] conj message-id)
(update-in [chat-id :count] inc))))
(register-handler :remove-unviewed-messages
(path :unviewed-messages)
(fn [db [_ chat-id]]
(dissoc db chat-id)))

View File

@ -182,3 +182,7 @@
(fn [db] (fn [db]
(let [current-chat-id (subscribe [:get-current-chat-id])] (let [current-chat-id (subscribe [:get-current-chat-id])]
(reaction (get-in @db [:custom-validation-errors @current-chat-id]))))) (reaction (get-in @db [:custom-validation-errors @current-chat-id])))))
(register-sub :unviewed-messages-count
(fn [db [_ chat-id]]
(reaction (get-in @db [:unviewed-messages chat-id :count]))))

View File

@ -120,20 +120,23 @@
[message-content-audio {:content content [message-content-audio {:content content
:content-type content-type}]]]) :content-type content-type}]]])
(defn message-delivery-status [{:keys [delivery-status]}] (defview message-delivery-status
[{:keys [delivery-status msg-id to] :as m}]
[status [:get-in [:message-status to msg-id]]]
[view st/delivery-view [view st/delivery-view
[image {:source (case delivery-status [image {:source (case (or status delivery-status)
:delivered {:uri :icon_ok_small}
:seen {:uri :icon_ok_small} :seen {:uri :icon_ok_small}
:seen-by-everyone {:uri :icon_ok_small} :seen-by-everyone {:uri :icon_ok_small}
:failed res/delivery-failed-icon) :failed res/delivery-failed-icon
nil)
:style st/delivery-image}] :style st/delivery-image}]
[text {:style st/delivery-text} [text {:style st/delivery-text}
(case delivery-status (case (or status delivery-status)
:delivered "Delivered" :delivered "Sent"
:seen "Seen" :seen "Seen"
:seen-by-everyone "Seen by everyone" :seen-by-everyone "Seen by everyone"
:failed "Failed")]]) :failed "Failed"
"Pending")]])
(defn member-photo [{:keys [photo-path]}] (defn member-photo [{:keys [photo-path]}]
[view st/photo-view [view st/photo-view
@ -159,12 +162,11 @@
[message-delivery-status {:delivery-status delivery-status}])]]])) [message-delivery-status {:delivery-status delivery-status}])]]]))
(defn message-body (defn message-body
[{:keys [outgoing] :as message} content] [{:keys [outgoing delivery-status] :as message} content]
(let [delivery-status :seen]
[view (st/message-body message) [view (st/message-body message)
content content
(when (and outgoing delivery-status) (when outgoing
[message-delivery-status {:delivery-status delivery-status}])])) [message-delivery-status message])])
(defn message-container-animation-logic [{:keys [to-value val callback]}] (defn message-container-animation-logic [{:keys [to-value val callback]}]
(fn [_] (fn [_]
@ -203,7 +205,18 @@
(into [view] children))) (into [view] children)))
(defn chat-message (defn chat-message
[{:keys [outgoing delivery-status timestamp new-day group-chat] [{:keys [outgoing delivery-status timestamp new-day group-chat msg-id chat-id]
:as message}]
(let [status (subscribe [:get-in [:message-status chat-id msg-id]])]
(r/create-class
{:component-did-mount
(fn []
(when (and (not outgoing)
(not= :seen delivery-status)
(not= :seen @status))
(dispatch [:send-seen! chat-id msg-id])))
:reagent-render
(fn [{:keys [outgoing delivery-status timestamp new-day group-chat]
:as message}] :as message}]
[message-container message [message-container message
;; TODO there is no new-day info in message ;; TODO there is no new-day info in message
@ -216,4 +229,4 @@
incoming-group-message-body incoming-group-message-body
message-body) message-body)
(merge message {:delivery-status (keyword delivery-status) (merge message {:delivery-status (keyword delivery-status)
:incoming-group incoming-group})])]]) :incoming-group incoming-group})])]])})))

View File

@ -6,9 +6,10 @@
[status-im.utils.utils :refer [truncate-str]] [status-im.utils.utils :refer [truncate-str]]
[status-im.utils.datetime :as time])) [status-im.utils.datetime :as time]))
(defn chat-list-item-inner-view (defview chat-list-item-inner-view
[{:keys [chat-id name color new-messages-count [{:keys [chat-id name color new-messages-count
online group-chat contacts] :as chat}] online group-chat contacts] :as chat}]
[unviewed-messages [:unviewed-messages-count chat-id]]
(let [last-message (first (:messages chat))] (let [last-message (first (:messages chat))]
[view st/chat-container [view st/chat-container
[view st/chat-icon-container [view st/chat-icon-container
@ -43,6 +44,6 @@
(when (:timestamp last-message) (when (:timestamp last-message)
[text {:style st/datetime-text} [text {:style st/datetime-text}
(time/to-short-str (:timestamp last-message))])]) (time/to-short-str (:timestamp last-message))])])
(when (pos? new-messages-count) (when (pos? unviewed-messages)
[view st/new-messages-container [view st/new-messages-container
[text {:style st/new-messages-text} new-messages-count]])]])) [text {:style st/new-messages-text} unviewed-messages]])]]))

View File

@ -3,7 +3,6 @@
[status-im.persistence.realm :as realm])) [status-im.persistence.realm :as realm]))
(defn unique-identity? [identity] (defn unique-identity? [identity]
(println identity)
(not (realm/exists? :contacts :whisper-identity identity))) (not (realm/exists? :contacts :whisper-identity identity)))
(defn valid-length? [identity] (defn valid-length? [identity]

View File

@ -11,7 +11,6 @@
[status-im.utils.handlers :refer [register-handler] :as u] [status-im.utils.handlers :refer [register-handler] :as u]
[status-im.models.protocol :as protocol] [status-im.models.protocol :as protocol]
status-im.chat.handlers status-im.chat.handlers
status-im.chat.handlers.animation
status-im.group-settings.handlers status-im.group-settings.handlers
status-im.navigation.handlers status-im.navigation.handlers
status-im.contacts.handlers status-im.contacts.handlers
@ -22,8 +21,7 @@
status-im.commands.handlers.jail status-im.commands.handlers.jail
status-im.qr-scanner.handlers status-im.qr-scanner.handlers
status-im.accounts.handlers status-im.accounts.handlers
status-im.protocol.handlers status-im.protocol.handlers))
status-im.chat.handlers.requests))
;; -- Middleware ------------------------------------------------------------ ;; -- Middleware ------------------------------------------------------------
;; ;;
@ -90,7 +88,9 @@
(u/side-effect! (u/side-effect!
(fn [db _] (fn [db _]
(log/debug "Starting node") (log/debug "Starting node")
(.startNode geth (fn [result] (node-started db result)))))) (.startNode geth
(fn [result] (node-started db result))
#(dispatch [:initialize-protocol])))))
(register-handler :crypt-initialized (register-handler :crypt-initialized
(u/side-effect! (u/side-effect!

View File

@ -26,7 +26,8 @@
(defn save-message (defn save-message
;; todo remove chat-id parameter ;; todo remove chat-id parameter
[chat-id {:keys [msg-id content] [chat-id {:keys [delivery-status msg-id content]
:or {delivery-status :pending}
:as message}] :as message}]
(when-not (r/exists? :msgs :msg-id msg-id) (when-not (r/exists? :msgs :msg-id msg-id)
(r/write (r/write
@ -38,8 +39,8 @@
message message
{:chat-id chat-id {:chat-id chat-id
:content content' :content content'
:timestamp (timestamp) :delivery-status delivery-status
:delivery-status nil})] :timestamp (timestamp)})]
(r/create :msgs message' true)))))) (r/create :msgs message' true))))))
(defn command-type? [type] (defn command-type? [type]

View File

@ -4,7 +4,7 @@
(:require [status-im.utils.handlers :as u] (:require [status-im.utils.handlers :as u]
[status-im.utils.logging :as log] [status-im.utils.logging :as log]
[status-im.protocol.api :as api] [status-im.protocol.api :as api]
[re-frame.core :refer [dispatch debug]] [re-frame.core :refer [dispatch after]]
[status-im.utils.handlers :refer [register-handler]] [status-im.utils.handlers :refer [register-handler]]
[status-im.models.contacts :as contacts] [status-im.models.contacts :as contacts]
[status-im.protocol.api :refer [init-protocol]] [status-im.protocol.api :refer [init-protocol]]
@ -18,8 +18,8 @@
(register-handler :initialize-protocol (register-handler :initialize-protocol
(u/side-effect! (u/side-effect!
(fn [db [_ account]] (fn [{:keys [user-identity] :as db} [_ account]]
(init-protocol account (make-handler db))))) (init-protocol (or account user-identity) (make-handler db)))))
(register-handler :protocol-initialized (register-handler :protocol-initialized
(fn [db [_ identity]] (fn [db [_ identity]]
@ -102,16 +102,28 @@
(log/debug action msg-id from group-id identity) (log/debug action msg-id from group-id identity)
(participant-invited-to-group-msg group-id identity from msg-id)))) (participant-invited-to-group-msg group-id identity from msg-id))))
(register-handler :acked-msg (defn update-message! [status]
(u/side-effect! (fn [_ [_ _ msg-id]]
(fn [_ [action from msg-id]]
(log/debug action from msg-id)
(messages/update-message! {:msg-id msg-id (messages/update-message! {:msg-id msg-id
:delivery-status :delivered})))) :delivery-status status})))
(defn update-message-status [status]
(fn [db [_ from msg-id]]
(let [current-status (get-in db [:message-status from msg-id])]
(if-not (= :seen current-status)
(assoc-in db [:message-status from msg-id] status)
db))))
(register-handler :acked-msg
(after (update-message! :delivered))
(update-message-status :delivered))
(register-handler :msg-delivery-failed (register-handler :msg-delivery-failed
(u/side-effect! (after (update-message! :failed))
(fn [_ [action msg-id]] (update-message-status :failed))
(log/debug action msg-id)
(messages/update-message! {:msg-id msg-id (register-handler :msg-seen
:delivery-status :failed})))) [(after (update-message! :seen))
(after (fn [_ [_ chat-id]]
(dispatch [:remove-unviewed-messages chat-id])))]
(update-message-status :seen))

View File

@ -22,8 +22,10 @@
(dispatch [:received-msg (assoc payload :from from :to to)])) (dispatch [:received-msg (assoc payload :from from :to to)]))
:msg-acked (let [{:keys [msg-id from]} event] :msg-acked (let [{:keys [msg-id from]} event]
(dispatch [:acked-msg from msg-id])) (dispatch [:acked-msg from msg-id]))
:delivery-failed (let [{:keys [msg-id]} event] :msg-seen (let [{:keys [msg-id from]} event]
(dispatch [:msg-delivery-failed msg-id])) (dispatch [:msg-seen from msg-id]))
:delivery-failed (let [{:keys [msg-id from]} event]
(dispatch [:msg-delivery-failed from msg-id]))
:new-group-chat (let [{:keys [from group-id identities group-name]} event] :new-group-chat (let [{:keys [from group-id identities group-name]} event]
(dispatch [:group-chat-invite-received from group-id identities group-name])) (dispatch [:group-chat-invite-received from group-id identities group-name]))
:new-group-msg (let [{from :from :new-group-msg (let [{from :from