MCGalaxy/Commands/CmdWhoip.cs
2015-03-21 09:45:31 -04:00

57 lines
2.2 KiB
C#

/*
Copyright 2011 MCGalaxy
Dual-licensed under the Educational Community License, Version 2.0 and
the GNU General Public License, Version 3 (the "Licenses"); you may
not use this file except in compliance with the Licenses. You may
obtain a copy of the Licenses at
http://www.opensource.org/licenses/ecl2.php
http://www.gnu.org/licenses/gpl-3.0.html
Unless required by applicable law or agreed to in writing,
software distributed under the Licenses are distributed on an "AS IS"
BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
or implied. See the Licenses for the specific language governing
permissions and limitations under the Licenses.
*/
using System.Data;
using MCGalaxy.SQL;
namespace MCGalaxy.Commands
{
public sealed class CmdWhoip : Command
{
public override string name { get { return "whoip"; } }
public override string shortcut { get { return ""; } }
public override string type { get { return "information"; } }
public override bool museumUsable { get { return true; } }
public override LevelPermission defaultRank { get { return LevelPermission.Operator; } }
public CmdWhoip() { }
public override void Use(Player p, string message)
{
if (message == "") { Help(p); return; }
if (message.IndexOf("'") != -1) { Player.SendMessage(p, "Cannot parse request."); return; }
Database.AddParams("@IP", message);
DataTable playerDb = Database.fillData("SELECT Name FROM Players WHERE IP=@IP");
if (playerDb.Rows.Count == 0) { Player.SendMessage(p, "Could not find anyone with this IP"); return; }
string playerNames = "Players with this IP: ";
for (int i = 0; i < playerDb.Rows.Count; i++)
{
playerNames += playerDb.Rows[i]["Name"] + ", ";
}
playerNames = playerNames.Remove(playerNames.Length - 2);
Player.SendMessage(p, playerNames);
playerDb.Dispose();
}
public override void Help(Player p)
{
p.SendMessage("/whoip <ip address> - Displays players associated with a given IP address.");
}
}
}