You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
76 lines
2.5 KiB
76 lines
2.5 KiB
{-# LANGUAGE RecordWildCards #-} |
|
|
|
{-# OPTIONS_HADDOCK hide #-} |
|
|
|
-- | Stanza related functions and constants |
|
-- |
|
|
|
module Network.Xmpp.Stanza where |
|
|
|
import Data.XML.Types |
|
import Network.Xmpp.Types |
|
|
|
|
|
-- | An empty message |
|
message :: Message |
|
message = Message { messageID = Nothing |
|
, messageFrom = Nothing |
|
, messageTo = Nothing |
|
, messageLangTag = Nothing |
|
, messageType = Normal |
|
, messagePayload = [] |
|
} |
|
|
|
-- | An empty presence. |
|
presence :: Presence |
|
presence = Presence { presenceID = Nothing |
|
, presenceFrom = Nothing |
|
, presenceTo = Nothing |
|
, presenceLangTag = Nothing |
|
, presenceType = Nothing |
|
, presencePayload = [] |
|
} |
|
|
|
-- | Request subscription with an entity. |
|
presenceSubscribe :: Jid -> Presence |
|
presenceSubscribe to = presence { presenceTo = Just to |
|
, presenceType = Just Subscribe |
|
} |
|
|
|
-- | Approve a subscripton of an entity. |
|
presenceSubscribed :: Jid -> Presence |
|
presenceSubscribed to = presence { presenceTo = Just to |
|
, presenceType = Just Subscribed |
|
} |
|
|
|
-- | End a subscription with an entity. |
|
presenceUnsubscribe :: Jid -> Presence |
|
presenceUnsubscribe to = presence { presenceTo = Just to |
|
, presenceType = Just Unsubscribed |
|
} |
|
|
|
-- | Signal to the server that the client is available for communication. |
|
presenceOnline :: Presence |
|
presenceOnline = presence |
|
|
|
-- | Signal to the server that the client is no longer available for |
|
-- communication. |
|
presenceOffline :: Presence |
|
presenceOffline = presence {presenceType = Just Unavailable} |
|
|
|
-- | Produce an answer message with the given payload, switching the "from" and |
|
-- "to" attributes in the original message. Produces a 'Nothing' value of the |
|
-- provided message message has no from attribute. |
|
answerMessage :: Message -> [Element] -> Maybe Message |
|
answerMessage Message{messageFrom = Just frm, ..} payload = |
|
Just Message{ messageFrom = messageTo |
|
, messageID = Nothing |
|
, messageTo = Just frm |
|
, messagePayload = payload |
|
, .. |
|
} |
|
answerMessage _ _ = Nothing |
|
|
|
-- | Add a recipient to a presence notification. |
|
presTo :: Presence -> Jid -> Presence |
|
presTo pres to = pres{presenceTo = Just to}
|
|
|