2 local connlisteners_register = require "net.connlisteners".register;
\r
4 local console_listener = { default_port = 5582; default_mode = "*l"; };
\r
8 local default_env_mt = { __index = def_env };
\r
12 function console:new_session(conn)
\r
13 local w = conn.write;
\r
14 local session = { conn = conn;
\r
15 send = function (t) w(tostring(t)); end;
\r
16 print = function (t) w("| "..tostring(t).."\n"); end;
\r
17 disconnect = function () conn.close(); end;
\r
19 session.env = setmetatable({}, default_env_mt);
\r
21 -- Load up environment with helper objects
\r
22 for name, t in pairs(def_env) do
\r
23 if type(t) == "table" then
\r
24 session.env[name] = setmetatable({ session = session }, { __index = t });
\r
31 local sessions = {};
\r
33 function console_listener.listener(conn, data)
\r
34 local session = sessions[conn];
\r
37 -- Handle new connection
\r
38 session = console:new_session(conn);
\r
39 sessions[conn] = session;
\r
40 session.print("Welcome to the lxmppd admin console!");
\r
45 if data:match("[!.]$") then
\r
46 local command = data:lower();
\r
47 command = data:match("^%w+") or data:match("%p");
\r
48 if commands[command] then
\r
49 commands[command](session, data);
\r
54 session.env._ = data;
\r
56 local chunk, err = loadstring("return "..data);
\r
58 chunk, err = loadstring(data);
\r
60 err = err:gsub("^%[string .-%]:%d+: ", "");
\r
61 err = err:gsub("^:%d+: ", "");
\r
62 err = err:gsub("'<eof>'", "the end of the line");
\r
63 session.print("Sorry, I couldn't understand that... "..err);
\r
68 setfenv(chunk, session.env);
\r
69 local ranok, taskok, message = pcall(chunk);
\r
72 session.print("Fatal error while running command, it did not complete");
\r
73 session.print("Error: "..taskok);
\r
78 session.print("Result: "..tostring(taskok));
\r
80 elseif (not taskok) and message then
\r
81 session.print("Command completed with a problem");
\r
82 session.print("Message: "..tostring(message));
\r
86 session.print("OK: "..tostring(message));
\r
90 function console_listener.disconnect(conn, err)
\r
94 connlisteners_register('console', console_listener);
\r
96 -- Console commands --
\r
97 -- These are simple commands, not valid standalone in Lua
\r
99 function commands.bye(session)
\r
100 session.print("See you! :)");
\r
101 session.disconnect();
\r
104 commands["!"] = function (session, data)
\r
105 if data:match("^!!") then
\r
106 session.print("!> "..session.env._);
\r
107 return console_listener.listener(session.conn, session.env._);
\r
109 local old, new = data:match("^!(.-[^\\])!(.-)!$");
\r
110 if old and new then
\r
111 local ok, res = pcall(string.gsub, session.env._, old, new);
\r
116 session.print("!> "..res);
\r
117 return console_listener.listener(session.conn, res);
\r
119 session.print("Sorry, not sure what you want");
\r
122 -- Session environment --
\r
123 -- Anything in def_env will be accessible within the session as a global variable
\r
125 def_env.server = {};
\r
126 function def_env.server:reload()
\r
128 return true, "Server reloaded";
\r
131 def_env.module = {};
\r
132 function def_env.module:load(name)
\r
133 local mm = require "modulemanager";
\r
134 local ok, err = mm.load(name);
\r
136 return false, err or "Unknown error loading module";
\r
138 return true, "Module loaded";
\r
141 def_env.config = {};
\r
142 function def_env.config:load(filename, format)
\r
143 local config_load = require "core.configmanager".load;
\r
144 local ok, err = config_load(filename, format);
\r
146 return false, err or "Unknown error loading config";
\r
148 return true, "Config loaded";
\r
151 function def_env.config:get(host, section, key)
\r
152 local config_get = require "core.configmanager".get
\r
153 return true, tostring(config_get(host, section, key));
\r
156 def_env.hosts = {};
\r
157 function def_env.hosts:list()
\r
158 for host, host_session in pairs(hosts) do
\r
159 self.session.print(host);
\r
161 return true, "Done";
\r
164 function def_env.hosts:add(name)
\r