diff options
author | fiaxh <git@mx.ax.lt> | 2017-03-10 17:01:45 +0100 |
---|---|---|
committer | fiaxh <git@mx.ax.lt> | 2017-03-10 17:11:25 +0100 |
commit | 2fe8489d368a371aefbfbe66e74621a8df14cdc2 (patch) | |
tree | 4dec90236b28101383753ffe4a1c7a34b09b0208 /vala-xmpp/src/module/xep/0030_service_discovery/info_result.vala | |
parent | 7a1aa8c806a63cfd031c082524501e26d4a181ee (diff) | |
download | dino-2fe8489d368a371aefbfbe66e74621a8df14cdc2.tar.gz dino-2fe8489d368a371aefbfbe66e74621a8df14cdc2.zip |
Rename vala-xmpp library to xmpp-vala
Diffstat (limited to 'vala-xmpp/src/module/xep/0030_service_discovery/info_result.vala')
-rw-r--r-- | vala-xmpp/src/module/xep/0030_service_discovery/info_result.vala | 78 |
1 files changed, 0 insertions, 78 deletions
diff --git a/vala-xmpp/src/module/xep/0030_service_discovery/info_result.vala b/vala-xmpp/src/module/xep/0030_service_discovery/info_result.vala deleted file mode 100644 index 7e0f0ea4..00000000 --- a/vala-xmpp/src/module/xep/0030_service_discovery/info_result.vala +++ /dev/null @@ -1,78 +0,0 @@ -using Gee; - -using Xmpp.Core; - -namespace Xmpp.Xep.ServiceDiscovery { - -public class InfoResult { - public Iq.Stanza iq { get; private set; } - - public ArrayList<string> features { - owned get { - ArrayList<string> ret = new ArrayList<string>(); - foreach (StanzaNode feature_node in iq.stanza.get_subnode("query", NS_URI_INFO).get_subnodes("feature", NS_URI_INFO)) { - ret.add(feature_node.get_attribute("var", NS_URI_INFO)); - } - return ret; - } - set { - foreach (string feature in value) { - add_feature(feature); - } - } - } - - public ArrayList<Identity> identities { - owned get { - ArrayList<Identity> ret = new ArrayList<Identity>(); - foreach (StanzaNode feature_node in iq.stanza.get_subnode("query", NS_URI_INFO).get_subnodes("identity", NS_URI_INFO)) { - ret.add(new Identity(feature_node.get_attribute("category", NS_URI_INFO), - feature_node.get_attribute("type", NS_URI_INFO), - feature_node.get_attribute("name", NS_URI_INFO))); - } - return ret; - } - set { - foreach (Identity identity in value) { - add_identity(identity); - } - } - } - - public void add_feature(string feature) { - iq.stanza.get_subnode("query", NS_URI_INFO).put_node(new StanzaNode.build("feature", NS_URI_INFO).put_attribute("var", feature)); - } - - public void add_identity(Identity identity) { - StanzaNode identity_node = new StanzaNode.build("identity", NS_URI_INFO) - .put_attribute("category", identity.category) - .put_attribute("type", identity.type_); - if (identity.name != null) { - identity_node.put_attribute("name", identity.name); - } - iq.stanza.get_subnode("query", NS_URI_INFO).put_node(identity_node); - } - - private InfoResult.from_iq(Iq.Stanza iq) { - this.iq = iq; - } - - public InfoResult(Iq.Stanza iq_request) { - iq = new Iq.Stanza.result(iq_request); - iq.to = iq_request.from; - iq.stanza.put_node(new StanzaNode.build("query", NS_URI_INFO).add_self_xmlns()); - } - - public static InfoResult? create_from_iq(Iq.Stanza iq) { - if (iq.is_error()) return null; - StanzaNode query_node = iq.stanza.get_subnode("query", NS_URI_INFO); - if (query_node == null) return null; - StanzaNode feature_node = query_node.get_subnode("feature", NS_URI_INFO); - if (feature_node == null) return null; - StanzaNode identity_node = query_node.get_subnode("identity", NS_URI_INFO); - if (identity_node == null) return null; - return new ServiceDiscovery.InfoResult.from_iq(iq); - } -} - -}
\ No newline at end of file |