aboutsummaryrefslogtreecommitdiff
path: root/xmpp-vala/src/module/xep/0048_bookmarks/module.vala
diff options
context:
space:
mode:
authorfiaxh <git@lightrise.org>2019-09-28 21:40:43 +0200
committerfiaxh <git@lightrise.org>2019-09-29 01:53:59 +0200
commit74c29d4df19f97b9b67bbc3c1a963a8729be69fd (patch)
treeaf3624c4b34a21274758b830c3df404244113829 /xmpp-vala/src/module/xep/0048_bookmarks/module.vala
parent1287135ebbe8420de44ab73ce6a553b17067dfdb (diff)
downloaddino-74c29d4df19f97b9b67bbc3c1a963a8729be69fd.tar.gz
dino-74c29d4df19f97b9b67bbc3c1a963a8729be69fd.zip
Add Bookmarks2 implementation, introduce bookmarks interfaces
Diffstat (limited to 'xmpp-vala/src/module/xep/0048_bookmarks/module.vala')
-rw-r--r--xmpp-vala/src/module/xep/0048_bookmarks/module.vala89
1 files changed, 0 insertions, 89 deletions
diff --git a/xmpp-vala/src/module/xep/0048_bookmarks/module.vala b/xmpp-vala/src/module/xep/0048_bookmarks/module.vala
deleted file mode 100644
index 2c16f5f0..00000000
--- a/xmpp-vala/src/module/xep/0048_bookmarks/module.vala
+++ /dev/null
@@ -1,89 +0,0 @@
-using Gee;
-
-namespace Xmpp.Xep.Bookmarks {
-private const string NS_URI = "storage:bookmarks";
-
-public class Module : XmppStreamModule {
- public static ModuleIdentity<Module> IDENTITY = new ModuleIdentity<Module>(NS_URI, "0048_bookmarks_module");
-
- public signal void received_conferences(XmppStream stream, Gee.List<Conference> conferences);
-
- public delegate void OnResult(XmppStream stream, Gee.List<Conference>? conferences);
- public void get_conferences(XmppStream stream, owned OnResult listener) {
- StanzaNode get_node = new StanzaNode.build("storage", NS_URI).add_self_xmlns();
- stream.get_module(PrivateXmlStorage.Module.IDENTITY).retrieve(stream, get_node, (stream, node) => {
- if (node == null) {
- listener(stream, null);
- } else {
- Gee.List<Conference> conferences = get_conferences_from_stanza(node);
- listener(stream, conferences);
- }
- });
- }
-
- public void set_conferences(XmppStream stream, Gee.List<Conference> conferences) {
- StanzaNode storage_node = (new StanzaNode.build("storage", NS_URI)).add_self_xmlns();
- foreach (Conference conference in conferences) {
- storage_node.put_node(conference.stanza_node);
- }
- stream.get_module(PrivateXmlStorage.Module.IDENTITY).store(stream, storage_node, (stream) => {
- stream.get_module(Module.IDENTITY).received_conferences(stream, conferences);
- });
- }
-
- public void add_conference(XmppStream stream, Conference conference) {
- get_conferences(stream, (stream, conferences) => {
- conferences.add(conference);
- stream.get_module(Module.IDENTITY).set_conferences(stream, conferences);
- });
- }
-
- public void replace_conference(XmppStream stream, Conference orig_conference, Conference modified_conference) {
- get_conferences(stream, (stream, conferences) => {
- foreach (Conference conference in conferences) {
- if (conference.autojoin == orig_conference.autojoin && conference.jid.equals(orig_conference.jid) &&
- conference.name == orig_conference.name && conference.nick == orig_conference.nick) {
- conference.autojoin = modified_conference.autojoin;
- conference.jid = modified_conference.jid;
- conference.name = modified_conference.name;
- conference.nick = modified_conference.nick;
- break;
- }
- }
- stream.get_module(Module.IDENTITY).set_conferences(stream, conferences);
- });
- }
-
- public void remove_conference(XmppStream stream, Conference conference_remove) {
- get_conferences(stream, (stream, conferences) => {
- Conference? rem = null;
- foreach (Conference conference in conferences) {
- if (conference.name == conference_remove.name && conference.jid.equals(conference_remove.jid) && conference.autojoin == conference_remove.autojoin) {
- rem = conference;
- break;
- }
- }
- if (rem != null) conferences.remove(rem);
- stream.get_module(Module.IDENTITY).set_conferences(stream, conferences);
- });
- }
-
- public override void attach(XmppStream stream) { }
-
- public override void detach(XmppStream stream) { }
-
- public override string get_ns() { return NS_URI; }
- public override string get_id() { return IDENTITY.id; }
-
- private static Gee.List<Conference> get_conferences_from_stanza(StanzaNode node) {
- Gee.List<Conference> conferences = new ArrayList<Conference>();
- Gee.List<StanzaNode> conferenceNodes = node.get_subnode("storage", NS_URI).get_subnodes("conference", NS_URI);
- foreach (StanzaNode conferenceNode in conferenceNodes) {
- Conference? conference = Conference.create_from_stanza_node(conferenceNode);
- conferences.add(conference);
- }
- return conferences;
- }
-}
-
-}