mirror of
https://github.com/ShadowNinja/LuaIRC.git
synced 2025-01-25 01:10:20 +01:00
Track user access changing and enable multi-prefix
This also changes the format of user.access.
This commit is contained in:
parent
ac2a9d03fc
commit
d443e2eeeb
@ -154,7 +154,7 @@ function irc:shutdown()
|
|||||||
-- <li><code>username</code> - User username.</li>
|
-- <li><code>username</code> - User username.</li>
|
||||||
-- <li><code>host</code> - User hostname.</li>
|
-- <li><code>host</code> - User hostname.</li>
|
||||||
-- <li><code>realname</code> - User real name.</li>
|
-- <li><code>realname</code> - User real name.</li>
|
||||||
-- <li><code>access</code> - User access, available in channel-oriented callbacks. Can be '+', '@', and others, depending on the server.</li>
|
-- <li><code>access</code> - User access, available in channel-oriented callbacks. A table containing the boolean fields 'op', 'halfop', and 'voice'.</li>
|
||||||
-- </ul>
|
-- </ul>
|
||||||
-- Apart from <code>nick</code>, fields may be missing. To fill them in, enable user tracking and use irc:whois.
|
-- Apart from <code>nick</code>, fields may be missing. To fill them in, enable user tracking and use irc:whois.
|
||||||
-- @name User
|
-- @name User
|
||||||
|
21
handlers.lua
21
handlers.lua
@ -1,6 +1,7 @@
|
|||||||
local pairs = pairs
|
local pairs = pairs
|
||||||
local error = error
|
local error = error
|
||||||
local tonumber = tonumber
|
local tonumber = tonumber
|
||||||
|
local table = table
|
||||||
|
|
||||||
module "irc"
|
module "irc"
|
||||||
|
|
||||||
@ -83,7 +84,7 @@ handlers["353"] = function(o, prefix, me, chanType, channel, names)
|
|||||||
local users = o.channels[channel].users
|
local users = o.channels[channel].users
|
||||||
for nick in names:gmatch("(%S+)") do
|
for nick in names:gmatch("(%S+)") do
|
||||||
local access, name = parseNick(nick)
|
local access, name = parseNick(nick)
|
||||||
users[name] = {type = access}
|
users[name] = {access = access}
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -131,6 +132,24 @@ handlers["324"] = function(o, prefix, user, channel, modes)
|
|||||||
end
|
end
|
||||||
|
|
||||||
handlers["MODE"] = function(o, prefix, target, modes, ...)
|
handlers["MODE"] = function(o, prefix, target, modes, ...)
|
||||||
|
if o.track_users and target ~= o.nick then
|
||||||
|
local add = true
|
||||||
|
local optList = {...}
|
||||||
|
for c in modes:gmatch(".") do
|
||||||
|
if c == "+" then add = true
|
||||||
|
elseif c == "-" then add = false
|
||||||
|
elseif c == "o" then
|
||||||
|
local user = table.remove(optList, 1)
|
||||||
|
o.channels[target].users[user].access.op = add
|
||||||
|
elseif c == "h" then
|
||||||
|
local user = table.remove(optList, 1)
|
||||||
|
o.channels[target].users[user].access.halfop = add
|
||||||
|
elseif c == "v" then
|
||||||
|
local user = table.remove(optList, 1)
|
||||||
|
o.channels[target].users[user].access.voice = add
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
o:invoke("OnModeChange", parsePrefix(prefix), target, modes, ...)
|
o:invoke("OnModeChange", parsePrefix(prefix), target, modes, ...)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
2
init.lua
2
init.lua
@ -117,6 +117,8 @@ function meta_preconnect:connect(_host, _port)
|
|||||||
self.socket = s
|
self.socket = s
|
||||||
setmetatable(self, meta)
|
setmetatable(self, meta)
|
||||||
|
|
||||||
|
self:send("CAP REQ multi-prefix")
|
||||||
|
|
||||||
self:invoke("PreRegister", self)
|
self:invoke("PreRegister", self)
|
||||||
self:send("CAP END")
|
self:send("CAP END")
|
||||||
|
|
||||||
|
17
util.lua
17
util.lua
@ -48,17 +48,30 @@ function parse(line)
|
|||||||
end
|
end
|
||||||
|
|
||||||
function parseNick(nick)
|
function parseNick(nick)
|
||||||
return nick:match("^([%+@]?)(.+)$")
|
local access, name = nick:match("^([%+@]*)(.+)$")
|
||||||
|
return parseAccess(access or ""), name
|
||||||
end
|
end
|
||||||
|
|
||||||
function parsePrefix(prefix)
|
function parsePrefix(prefix)
|
||||||
local user = {}
|
local user = {}
|
||||||
if prefix then
|
if prefix then
|
||||||
user.access, user.nick, user.username, user.host = prefix:match("^([%+@]?)(.+)!(.+)@(.+)$")
|
user.access, user.nick, user.username, user.host = prefix:match("^([%+@]*)(.+)!(.+)@(.+)$")
|
||||||
end
|
end
|
||||||
|
user.access = parseAccess(user.access or "")
|
||||||
return user
|
return user
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function parseAccess(accessString)
|
||||||
|
local access = {op = false, halfop = false, voice = false}
|
||||||
|
for c in accessString:gmatch(".") do
|
||||||
|
if c == "@" then access.op = true
|
||||||
|
elseif c == "%" then access.halfop = true
|
||||||
|
elseif c == "+" then access.voice = true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return access
|
||||||
|
end
|
||||||
|
|
||||||
--mIRC markup scheme (de-facto standard)
|
--mIRC markup scheme (de-facto standard)
|
||||||
color = {
|
color = {
|
||||||
black = 1,
|
black = 1,
|
||||||
|
Loading…
Reference in New Issue
Block a user