aboutsummaryrefslogtreecommitdiff
path: root/xmpp-vala/src/module/roster/module.vala
diff options
context:
space:
mode:
authorfiaxh <git@mx.ax.lt>2017-05-21 23:30:30 +0200
committerfiaxh <git@mx.ax.lt>2017-05-22 01:02:09 +0200
commitbcb96909c9b53c2ca5287433f2fef103b0ddf317 (patch)
tree2cf49f939f4ad8818444802080580043c233c40c /xmpp-vala/src/module/roster/module.vala
parent4247922e8cc85b488997ebef2121e6f3055e1e26 (diff)
downloaddino-bcb96909c9b53c2ca5287433f2fef103b0ddf317.tar.gz
dino-bcb96909c9b53c2ca5287433f2fef103b0ddf317.zip
Roster versioning
Diffstat (limited to 'xmpp-vala/src/module/roster/module.vala')
-rw-r--r--xmpp-vala/src/module/roster/module.vala173
1 files changed, 87 insertions, 86 deletions
diff --git a/xmpp-vala/src/module/roster/module.vala b/xmpp-vala/src/module/roster/module.vala
index 1ebb7f22..e0d8aeb3 100644
--- a/xmpp-vala/src/module/roster/module.vala
+++ b/xmpp-vala/src/module/roster/module.vala
@@ -3,117 +3,118 @@ using Gee;
using Xmpp.Core;
namespace Xmpp.Roster {
- private const string NS_URI = "jabber:iq:roster";
- public class Module : XmppStreamModule, Iq.Handler {
- public static ModuleIdentity<Module> IDENTITY = new ModuleIdentity<Module>(NS_URI, "roster_module");
+private const string NS_URI = "jabber:iq:roster";
- public signal void received_roster(XmppStream stream, Collection<Item> roster);
- public signal void item_removed(XmppStream stream, Item roster_item);
- public signal void item_updated(XmppStream stream, Item roster_item);
+public class Module : XmppStreamModule, Iq.Handler {
+ public static ModuleIdentity<Module> IDENTITY = new ModuleIdentity<Module>(NS_URI, "roster_module");
- public bool interested_resource = true;
+ public signal void received_roster(XmppStream stream, Collection<Item> roster, Iq.Stanza stanza);
+ public signal void pre_get_roster(XmppStream stream, Iq.Stanza iq);
+ public signal void item_removed(XmppStream stream, Item item, Iq.Stanza iq);
+ public signal void item_updated(XmppStream stream, Item item, Iq.Stanza iq);
- /**
- * Add a jid to the roster
- */
- public void add_jid(XmppStream stream, string jid, string? handle = null) {
- Item roster_item = new Item();
- roster_item.jid = jid;
- if (handle != null) {
- roster_item.name = handle;
- }
- roster_set(stream, roster_item);
+ public bool interested_resource = true;
+
+ public void add_jid(XmppStream stream, string jid, string? handle = null) {
+ Item roster_item = new Item();
+ roster_item.jid = jid;
+ if (handle != null) {
+ roster_item.name = handle;
}
+ roster_set(stream, roster_item);
+ }
- /**
- * Remove a jid from the roster
- */
- public void remove_jid(XmppStream stream, string jid) {
- Item roster_item = new Item();
- roster_item.jid = jid;
- roster_item.subscription = Item.SUBSCRIPTION_REMOVE;
+ public void remove_jid(XmppStream stream, string jid) {
+ Item roster_item = new Item();
+ roster_item.jid = jid;
+ roster_item.subscription = Item.SUBSCRIPTION_REMOVE;
- roster_set(stream, roster_item);
+ roster_set(stream, roster_item);
+ }
+
+ /**
+ * Set a handle for a jid
+ * @param handle Handle to be set. If null, any handle will be removed.
+ */
+ public void set_jid_handle(XmppStream stream, string jid, string? handle) {
+ Item roster_item = new Item();
+ roster_item.jid = jid;
+ if (handle != null) {
+ roster_item.name = handle;
}
- /**
- * Set a handle for a jid
- * @param handle Handle to be set. If null, any handle will be removed.
- */
- public void set_jid_handle(XmppStream stream, string jid, string? handle) {
- Item roster_item = new Item();
- roster_item.jid = jid;
- if (handle != null) {
- roster_item.name = handle;
- }
+ roster_set(stream, roster_item);
+ }
- roster_set(stream, roster_item);
+ public void on_iq_set(XmppStream stream, Iq.Stanza iq) {
+ StanzaNode? query_node = iq.stanza.get_subnode("query", NS_URI);
+ if (query_node == null) return;
+
+ Flag flag = stream.get_flag(Flag.IDENTITY);
+ Item item = new Item.from_stanza_node(query_node.get_subnode("item", NS_URI));
+ switch (item.subscription) {
+ case Item.SUBSCRIPTION_REMOVE:
+ flag.roster_items.unset(item.jid);
+ item_removed(stream, item, iq);
+ break;
+ default:
+ flag.roster_items[item.jid] = item;
+ item_updated(stream, item, iq);
+ break;
}
+ }
- public void on_iq_set(XmppStream stream, Iq.Stanza iq) {
- StanzaNode? query_node = iq.stanza.get_subnode("query", NS_URI);
- if (query_node == null) return;
-
- Flag flag = stream.get_flag(Flag.IDENTITY);
- Item item = new Item.from_stanza_node(query_node.get_subnode("item", NS_URI));
- switch (item.subscription) {
- case Item.SUBSCRIPTION_REMOVE:
- flag.roster_items.unset(item.jid);
- item_removed(stream, item);
- break;
- default:
- flag.roster_items[item.jid] = item;
- item_updated(stream, item);
- break;
- }
- }
+ public void on_iq_get(XmppStream stream, Iq.Stanza iq) { }
- public void on_iq_get(XmppStream stream, Iq.Stanza iq) { }
+ public static void require(XmppStream stream) {
+ if (stream.get_module(IDENTITY) == null) stream.add_module(new Module());
+ }
- public static void require(XmppStream stream) {
- if (stream.get_module(IDENTITY) == null) stream.add_module(new Module());
- }
+ public override void attach(XmppStream stream) {
+ Iq.Module.require(stream);
+ stream.get_module(Iq.Module.IDENTITY).register_for_namespace(NS_URI, this);
+ Presence.Module.require(stream);
+ stream.get_module(Presence.Module.IDENTITY).initial_presence_sent.connect(roster_get);
+ stream.add_flag(new Flag());
+ }
- public override void attach(XmppStream stream) {
- Iq.Module.require(stream);
- stream.get_module(Iq.Module.IDENTITY).register_for_namespace(NS_URI, this);
- Presence.Module.require(stream);
- stream.get_module(Presence.Module.IDENTITY).initial_presence_sent.connect(roster_get);
- stream.add_flag(new Flag());
- }
+ public override void detach(XmppStream stream) {
+ stream.get_module(Presence.Module.IDENTITY).initial_presence_sent.disconnect(roster_get);
+ }
- public override void detach(XmppStream stream) {
- stream.get_module(Presence.Module.IDENTITY).initial_presence_sent.disconnect(roster_get);
- }
+ internal override string get_ns() { return NS_URI; }
+ internal override string get_id() { return IDENTITY.id; }
- internal override string get_ns() { return NS_URI; }
- internal override string get_id() { return IDENTITY.id; }
+ private void roster_get(XmppStream stream) {
+ stream.get_flag(Flag.IDENTITY).iq_id = random_uuid();
+ StanzaNode query_node = new StanzaNode.build("query", NS_URI).add_self_xmlns();
+ Iq.Stanza iq = new Iq.Stanza.get(query_node, stream.get_flag(Flag.IDENTITY).iq_id);
- private void roster_get(XmppStream stream) {
- stream.get_flag(Flag.IDENTITY).iq_id = random_uuid();
- StanzaNode query_node = new StanzaNode.build("query", NS_URI).add_self_xmlns();
- Iq.Stanza iq = new Iq.Stanza.get(query_node, stream.get_flag(Flag.IDENTITY).iq_id);
- stream.get_module(Iq.Module.IDENTITY).send_iq(stream, iq, on_roster_get_received);
- }
+ pre_get_roster(stream, iq);
+ stream.get_module(Iq.Module.IDENTITY).send_iq(stream, iq, on_roster_get_received);
+ }
- private static void on_roster_get_received(XmppStream stream, Iq.Stanza iq) {
- Flag flag = stream.get_flag(Flag.IDENTITY);
- if (iq.id == flag.iq_id) {
- StanzaNode? query_node = iq.stanza.get_subnode("query", NS_URI);
+ private static void on_roster_get_received(XmppStream stream, Iq.Stanza iq) {
+ Flag flag = stream.get_flag(Flag.IDENTITY);
+ if (iq.id == flag.iq_id) {
+ StanzaNode? query_node = iq.stanza.get_subnode("query", NS_URI);
+ if (query_node != null) {
foreach (StanzaNode item_node in query_node.sub_nodes) {
Item item = new Item.from_stanza_node(item_node);
flag.roster_items[item.jid] = item;
}
- stream.get_module(Module.IDENTITY).received_roster(stream, flag.roster_items.values);
}
+ stream.get_module(Module.IDENTITY).received_roster(stream, flag.roster_items.values, iq);
}
+ }
- private void roster_set(XmppStream stream, Item roster_item) {
- StanzaNode query_node = new StanzaNode.build("query", NS_URI).add_self_xmlns()
- .put_node(roster_item.stanza_node);
- Iq.Stanza iq = new Iq.Stanza.set(query_node);
- stream.get_module(Iq.Module.IDENTITY).send_iq(stream, iq);
- }
+ private void roster_set(XmppStream stream, Item roster_item) {
+ StanzaNode query_node = new StanzaNode.build("query", NS_URI).add_self_xmlns()
+ .put_node(roster_item.stanza_node);
+ Iq.Stanza iq = new Iq.Stanza.set(query_node);
+ stream.get_module(Iq.Module.IDENTITY).send_iq(stream, iq);
}
}
+
+}