summaryrefslogtreecommitdiff
path: root/modules
diff options
context:
space:
mode:
Diffstat (limited to 'modules')
-rw-r--r--modules/mod_csi_on_away.lua29
-rw-r--r--modules/mod_message_fake_id.lua21
2 files changed, 50 insertions, 0 deletions
diff --git a/modules/mod_csi_on_away.lua b/modules/mod_csi_on_away.lua
new file mode 100644
index 0000000..90a76a0
--- /dev/null
+++ b/modules/mod_csi_on_away.lua
@@ -0,0 +1,29 @@
+local st = require "util.stanza";
+
+
+-- Make sure we only load this module when CSI itself is deployed
+module:depends("csi");
+
+
+local function on_presence(event)
+ if not event.origin.username then
+ return nil;
+ end
+
+ local child = event.stanza:get_child("show");
+
+ if child and child:get_text() == "away" then
+ module:log("debug", "User is now away, simulating CSI.");
+ module:fire_event("csi-client-inactive", event);
+ else
+ module:log("debug", "User is no longer away, ending simulated CSI.");
+ module:fire_event("csi-client-active", event);
+ end
+end
+
+
+-- outgoing
+module:hook("pre-presence/bare", on_presence);
+module:hook("pre-presence/full", on_presence);
+module:hook("pre-presence/host", on_presence);
+
diff --git a/modules/mod_message_fake_id.lua b/modules/mod_message_fake_id.lua
new file mode 100644
index 0000000..ed6e2b4
--- /dev/null
+++ b/modules/mod_message_fake_id.lua
@@ -0,0 +1,21 @@
+local st = require "util.stanza";
+local uuid_generate = require "util.uuid".generate;
+
+
+local function on_message(event)
+ if not event.origin.username then
+ return nil;
+ end
+
+ if not event.stanza.attr.id then
+ module:log("debug", "Faking message ID.");
+ event.stanza.attr.id = uuid_generate();
+ end
+end
+
+
+-- outgoing
+module:hook("pre-message/bare", on_message, 5432);
+module:hook("pre-message/full", on_message, 5432);
+module:hook("pre-message/host", on_message, 5432);
+