summaryrefslogtreecommitdiff
path: root/Assistant/Threads/XMPPClient.hs
diff options
context:
space:
mode:
Diffstat (limited to 'Assistant/Threads/XMPPClient.hs')
-rw-r--r--Assistant/Threads/XMPPClient.hs60
1 files changed, 39 insertions, 21 deletions
diff --git a/Assistant/Threads/XMPPClient.hs b/Assistant/Threads/XMPPClient.hs
index 7da2bccc6..1117c3c14 100644
--- a/Assistant/Threads/XMPPClient.hs
+++ b/Assistant/Threads/XMPPClient.hs
@@ -52,7 +52,7 @@ xmppClient urlrenderer d = do
Just c -> retry (runclient c) =<< getCurrentTime
where
liftAssistant = runAssistant d
- xAssistant = liftIO . liftAssistant
+ inAssistant = liftIO . liftAssistant
{- When the client exits, it's restarted;
- if it keeps failing, back off to wait 5 minutes before
@@ -73,30 +73,35 @@ xmppClient urlrenderer d = do
selfjid <- bindJID jid
putStanza gitAnnexSignature
- xAssistant $ debug ["connected", show selfjid]
+ inAssistant $ debug ["connected", show selfjid]
{- The buddy list starts empty each time
- the client connects, so that stale info
- is not retained. -}
- void $ xAssistant $
+ void $ inAssistant $
updateBuddyList (const noBuddies) <<~ buddyList
xmppThread $ receivenotifications selfjid
forever $ do
- a <- xAssistant $ relayNetMessage selfjid
+ a <- inAssistant $ relayNetMessage selfjid
a
receivenotifications selfjid = forever $ do
l <- decodeStanza selfjid <$> getStanza
- xAssistant $ debug ["received:", show l]
+ inAssistant $ debug ["received:", show l]
mapM_ (handle selfjid) l
- handle _ (PresenceMessage p) = void $ xAssistant $
+ handle _ (PresenceMessage p) = void $ inAssistant $
updateBuddyList (updateBuddies p) <<~ buddyList
handle _ (GotNetMessage QueryPresence) = putStanza gitAnnexSignature
- handle _ (GotNetMessage (NotifyPush us)) = void $ xAssistant $
+ handle _ (GotNetMessage (NotifyPush us)) = void $ inAssistant $
pull us
- handle selfjid (GotNetMessage (PairingNotification stage t u)) =
- maybe noop (xAssistant . pairMsgReceived urlrenderer stage u selfjid) (parseJID t)
+ handle selfjid (GotNetMessage (PairingNotification stage c u)) =
+ maybe noop (inAssistant . pairMsgReceived urlrenderer stage u selfjid) (parseJID c)
+ handle selfjid (GotNetMessage (PushRequest c)) = error "TODO"
+ handle selfjid (GotNetMessage (StartingPush c)) = error "TODO"
+ handle selfjid (GotNetMessage (ReceivePackOutput c b)) = error "TODO"
+ handle selfjid (GotNetMessage (SendPackOutput c b)) = error "TODO"
+ handle selfjid (GotNetMessage (ReceivePackDone c code)) = error "TODO"
handle _ (Ignorable _) = noop
handle _ (Unknown _) = noop
handle _ (ProtocolError _) = noop
@@ -117,7 +122,7 @@ decodeStanza selfjid s@(ReceivedPresence p)
| presenceFrom p == Just selfjid = [Ignorable s]
| otherwise = maybe [PresenceMessage p] decode (getGitAnnexAttrValue p)
where
- decode (attr, v)
+ decode (attr, v, _tag)
| attr == pushAttr = impliedp $ GotNetMessage $ NotifyPush $
decodePushNotification v
| attr == queryAttr = impliedp $ GotNetMessage QueryPresence
@@ -131,10 +136,15 @@ decodeStanza selfjid s@(ReceivedMessage m)
| messageType m == MessageError = [ProtocolError s]
| otherwise = maybe [Unknown s] decode (getGitAnnexAttrValue m)
where
- decode (attr, v)
- | attr == pairAttr =
- [maybe (Unknown s) GotNetMessage (decodePairingNotification v m)]
+ decode (attr, v, tag)
+ | attr == pairAttr = use $ decodePairingNotification v
+ | attr == pushRequestAttr = use decodePushRequest
+ | attr == startingPushAttr = use decodeStartingPush
+ | attr == receivePackAttr = use $ decodeReceivePackOutput tag
+ | attr == sendPackAttr = use $ decodeSendPackOutput tag
+ | attr == receivePackDoneAttr = use $ decodeReceivePackDone v
| otherwise = [Unknown s]
+ use v = [maybe (Unknown s) GotNetMessage (v m)]
decodeStanza _ s = [Unknown s]
{- Waits for a NetMessager message to be sent, and relays it to XMPP. -}
@@ -142,15 +152,23 @@ relayNetMessage :: JID -> Assistant (XMPP ())
relayNetMessage selfjid = convert =<< waitNetMessage
where
convert (NotifyPush us) = return $ putStanza $ pushNotification us
- convert QueryPresence = return $ putStanza $ presenceQuery
- convert (PairingNotification stage t u) = case parseJID t of
- Nothing -> return $ noop
+ convert QueryPresence = return $ putStanza presenceQuery
+ convert (PairingNotification stage c u) = withclient c $ \tojid -> do
+ changeBuddyPairing tojid True
+ return $ putStanza $ pairingNotification stage u tojid selfjid
+ convert (PushRequest c) = sendclient c pushRequest
+ convert (StartingPush c) = sendclient c startingPush
+ convert (ReceivePackOutput c b) = sendclient c $ receivePackOutput b
+ convert (SendPackOutput c b) = sendclient c $ sendPackOutput b
+ convert (ReceivePackDone c code) = sendclient c $ receivePackDone code
+
+ sendclient c construct = withclient c $ \tojid ->
+ return $ putStanza $ construct tojid selfjid
+ withclient c a = case parseJID c of
+ Nothing -> return noop
Just tojid
- | tojid == selfjid -> return $ noop
- | otherwise -> do
- changeBuddyPairing tojid True
- return $ putStanza $
- pairingNotification stage u tojid selfjid
+ | tojid == selfjid -> return noop
+ | otherwise -> a tojid
{- Runs a XMPP action in a separate thread, using a session to allow it
- to access the same XMPP client. -}