aboutsummaryrefslogtreecommitdiffstats
path: root/plugins/mod_compression.lua
diff options
context:
space:
mode:
authorTobias Markmann <tm@ayena.de>2009-08-13 09:34:27 +0200
committerTobias Markmann <tm@ayena.de>2009-08-13 09:34:27 +0200
commit13bfc062ef7a8e49d82538a1c4803f0dd23bd464 (patch)
tree2257c7f0468dadeb9ea5340bf24c045a95ebda90 /plugins/mod_compression.lua
parent7e7a5ab0897aeab8eee3d09950f6238b5cbbf4f8 (diff)
downloadprosody-13bfc062ef7a8e49d82538a1c4803f0dd23bd464.tar.gz
prosody-13bfc062ef7a8e49d82538a1c4803f0dd23bd464.zip
Actually inject de- and compression into the reading/writing functions.
Diffstat (limited to 'plugins/mod_compression.lua')
-rw-r--r--plugins/mod_compression.lua34
1 files changed, 33 insertions, 1 deletions
diff --git a/plugins/mod_compression.lua b/plugins/mod_compression.lua
index d5df2578..bb2a7e5d 100644
--- a/plugins/mod_compression.lua
+++ b/plugins/mod_compression.lua
@@ -6,6 +6,7 @@
--
local st = require "util.stanza";
+local zlib = require "zlib";
local print = print
local xmlns_compression_feature = "http://jabber.org/features/compress"
@@ -15,7 +16,7 @@ local compression_stream_feature = st.stanza("compression", {xmlns=xmlns_compres
module:add_event_hook("stream-features",
function (session, features)
- features:add_child(compression_stream_feature);
+ if not session.compressed then features:add_child(compression_stream_feature); end
end
);
@@ -26,6 +27,37 @@ module:add_handler("c2s_unauthed", "compress", xmlns_compression_protocol,
if method == "zlib" then
session.log("info", method.." compression selected.");
session.send(st.stanza("compressed", {xmlns=xmlns_compression_protocol}));
+ session:reset_stream();
+
+ -- create deflate and inflate streams
+ local deflate_stream = zlib.deflate(9);
+ local inflate_stream = zlib.inflate();
+
+ -- setup compression for session.w
+ local old_send = session.send;
+
+ session.send = function(t)
+ local compressed, eof = deflate_stream(tostring(t), 'sync');
+ old_send(compressed);
+ end;
+
+ -- setup decompression for session.data
+ local function setup_decompression(session)
+ local old_data = session.data
+ session.data = function(conn, data)
+ local decompressed, eof = inflate_stream(data);
+ old_data(conn, decompressed);
+ end;
+ end
+ setup_decompression(session);
+
+ local session_reset_stream = session.reset_stream;
+ session.reset_stream = function(session)
+ session_reset_stream(session);
+ setup_decompression(session);
+ return true;
+ end;
+ session.compressed = true;
else
session.log("info", method.." compression selected. But we don't support it.");
local error_st = st.stanza("failure", {xmlns=xmlns_compression_protocol}):tag("unsupported-method");