module Network.Protocol.XMPP.Client.Features
( Feature (..)
, parseFeatures
, parseFeature
) where
import Control.Arrow ((&&&))
import qualified Data.ByteString.Char8 as B
import qualified Data.Text.Lazy as TL
import qualified Network.Protocol.XMPP.XML as X
data Feature =
FeatureStartTLS Bool
| FeatureSASL [B.ByteString]
| FeatureRegister
| FeatureBind
| FeatureSession
| FeatureUnknown X.Element
deriving (Show, Eq)
parseFeatures :: X.Element -> [Feature]
parseFeatures e =
X.isNamed nameFeatures e
>>= X.elementChildren
>>= return . parseFeature
parseFeature :: X.Element -> Feature
parseFeature elemt = feature where
unpackName = (maybe "" id . X.nameNamespace) &&& X.nameLocalName
feature = case unpackName (X.elementName elemt) of
("urn:ietf:params:xml:ns:xmpp-tls", "starttls") -> parseFeatureTLS elemt
("urn:ietf:params:xml:ns:xmpp-sasl", "mechanisms") -> parseFeatureSASL elemt
("http://jabber.org/features/iq-register", "register") -> FeatureRegister
("urn:ietf:params:xml:ns:xmpp-bind", "bind") -> FeatureBind
("urn:ietf:params:xml:ns:xmpp-session", "session") -> FeatureSession
_ -> FeatureUnknown elemt
parseFeatureTLS :: X.Element -> Feature
parseFeatureTLS _ = FeatureStartTLS True
parseFeatureSASL :: X.Element -> Feature
parseFeatureSASL e = FeatureSASL $
X.elementChildren e
>>= X.isNamed nameMechanism
>>= X.elementNodes
>>= X.isContent
>>= return . B.pack . TL.unpack . X.contentText
nameMechanism :: X.Name
nameMechanism = X.Name "mechanism" (Just "urn:ietf:params:xml:ns:xmpp-sasl") Nothing
nameFeatures :: X.Name
nameFeatures = X.Name "features" (Just "http://etherx.jabber.org/streams") Nothing