util.ip: Fix protocol detection of IPv6 addresses beginning with : [Backported from...
[prosody.git] / util / filters.lua
index f6a3e77ae36c1bfb6c94c0fd2fbead13908026ab..6290e53b1744bf82c7c24a0cdeb6b759aaf12a3c 100644 (file)
@@ -10,20 +10,30 @@ local t_insert, t_remove = table.insert, table.remove;
 
 module "filters"
 
+local new_filter_hooks = {};
+
 function initialize(session)
-       local filters = {};
-       session.filters = filters;
-       
-       function session.filter(type, data)
-               local filter_list = filters[type];
-               if filter_list then
-                       for i = 1, #filter_list do
-                               data = filter_list[i](data);
-                               if data == nil then break; end
+       if not session.filters then
+               local filters = {};
+               session.filters = filters;
+               
+               function session.filter(type, data)
+                       local filter_list = filters[type];
+                       if filter_list then
+                               for i = 1, #filter_list do
+                                       data = filter_list[i](data, session);
+                                       if data == nil then break; end
+                               end
                        end
+                       return data;
                end
-               return data;
        end
+       
+       for i=1,#new_filter_hooks do
+               new_filter_hooks[i](session);
+       end
+       
+       return session.filter;
 end
 
 function add_filter(session, type, callback, priority)
@@ -35,6 +45,8 @@ function add_filter(session, type, callback, priority)
        if not filter_list then
                filter_list = {};
                session.filters[type] = filter_list;
+       elseif filter_list[callback] then
+               return; -- Filter already added
        end
        
        priority = priority or 0;
@@ -42,7 +54,7 @@ function add_filter(session, type, callback, priority)
        local i = 0;
        repeat
                i = i + 1;
-       until not filter_list[i] or filter_list[filter_list[i]] >= priority;
+       until not filter_list[i] or filter_list[filter_list[i]] < priority;
        
        t_insert(filter_list, i, callback);
        filter_list[callback] = priority;
@@ -62,4 +74,16 @@ function remove_filter(session, type, callback)
        end
 end
 
-return _M;
\ No newline at end of file
+function add_filter_hook(callback)
+       t_insert(new_filter_hooks, callback);
+end
+
+function remove_filter_hook(callback)
+       for i=1,#new_filter_hooks do
+               if new_filter_hooks[i] == callback then
+                       t_remove(new_filter_hooks, i);
+               end
+       end
+end
+
+return _M;