123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337 |
- using Combot.IRCServices;
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using Combot.IRCServices.Messaging;
-
- namespace Combot.Modules.Plugins
- {
- public class Relay : Module
- {
- public override void Initialize()
- {
- Bot.CommandReceivedEvent += HandleCommandEvent;
-
- Bot.IRC.Message.CTCPMessageReceivedEvent += CTCPRelayHandler;
- Bot.IRC.Message.CTCPNoticeReceivedEvent += CTCPRelayHandler;
- Bot.IRC.Message.ChannelMessageReceivedEvent += RelayChannelMessage;
- Bot.IRC.Message.PrivateMessageReceivedEvent += RelayPrivateMessage;
- Bot.IRC.Message.ChannelNoticeReceivedEvent += RelayChannelNotice;
- Bot.IRC.Message.PrivateNoticeReceivedEvent += RelayPrivateNotice;
- Bot.IRC.Message.JoinChannelEvent += RelayChannelJoin;
- Bot.IRC.Message.InviteChannelEvent += RelayChannelInvite;
- Bot.IRC.Message.PartChannelEvent += RelayChannelPart;
- Bot.IRC.Message.KickEvent += RelayChannelKick;
- Bot.IRC.Message.QuitEvent += RelayQuit;
- }
-
- public override void ParseCommand(CommandMessage command)
- {
- Command foundCommand = Commands.Find(c => c.Triggers.Contains(command.Command));
- switch (foundCommand.Name)
- {
- case "Relay":
- string method = command.Arguments["Method"];
- switch (method.ToLower())
- {
- case "add":
- AddRelay(command);
- break;
- case "edit":
- EditRelay(command);
- break;
- case "delete":
- case "del":
- DeleteRelay(command);
- break;
- case "view":
- ViewRelay(command);
- break;
- }
- break;
- }
- }
-
- private void AddRelay(CommandMessage command)
- {
- string source = command.Arguments.ContainsKey("Source") ? command.Arguments["Source"] : command.Location;
- string target = command.Arguments.ContainsKey("Target") ? command.Arguments["Target"] : command.Nick.Nickname;
- string type = command.Arguments.ContainsKey("Type") ? command.Arguments["Type"] : "Message";
- string modes = command.Arguments.ContainsKey("Modes") ? command.Arguments["Modes"] : string.Empty;
-
- // verify access in source and target
- if (!CheckAccess(source, command.Nick.Nickname, command.Access))
- {
- string invalid = string.Format("You do not have permission to use '{0}' as a source.", source);
- SendResponse(command.MessageType, command.Location, command.Nick.Nickname, invalid, true);
- return;
- }
- if (!CheckAccess(target, command.Nick.Nickname, command.Access))
- {
- string invalid = string.Format("You do not have permission to use '{0}' as a target.", source);
- SendResponse(command.MessageType, command.Location, command.Nick.Nickname, invalid, true);
- return;
- }
-
- RelayType relayType = RelayType.Message;
- Enum.TryParse(type, out relayType);
-
- AddNick(command.Nick);
- string query = "INSERT INTO `relays` SET " +
- "`server_id` = (SELECT `id` FROM `servers` WHERE `name` = {0}), " +
- "`nick_id` = (SELECT `nicks`.`id` FROM `nicks` INNER JOIN `servers` ON `servers`.`id` = `nicks`.`server_id` WHERE `servers`.`name` = {1} && `nickname` = {2}), " +
- "`source` = {3}, " +
- "`target` = {4}, " +
- "`type` = {5}, " +
- "`modes` = {6}, " +
- "`date_added` = {7}";
- Bot.Database.Execute(query, new object[] { Bot.ServerConfig.Name, Bot.ServerConfig.Name, command.Nick.Nickname, source, target, (int)relayType, modes, command.TimeStamp });
- List<Dictionary<string, object>> results = GetRelayList(command.Nick.Nickname);
- string relayMessage = string.Format("Added relay from \u0002{0}\u0002 to \u0002{1}\u0002. You now have \u0002{2}\u0002 relays created.", source, target, results.Count);
- SendResponse(command.MessageType, command.Location, command.Nick.Nickname, relayMessage);
- }
-
- private void EditRelay(CommandMessage command)
- {
- string source = command.Arguments.ContainsKey("Source") ? command.Arguments["Source"] : command.Location;
- string target = command.Arguments.ContainsKey("Target") ? command.Arguments["Target"] : command.Nick.Nickname;
- string type = command.Arguments.ContainsKey("Type") ? command.Arguments["Type"] : "Message";
- string modes = command.Arguments.ContainsKey("Modes") ? command.Arguments["Modes"] : string.Empty;
-
- // verify access in source and target
- if (!CheckAccess(source, command.Nick.Nickname, command.Access))
- {
- string invalid = string.Format("You do not have permission to use '{0}' as a source.", source);
- SendResponse(command.MessageType, command.Location, command.Nick.Nickname, invalid, true);
- return;
- }
- if (!CheckAccess(target, command.Nick.Nickname, command.Access))
- {
- string invalid = string.Format("You do not have permission to use '{0}' as a target.", source);
- SendResponse(command.MessageType, command.Location, command.Nick.Nickname, invalid, true);
- return;
- }
-
- RelayType relayType = RelayType.Message;
- Enum.TryParse(type, out relayType);
-
- int num = HasValidID(command);
-
- if (num > 0)
- {
- List<Dictionary<string, object>> results = GetRelayList(command.Nick.Nickname);
- int id = Convert.ToInt32(results[num - 1]["id"]);
- string query = "UPDATE `relays` SET " +
- "`source` = {0}, " +
- "`target` = {1}, " +
- "`type` = {2}, " +
- "`modes` = {3} " +
- "WHERE `id` = {4}";
- Bot.Database.Execute(query, new object[] { source, target, (int)relayType, modes, id });
- string relayMessage = string.Format("Updated relay \u0002{0}\u0002 to be from \u0002{1}\u0002 to \u0002{2}\u0002.", num, source, target);
- SendResponse(command.MessageType, command.Location, command.Nick.Nickname, relayMessage);
- }
- else
- {
- string invalid = "Invalid relay ID.";
- SendResponse(command.MessageType, command.Location, command.Nick.Nickname, invalid, true);
- }
- }
-
- private void DeleteRelay(CommandMessage command)
- {
- int num = HasValidID(command);
-
- if (num > 0)
- {
- List<Dictionary<string, object>> results = GetRelayList(command.Nick.Nickname);
- int id = Convert.ToInt32(results[num - 1]["id"]);
- string query = "DELETE FROM `relays` " +
- "WHERE `id` = {0}";
- Bot.Database.Execute(query, new object[] { id });
- string relayMessage = string.Format("Relay #\u0002{0}\u0002 has been deleted.", num);
- SendResponse(command.MessageType, command.Location, command.Nick.Nickname, relayMessage);
- }
- else
- {
- string invalid = "Invalid relay ID.";
- SendResponse(command.MessageType, command.Location, command.Nick.Nickname, invalid, true);
- }
- }
-
- private void ViewRelay(CommandMessage command)
- {
- List<Dictionary<string, object>> results = GetRelayList(command.Nick.Nickname);
-
- if (command.Arguments.ContainsKey("ID"))
- {
- int num = HasValidID(command);
- if (num > 0)
- {
- int relayInt = 0;
- Int32.TryParse(results[num - 1]["type"].ToString(), out relayInt);
-
- string relayMessage = string.Format("Relay #\u0002{0}\u0002 - Source: \u0002{1}\u0002 | Target: \u0002{2}\u0002 | Type: \u0002{3}\u0002",
- num, results[num - 1]["source"], results[num - 1]["target"], (RelayType)relayInt);
- if ((RelayType)relayInt == RelayType.Mode)
- {
- relayMessage = string.Format("{0} | Modes: \u0002{1}\u0002", relayMessage, results[num - 1]["modes"]);
- }
- SendResponse(command.MessageType, command.Location, command.Nick.Nickname, relayMessage);
- }
- else
- {
- string invalid = "Invalid relay ID.";
- SendResponse(command.MessageType, command.Location, command.Nick.Nickname, invalid, true);
- }
- }
- else
- {
- if (results.Any())
- {
- for (int i = 0; i < results.Count; i++)
- {
- int relayInt = 0;
- Int32.TryParse(results[i]["type"].ToString(), out relayInt);
-
- string relayMessage = string.Format("Relay #\u0002{0}\u0002 - Source: \u0002{1}\u0002 | Target: \u0002{2}\u0002 | Type: \u0002{3}\u0002",
- i + 1, results[i]["source"], results[i]["target"], (RelayType)relayInt);
- if ((RelayType)relayInt == RelayType.Mode)
- {
- relayMessage = string.Format("{0} | Modes: \u0002{1}\u0002", relayMessage, results[i]["modes"]);
- }
- SendResponse(command.MessageType, command.Location, command.Nick.Nickname, relayMessage, true);
- }
- }
- else
- {
- string invalid = "You do not have any relays set.";
- SendResponse(command.MessageType, command.Location, command.Nick.Nickname, invalid, true);
- }
- }
- }
-
- private List<Dictionary<string, object>> GetRelayList(string nickname)
- {
- string search = "SELECT `relays`.`id`, `relays`.`source`, `relays`.`target`, `relays`.`type`, `relays`.`modes` FROM `relays` " +
- "INNER JOIN `nicks` " +
- "ON `relays`.`nick_id` = `nicks`.`id` " +
- "INNER JOIN `servers` " +
- "ON `nicks`.`server_id` = `servers`.`id` " +
- "WHERE `servers`.`name` = {0} AND `nicks`.`nickname` = {1}";
- return Bot.Database.Query(search, new object[] { Bot.ServerConfig.Name, nickname });
- }
-
- private List<Dictionary<string, object>> GetRelayList(string source, RelayType type)
- {
- string search = "SELECT `relays`.`target`, `relays`.`modes` FROM `relays` " +
- "INNER JOIN `servers` " +
- "ON `relays`.`server_id` = `servers`.`id` " +
- "WHERE `servers`.`name` = {0} AND `relays`.`source` = {1} AND `relays`.`type` = {2}";
- return Bot.Database.Query(search, new object[] { Bot.ServerConfig.Name, source, (int)type });
- }
-
- private bool CheckAccess(string source, string nick, List<AccessType> types)
- {
- // Owners get to have all the fun
- if (Bot.ServerConfig.Owners.Contains(nick))
- return true;
-
- // The source is a channel
- if (Bot.IRC.Channels.Exists(chan => chan.Name == source))
- {
- foreach (AccessType access in types)
- {
- bool valid = Bot.CheckChannelAccess(source, nick, AccessType.Operator);
- if (!valid)
- return false;
- }
- }
- // The source is a nickname
- else
- {
- if (source != nick)
- return false;
- }
- return true;
- }
-
- /* Returns the parsed ID field if valid, otherwise returns 0 */
- private int HasValidID(CommandMessage command)
- {
- int num = 0;
- int ret = 0;
- List<Dictionary<string, object>> results = GetRelayList(command.Nick.Nickname);
-
- if (int.TryParse(command.Arguments["ID"], out num))
- {
- if (results.Count >= num && num > 0)
- {
- ret = num;
- }
- }
-
- return ret;
- }
-
- private void ProcessRelay(string source, RelayType type, string message)
- {
- switch (type)
- {
-
- }
- }
-
- private void RelayQuit(object sender, QuitInfo e)
- {
- string msg = string.Format("{0} has quit.");
- ProcessRelay(e.Nick.Nickname, RelayType.Quit, msg);
- }
-
- private void RelayChannelKick(object sender, KickInfo e)
- {
- string msg = string.Format("{0} has kicked {1} from {2} ({3})", e.Nick.Nickname, e.KickedNick.Nickname, e.Channel, e.Reason);
- ProcessRelay(e.Channel, RelayType.Kick, msg);
- }
-
- private void RelayChannelPart(object sender, PartChannelInfo e)
- {
- throw new NotImplementedException();
- }
-
- private void RelayChannelInvite(object sender, InviteChannelInfo e)
- {
- throw new NotImplementedException();
- }
-
- private void RelayChannelJoin(object sender, JoinChannelInfo e)
- {
- throw new NotImplementedException();
- }
-
- private void RelayPrivateNotice(object sender, PrivateNotice e)
- {
- throw new NotImplementedException();
- }
-
- private void RelayChannelNotice(object sender, ChannelNotice e)
- {
- throw new NotImplementedException();
- }
-
- private void RelayPrivateMessage(object sender, PrivateMessage e)
- {
- throw new NotImplementedException();
- }
-
- private void RelayChannelMessage(object sender, ChannelMessage e)
- {
- throw new NotImplementedException();
- }
-
- private void CTCPRelayHandler(object sender, CTCPMessage e)
- {
- throw new NotImplementedException();
- }
- }
- }
|