diff --git a/mods/irc/init.lua b/mods/irc/init.lua
index 8a6ab85f..8232c245 100755
--- a/mods/irc/init.lua
+++ b/mods/irc/init.lua
@@ -17,8 +17,9 @@ if not jit and package.config:sub(1, 1) == "/" then
package.path = package.path..
";/usr/share/lua/5.1/?.lua"..
";/usr/share/lua/5.1/?/init.lua"
- package.cpath = package.cpath..
- ";/usr/lib/lua/5.1/?.so"
+ package.cpath = package.cpath..
+ -- ";/usr/lib/lua/5.1/?.so"
+ ";/usr/lib/x86_64-linux-gnu/lua/5.1/?.so"
end
irc = {
diff --git a/mods/irc/irc/doc/irc.luadoc b/mods/irc/irc/doc/irc.luadoc
index e5616ed6..7bf638e6 100755
--- a/mods/irc/irc/doc/irc.luadoc
+++ b/mods/irc/irc/doc/irc.luadoc
@@ -1,7 +1,7 @@
--- LuaIRC is a low-level IRC library for Lua.
-- All functions raise Lua exceptions on error.
--
--- Use new
to create a new Connection object.
+-- Use new
to create a new IRC object.
-- Example:
--
--require "irc"
@@ -24,12 +24,11 @@
module "irc"
---- Create a new Connection object. Use irc:connect
to connect to a server.
+--- Create a new IRC object. Use irc:connect
to connect to a server.
-- @param user Table with fields nick
, username
and realname
.
-- The nick
field is required.
--
--- @return Returns a new Connection object.
--- @see Connection
+-- @return Returns a new irc
object.
function new(user)
--- Hook a function to an event.
@@ -50,7 +49,7 @@ function irc:unhook(name, id)
function irc:connect(server, port)
-- @param table Table of connection details
--- @see ConnectOptions
+-- @see Connection
function irc:connect(table)
--- Disconnect irc
from the server.
@@ -117,26 +116,16 @@ function irc:handle(msg)
function irc:shutdown()
--- Table with connection information.
--- @name ConnectOptions
--- @class table
--- @field host Server host name.
--- @field port Server port. [defaults to 6667
]
--- @field timeout Connect timeout. [defaults to 30
]
--- @field password Server password.
--- @field secure Boolean to enable TLS connection, pass a params table (described, [luasec]) to control
+--
+-- host
- Server host name.
+-- port
- Server port. [defaults to 6667
]
+-- timeout
- Connect timeout. [defaults to 30
]
+-- password
- Server password.
+-- secure
- Boolean to enable TLS connection, pass a params table (described, [luasec]) to control
+--
-- [luasec]: http://www.inf.puc-rio.br/~brunoos/luasec/reference.html
-
---- Class representing a connection.
-- @name Connection
-- @class table
--- @field authed Boolean indicating whether the connection has completed registration.
--- @field connected Whether the connection is currently connected.
--- @field motd The server's message of the day. Can be nil.
--- @field nick The current nickname.
--- @field realname The real name sent to the server.
--- @field username The username/ident sent to the server.
--- @field socket Raw socket used by the library.
--- @field supports What the server claims to support in it's ISUPPORT message.
--- Class representing an IRC message.
-- @name Message
@@ -156,8 +145,8 @@ function irc:shutdown()
--- List of hooks you can use with irc:hook.
-- The parameter list describes the parameters passed to the callback function.
--
--- PreRegister()
- Usefull for requesting capabilities.
--- OnRaw(line)
- Any non false/nil return value assumes line handled and will not be further processed.
+-- PreRegister(connection)
Useful for CAP commands and SASL.
+-- OnRaw(line) - (any non false/nil return value assumes line handled and will not be further processed)
-- OnSend(line)
-- OnDisconnect(message, errorOccurred)
-- OnChat(user, channel, message)
@@ -173,10 +162,7 @@ function irc:shutdown()
-- OnUserMode(modes)
-- OnChannelMode(user, channel, modes)
-- OnModeChange(user, target, modes, ...)
* ('...' contains mode options such as banmasks)
--- OnCapabilityList(caps)
--- OnCapabilityAvailable(cap, value)
Called only when a capability becomes available or changes.
--- OnCapabilitySet(cap, enabled)
*
--- DoX(msg)
* - 'X' is any IRC command or numeric with the first letter capitalized (eg, DoPing and Do001)
+-- DoX(msg)
'X' is any IRC command or numeric with the first letter capitalized (eg, DoPing and Do001)
--
-- * Event also invoked for yourself.
-- † Channel passed only when user tracking is enabled
diff --git a/mods/irc/irc/handlers.lua b/mods/irc/irc/handlers.lua
index 6e60f76e..6af5d107 100755
--- a/mods/irc/irc/handlers.lua
+++ b/mods/irc/irc/handlers.lua
@@ -7,67 +7,6 @@ handlers["PING"] = function(conn, msg)
conn:send(irc.Message({command="PONG", args=msg.args}))
end
-local function requestWanted(conn, wanted)
- local args = {}
- for cap, value in pairs(wanted) do
- if type(value) == "string" then
- cap = cap .. "=" .. value
- end
- if not conn.capabilities[cap] then
- table.insert(args, cap)
- end
- end
- conn:queue(irc.Message({
- command = "CAP",
- args = {"REQ", table.concat(args, " ")}
- })
- )
-end
-
-handlers["CAP"] = function(conn, msg)
- local cmd = msg.args[2]
- if not cmd then
- return
- end
- if cmd == "LS" then
- local list = msg.args[3]
- local last = false
- if list == "*" then
- list = msg.args[4]
- else
- last = true
- end
- local avail = conn.availableCapabilities
- local wanted = conn.wantedCapabilities
- for item in list:gmatch("(%S+)") do
- local eq = item:find("=", 1, true)
- local k, v
- if eq then
- k, v = item:sub(1, eq - 1), item:sub(eq + 1)
- else
- k, v = item, true
- end
- if not avail[k] or avail[k] ~= v then
- wanted[k] = conn:invoke("OnCapabilityAvailable", k, v)
- end
- avail[k] = v
- end
- if last then
- if next(wanted) then
- requestWanted(conn, wanted)
- end
- conn:invoke("OnCapabilityList", conn.availableCapabilities)
- end
- elseif cmd == "ACK" then
- for item in msg.args[3]:gmatch("(%S+)") do
- local enabled = (item:sub(1, 1) ~= "-")
- local name = enabled and item or item:sub(2)
- conn:invoke("OnCapabilitySet", name, enabled)
- conn.capabilities[name] = enabled
- end
- end
-end
-
handlers["001"] = function(conn, msg)
conn.authed = true
conn.nick = msg.args[1]
@@ -77,6 +16,7 @@ handlers["PRIVMSG"] = function(conn, msg)
conn:invoke("OnChat", msg.user, msg.args[1], msg.args[2])
end
+
handlers["NOTICE"] = function(conn, msg)
conn:invoke("OnNotice", msg.user, msg.args[1], msg.args[2])
end
@@ -131,13 +71,13 @@ handlers["NICK"] = function(conn, msg)
conn:invoke("NickChange", msg.user, newNick)
end
if msg.user.nick == conn.nick then
- conn.nick = newNick
+ conn.nick = newnick
end
end
local function needNewNick(conn, msg)
local newnick = conn.nickGenerator(msg.args[2])
- conn:queue(irc.msgs.nick(newnick))
+ conn:queue(msgs.nick(newnick))
end
-- ERR_ERRONEUSNICKNAME (Misspelt but remains for historical reasons)
@@ -146,13 +86,6 @@ handlers["432"] = needNewNick
-- ERR_NICKNAMEINUSE
handlers["433"] = needNewNick
--- ERR_UNAVAILRESOURCE
-handlers["437"] = function(conn, msg)
- if not conn.authed then
- needNewNick(conn, msg)
- end
-end
-
-- RPL_ISUPPORT
handlers["005"] = function(conn, msg)
local arglen = #msg.args
diff --git a/mods/irc/irc/init.lua b/mods/irc/irc/init.lua
index 15c9e7c0..e2eb71e8 100755
--- a/mods/irc/irc/init.lua
+++ b/mods/irc/irc/init.lua
@@ -1,11 +1,9 @@
-local name = ...
-name = name:gsub("%.init$", "")
-local irc = require(name..".main")
-require(name..".util")
-require(name..".asyncoperations")
-require(name..".handlers")
-require(name..".messages")
+local irc = require("irc.main")
+require("irc.util")
+require("irc.asyncoperations")
+require("irc.handlers")
+require("irc.messages")
return irc
diff --git a/mods/irc/irc/main.lua b/mods/irc/irc/main.lua
index 42454fa5..c3a7c8f6 100755
--- a/mods/irc/irc/main.lua
+++ b/mods/irc/irc/main.lua
@@ -11,15 +11,12 @@ local meta_preconnect = {}
function meta_preconnect.__index(o, k)
local v = rawget(meta_preconnect, k)
- if v == nil and meta[k] then
+ if not v and meta[k] then
error(("field '%s' is not accessible before connecting"):format(k), 2)
end
return v
end
-meta.connected = true
-meta_preconnect.connected = false
-
function irc.new(data)
local o = {
nick = assert(data.nick, "Field 'nick' is required");
@@ -32,9 +29,6 @@ function irc.new(data)
messageQueue = {};
lastThought = 0;
recentMessages = 0;
- availableCapabilities = {};
- wantedCapabilities = {};
- capabilities = {};
}
assert(irc.checkNick(o.nick), "Erroneous nickname passed to irc.new")
return setmetatable(o, meta_preconnect)
@@ -63,9 +57,8 @@ function meta:invoke(name, ...)
local hooks = self.hooks[name]
if hooks then
for id, f in pairs(hooks) do
- local ret = f(...)
- if ret then
- return ret
+ if f(...) then
+ return true
end
end
end
@@ -116,7 +109,10 @@ function meta_preconnect:connect(_host, _port)
self.socket = s
setmetatable(self, meta)
- self:invoke("PreRegister")
+ self:queue(irc.Message({command="CAP", args={"REQ", "multi-prefix"}}))
+
+ self:invoke("PreRegister", self)
+ self:queue(irc.Message({command="CAP", args={"END"}}))
if password then
self:queue(irc.Message({command="PASS", args={password}}))
@@ -146,7 +142,7 @@ end
function meta:shutdown()
self.socket:close()
- setmetatable(self, meta_preconnect)
+ setmetatable(self, nil)
end
local function getline(self, errlevel)
diff --git a/mods/irc/irc/messages.lua b/mods/irc/irc/messages.lua
index 012f38ce..2f753edc 100755
--- a/mods/irc/irc/messages.lua
+++ b/mods/irc/irc/messages.lua
@@ -198,7 +198,3 @@ function msgs.mode(target, modes)
return irc.Message({command="MODE", args={target, unpack(mt)}})
end
-function msgs.cap(cmd, ...)
- return irc.Message({command="CAP", args={cmd, ...}})
-end
-