Mercurial > prosody-modules
comparison mod_server_status/mod_server_status.lua @ 609:edb4afb6a227
mod_server_status: remove cleanup function move it to a separate plugin.
author | Marco Cirillo <maranda@lightwitch.org> |
---|---|
date | Sun, 12 Feb 2012 18:01:48 +0000 |
parents | 00590d492a5b |
children | dfd7f1ed7782 |
comparison
equal
deleted
inserted
replaced
608:fb9a2ab8458a | 609:edb4afb6a227 |
---|---|
128 end | 128 end |
129 | 129 |
130 -- initialization. | 130 -- initialization. |
131 -- init http interface | 131 -- init http interface |
132 | 132 |
133 function stats_cleanup() -- handy, recycled from mod_register_json | |
134 module:log("debug", "Cleaning up handlers and stuff as module is being unloaded.") | |
135 for _, options in ipairs(ports) do | |
136 if options.port then | |
137 httpserver.new.http_servers[options.port].handlers[options.path or "server-status"] = nil | |
138 end | |
139 end | |
140 | |
141 local event = require "core.configmanager".get("*", "core", "use_libevent") | |
142 | |
143 -- if there're no handlers left clean the socket, not sure if it works with server_select | |
144 if not event then | |
145 for _, options in ipairs(ports) do | |
146 if options.port and not next(httpserver.new.http_servers[options.port].handlers) then | |
147 httpserver.new.http_servers[options.port] = nil | |
148 if options.interface then | |
149 for _, value in ipairs(options.interface) do | |
150 if server.getserver(value, options.port) then server.removeserver(value, options.port) end | |
151 end | |
152 else if server.getserver("*", options.port) then server.removeserver("*", options.port) end end | |
153 end | |
154 end | |
155 end | |
156 | |
157 prosody.events.remove_handler("module-unloaded", stats_cleanup) | |
158 end | |
159 | |
160 local function setup() | 133 local function setup() |
161 httpserver.new_from_config(ports, request, { base = "server-status" }) | 134 httpserver.new_from_config(ports, request, { base = "server-status" }) |
162 prosody.events.add_handler("module-unloaded", stats_cleanup) | |
163 end | 135 end |
164 | 136 |
165 if prosody.start_time then | 137 if prosody.start_time then |
166 setup() | 138 setup() |
167 else | 139 else |