forked from minetest-mods/irc
Add better support for multiple servers and remove format_in/format_out
This commit is contained in:
parent
b3ae3f5f03
commit
25696a8e9a
32
README.txt
32
README.txt
@ -88,38 +88,6 @@ All settings are changed in 'minetest.conf'. If any of these settings
|
|||||||
irc.SASLUser (string, default irc.nick)
|
irc.SASLUser (string, default irc.nick)
|
||||||
The SASL username. This should normaly be set to your main NickServ account name.
|
The SASL username. This should normaly be set to your main NickServ account name.
|
||||||
|
|
||||||
irc.format_out (string, default "<$(name)> $(message)")
|
|
||||||
This specifies how to send the messages from in-game to IRC.
|
|
||||||
The strings can contain "macros" (or variable substitutions), which
|
|
||||||
are specified as "$(macro_name)".
|
|
||||||
Currently, these macros are supported:
|
|
||||||
$(name) The name of the player sending the message.
|
|
||||||
$(message) The actual message text.
|
|
||||||
Any unrecognized macro will be left in the message verbatim.
|
|
||||||
For example, if a user named "mtuser" is saying "Hello!", then:
|
|
||||||
"<$(name)> $(message)"
|
|
||||||
...will yield...
|
|
||||||
"<mtuser> Hello!"
|
|
||||||
...and...
|
|
||||||
"$(name): $(message) $(xyz)"
|
|
||||||
...will yield...
|
|
||||||
"mtuser: Hello! $(xyz)"
|
|
||||||
|
|
||||||
irc.format_in (string,
|
|
||||||
default "<$(name)@IRC> $(message)")
|
|
||||||
This specifies how the messages gotten from the IRC channel are
|
|
||||||
displayed in-game.
|
|
||||||
The strings can contain "macros" (or variable substitutions), which
|
|
||||||
are specified as "$(macro_name)".
|
|
||||||
Currently, these macros are supported:
|
|
||||||
$(name) The nickname of the user sending the message.
|
|
||||||
$(message) The actual message text.
|
|
||||||
$(server) The IRC server.
|
|
||||||
$(port) The IRC server port.
|
|
||||||
$(channel) The IRC channel.
|
|
||||||
In the default configuration, this will yield:
|
|
||||||
<IRCUser@IRC> Hello!
|
|
||||||
|
|
||||||
irc.debug (boolean, default false)
|
irc.debug (boolean, default false)
|
||||||
Whether to output debug information.
|
Whether to output debug information.
|
||||||
|
|
||||||
|
@ -25,7 +25,8 @@ minetest.register_on_chat_message(function(name, message)
|
|||||||
or (not minetest.check_player_privs(name, {shout=true})) then
|
or (not minetest.check_player_privs(name, {shout=true})) then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
mt_irc:queueMsg(mt_irc.msgs.playerMessage(mt_irc.config.channel, name, message))
|
mt_irc:queueMsg(mt_irc.msgs.playerMessage(
|
||||||
|
mt_irc.config.channel, name, message))
|
||||||
end)
|
end)
|
||||||
|
|
||||||
|
|
||||||
|
@ -54,14 +54,6 @@ config.timeout = tonumber(minetest.setting_get("irc.timeout")) or 60.0
|
|||||||
config.command_prefix = minetest.setting_get("irc.command_prefix") or '!'
|
config.command_prefix = minetest.setting_get("irc.command_prefix") or '!'
|
||||||
config.command_prefix = config.command_prefix:sub(1, 1)
|
config.command_prefix = config.command_prefix:sub(1, 1)
|
||||||
|
|
||||||
-- The format of messages sent to IRC server (string, default "<$(name)> $(message)")
|
|
||||||
-- See `README.txt' for the macros supported here.
|
|
||||||
config.format_out = minetest.setting_get("irc.format_out") or "<$(name)> $(message)"
|
|
||||||
|
|
||||||
-- The format of messages sent to IRC server (string, default "<$(name)@IRC> $(message)")
|
|
||||||
-- See `README.txt' for the macros supported here.
|
|
||||||
config.format_in = minetest.setting_get("irc.format_in") or "<$(name)@IRC> $(message)"
|
|
||||||
|
|
||||||
-- Enable debug output (boolean, default false)
|
-- Enable debug output (boolean, default false)
|
||||||
config.debug = minetest.setting_getbool("irc.debug")
|
config.debug = minetest.setting_getbool("irc.debug")
|
||||||
|
|
||||||
|
@ -55,16 +55,34 @@ end
|
|||||||
|
|
||||||
|
|
||||||
function mt_irc.hooks.channelChat(user, channel, message)
|
function mt_irc.hooks.channelChat(user, channel, message)
|
||||||
local t = {
|
-- Support multiple servers in a channel better by converting:
|
||||||
access=user.access,
|
-- "<server@IRC> <player> message" into "<player@server> message"
|
||||||
name=user.nick,
|
-- "<server@IRC> *** player joined/left the game" into "*** player@server joined/left the game"
|
||||||
message=message,
|
-- and "<server@IRC> * player orders a pizza" into "* player@server orders a pizza"
|
||||||
server=mt_irc.conn.host,
|
local foundchat, _, chatnick, chatmessage
|
||||||
port=mt_irc.conn.port,
|
= message:find("^<([^>]+)> (.*)$")
|
||||||
channel=channel
|
local foundjoin, _, joinnick
|
||||||
}
|
= message:find("^%*%*%* ([^%s]+) joined the game$")
|
||||||
local text = mt_irc.config.format_in:expandvars(t)
|
local foundleave, _, leavenick
|
||||||
mt_irc:sendLocal(text)
|
= message:find("^%*%*%* ([^%s]+) left the game$")
|
||||||
|
local foundaction, _, actionnick, actionmessage
|
||||||
|
= message:find("^%* ([^%s]+) (.*)$")
|
||||||
|
|
||||||
|
if foundchat then
|
||||||
|
mt_irc:sendLocal(("<%s@%s> %s")
|
||||||
|
:format(chatnick, user.nick, chatmessage))
|
||||||
|
elseif foundjoin then
|
||||||
|
mt_irc:sendLocal(("*** %s@%s joined the game")
|
||||||
|
:format(joinnick, user.nick))
|
||||||
|
elseif foundleave then
|
||||||
|
mt_irc:sendLocal(("*** %s@%s left the game")
|
||||||
|
:format(leavenick, user.nick))
|
||||||
|
elseif foundaction then
|
||||||
|
mt_irc:sendLocal(("* %s@%s %s")
|
||||||
|
:format(actionnick, user.nick, actionmessage))
|
||||||
|
else
|
||||||
|
mt_irc:sendLocal(("<%s@IRC> %s"):format(user.nick, message))
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
@ -80,15 +98,8 @@ function mt_irc.hooks.pm(user, message)
|
|||||||
mt_irc:say(user.nick, "User '"..player_to.."' is not in the game.")
|
mt_irc:say(user.nick, "User '"..player_to.."' is not in the game.")
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
local t = {
|
minetest.chat_send_player(player_to,
|
||||||
name=user.nick,
|
"PM from "..user.nick.."@IRC: "..message, false)
|
||||||
message=message,
|
|
||||||
server=mt_irc.server,
|
|
||||||
port=mt_irc.port,
|
|
||||||
channel=mt_irc.channel
|
|
||||||
}
|
|
||||||
local text = mt_irc.config.format_in:expandvars(t)
|
|
||||||
minetest.chat_send_player(player_to, "PM: "..text, false)
|
|
||||||
mt_irc:say(user.nick, "Message sent!")
|
mt_irc:say(user.nick, "Message sent!")
|
||||||
elseif message:sub(1, 1) == "!" then
|
elseif message:sub(1, 1) == "!" then
|
||||||
mt_irc:bot_command(user, message:sub(2))
|
mt_irc:bot_command(user, message:sub(2))
|
||||||
|
@ -32,9 +32,8 @@ function mt_irc.msgs.action(to, message)
|
|||||||
end
|
end
|
||||||
|
|
||||||
function mt_irc.msgs.playerMessage(to, name, message)
|
function mt_irc.msgs.playerMessage(to, name, message)
|
||||||
local t = {name=name, message=message}
|
return mt_irc.msgs.privmsg(to, ("<%s> %s"):format(name, message))
|
||||||
local text = mt_irc.config.format_out:expandvars(t)
|
|
||||||
return mt_irc.msgs.privmsg(to, text)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
-- TODO Add more message types
|
-- TODO Add more message types
|
||||||
--
|
|
||||||
|
Loading…
Reference in New Issue
Block a user