mirror of
				https://github.com/sys4-fr/server-nalc.git
				synced 2025-10-25 03:15:22 +02:00 
			
		
		
		
	Reverted IRC update
This commit is contained in:
		| @@ -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 = { | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| --- LuaIRC is a low-level IRC library for Lua. | ||||
| -- All functions raise Lua exceptions on error. | ||||
| -- | ||||
| -- Use <code>new</code> to create a new Connection object.<br/> | ||||
| -- Use <code>new</code> to create a new IRC object.<br/> | ||||
| -- Example:<br/><br/> | ||||
| --<code> | ||||
| --require "irc"<br/> | ||||
| @@ -24,12 +24,11 @@ | ||||
|  | ||||
| module "irc" | ||||
|  | ||||
| --- Create a new Connection object. Use <code>irc:connect</code> to connect to a server. | ||||
| --- Create a new IRC object. Use <code>irc:connect</code> to connect to a server. | ||||
| -- @param user Table with fields <code>nick</code>, <code>username</code> and <code>realname</code>. | ||||
| -- The <code>nick</code> field is required. | ||||
| -- | ||||
| -- @return Returns a new Connection object. | ||||
| -- @see Connection | ||||
| -- @return Returns a new <code>irc</code> 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 <code>irc</code> 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 <code>6667</code>] | ||||
| -- @field timeout Connect timeout. [defaults to <code>30</code>] | ||||
| -- @field password Server password. | ||||
| -- @field secure Boolean to enable TLS connection, pass a params table (described, [luasec]) to control | ||||
| -- <ul> | ||||
| -- <li><code>host</code> - Server host name.</li> | ||||
| -- <li><code>port</code> - Server port. [defaults to <code>6667</code>]</li> | ||||
| -- <li><code>timeout</code> - Connect timeout. [defaults to <code>30</code>]</li> | ||||
| -- <li><code>password</code> - Server password.</li> | ||||
| -- <li><code>secure</code> - Boolean to enable TLS connection, pass a params table (described, [luasec]) to control</li> | ||||
| -- </ul> | ||||
| -- [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. | ||||
| -- <ul> | ||||
| -- <li><code>PreRegister()</code> - Usefull for requesting capabilities.</li> | ||||
| -- <li><code>OnRaw(line)</code> - Any non false/nil return value assumes line handled and will not be further processed.</li> | ||||
| -- <li><code>PreRegister(connection)</code>Useful for CAP commands and SASL.</li> | ||||
| -- <li><code>OnRaw(line) - (any non false/nil return value assumes line handled and will not be further processed)</code></li> | ||||
| -- <li><code>OnSend(line)</code></li> | ||||
| -- <li><code>OnDisconnect(message, errorOccurred)</code></li> | ||||
| -- <li><code>OnChat(user, channel, message)</code></li> | ||||
| @@ -173,10 +162,7 @@ function irc:shutdown() | ||||
| -- <li><code>OnUserMode(modes)</code></li> | ||||
| -- <li><code>OnChannelMode(user, channel, modes)</code></li> | ||||
| -- <li><code>OnModeChange(user, target, modes, ...)</code>* ('...' contains mode options such as banmasks)</li> | ||||
| -- <li><code>OnCapabilityList(caps)</code></li> | ||||
| -- <li><code>OnCapabilityAvailable(cap, value)</code> Called only when a capability becomes available or changes.</li> | ||||
| -- <li><code>OnCapabilitySet(cap, enabled)</code>*</li> | ||||
| -- <li><code>DoX(msg)</code>* - 'X' is any IRC command or numeric with the first letter capitalized (eg, DoPing and Do001)</li> | ||||
| -- <li><code>DoX(msg)</code>'X' is any IRC command or numeric with the first letter capitalized (eg, DoPing and Do001)</li> | ||||
| -- </ul> | ||||
| -- * Event also invoked for yourself. | ||||
| -- <20> Channel passed only when user tracking is enabled | ||||
|   | ||||
| @@ -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 | ||||
|   | ||||
| @@ -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 | ||||
|  | ||||
|   | ||||
| @@ -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) | ||||
|   | ||||
| @@ -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 | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user