Add support for common CTCP commands
This commit is contained in:
		
							parent
							
								
									5b0671b512
								
							
						
					
					
						commit
						290082760b
					
				| @ -5,6 +5,7 @@ cmake_minimum_required(VERSION 2.8) | |||||||
| 
 | 
 | ||||||
| project(MINETEST_IRC C) | project(MINETEST_IRC C) | ||||||
| 
 | 
 | ||||||
|  | # Also update init.lua | ||||||
| set(MINETEST_IRC_VERSION 0.2.0) | set(MINETEST_IRC_VERSION 0.2.0) | ||||||
| 
 | 
 | ||||||
| list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/cmake") | list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/cmake") | ||||||
|  | |||||||
| @ -40,16 +40,36 @@ function mt_irc.hooks.chat(user, channel, message) | |||||||
| 	message = message:gsub('\2', '') | 	message = message:gsub('\2', '') | ||||||
| 	message = message:gsub('\31', '') | 	message = message:gsub('\31', '') | ||||||
| 	message = message:gsub('\3[0-9][0-9,]*', '') | 	message = message:gsub('\3[0-9][0-9,]*', '') | ||||||
|  | 
 | ||||||
|  | 	if string.sub(message, 1, 1) == string.char(1) then | ||||||
|  | 		mt_irc.conn:invoke("OnCTCP", user, channel, message) | ||||||
|  | 		return | ||||||
|  | 	end | ||||||
|  | 
 | ||||||
| 	if channel == mt_irc.conn.nick then | 	if channel == mt_irc.conn.nick then | ||||||
| 		mt_irc.conn:invoke("PrivateMessage", user, message) | 		mt_irc.conn:invoke("PrivateMessage", user, message) | ||||||
| 	else |  | ||||||
| 		local c = string.char(1) |  | ||||||
| 		local found, _, action = message:find(("^%sACTION ([^%s]*)%s$"):format(c, c, c)) |  | ||||||
| 		if found then |  | ||||||
| 			mt_irc.conn:invoke("OnChannelAction", user, channel, action) |  | ||||||
| 	else | 	else | ||||||
| 		mt_irc.conn:invoke("OnChannelChat", user, channel, message) | 		mt_irc.conn:invoke("OnChannelChat", user, channel, message) | ||||||
| 	end | 	end | ||||||
|  | end | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | function mt_irc.hooks.ctcp(user, channel, message) | ||||||
|  | 	if message:sub(2, 7):upper() == "ACTION" and | ||||||
|  | 			channel ~= mt_irc.conn.nick then | ||||||
|  | 		local action = message:sub(9, -2) | ||||||
|  | 		mt_irc:sendLocal(("* %s@IRC %s"):format(user.nick, action)) | ||||||
|  | 	elseif message:sub(2, 8):upper() == "VERSION" then | ||||||
|  | 		mt_irc:queueMsg(mt_irc.msgs.notice(user.nick, | ||||||
|  | 				("\1VERSION Minetest IRC mod %s\1") | ||||||
|  | 				:format(mt_irc.version))) | ||||||
|  | 	elseif message:sub(2, 5):upper() == "PING" then | ||||||
|  | 		local ts = message:sub(7, -2) | ||||||
|  | 		mt_irc:queueMsg(mt_irc.msgs.notice(user.nick, | ||||||
|  | 				("\1PING %s\1"):format(ts))) | ||||||
|  | 	elseif message:sub(2, 5):upper() == "TIME" then | ||||||
|  | 		mt_irc:queueMsg(mt_irc.msgs.notice(user.nick, | ||||||
|  | 				("\1TIME %s\1"):format(os.date()))) | ||||||
| 	end | 	end | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| @ -170,12 +190,6 @@ function mt_irc.hooks.quit(user, reason) | |||||||
| end | end | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| function mt_irc.hooks.action(user, channel, message) |  | ||||||
| 	mt_irc:sendLocal(("* %s@IRC %s") |  | ||||||
| 			:format(user.nick, message)) |  | ||||||
| end |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| function mt_irc.hooks.disconnect(message, isError) | function mt_irc.hooks.disconnect(message, isError) | ||||||
| 	mt_irc.connected = false | 	mt_irc.connected = false | ||||||
| 	if isError then | 	if isError then | ||||||
| @ -213,7 +227,7 @@ mt_irc:register_hook("OnKick",          mt_irc.hooks.kick) | |||||||
| mt_irc:register_hook("OnJoin",          mt_irc.hooks.join) | mt_irc:register_hook("OnJoin",          mt_irc.hooks.join) | ||||||
| mt_irc:register_hook("OnQuit",          mt_irc.hooks.quit) | mt_irc:register_hook("OnQuit",          mt_irc.hooks.quit) | ||||||
| mt_irc:register_hook("NickChange",      mt_irc.hooks.nick) | mt_irc:register_hook("NickChange",      mt_irc.hooks.nick) | ||||||
| mt_irc:register_hook("OnChannelAction", mt_irc.hooks.action) | mt_irc:register_hook("OnCTCP",          mt_irc.hooks.ctcp) | ||||||
| mt_irc:register_hook("PrivateMessage",  mt_irc.hooks.pm) | mt_irc:register_hook("PrivateMessage",  mt_irc.hooks.pm) | ||||||
| mt_irc:register_hook("OnNotice",        mt_irc.hooks.notice) | mt_irc:register_hook("OnNotice",        mt_irc.hooks.notice) | ||||||
| mt_irc:register_hook("OnChannelChat",   mt_irc.hooks.channelChat) | mt_irc:register_hook("OnChannelChat",   mt_irc.hooks.channelChat) | ||||||
|  | |||||||
| @ -3,12 +3,13 @@ | |||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| mt_irc = { | mt_irc = { | ||||||
|  | 	version = "0.2.0",  -- Also update CMakeLists.txt | ||||||
| 	connected = false, | 	connected = false, | ||||||
| 	cur_time = 0, | 	cur_time = 0, | ||||||
| 	message_buffer = {}, | 	message_buffer = {}, | ||||||
| 	recent_message_count = 0, | 	recent_message_count = 0, | ||||||
| 	joined_players = {}, | 	joined_players = {}, | ||||||
| 	modpath = minetest.get_modpath("irc") | 	modpath = minetest.get_modpath(minetest.get_current_modname()), | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| -- To find LuaIRC and LuaSocket | -- To find LuaIRC and LuaSocket | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user