1 #**************************************************************************
2 # Copyright (C) 2009 by Michael Andreen <harvATruinDOTnu> *
4 # This program is free software; you can redistribute it and/or modify *
5 # it under the terms of the GNU General Public License as published by *
6 # the Free Software Foundation; either version 2 of the License, or *
7 # (at your option) any later version. *
9 # This program is distributed in the hope that it will be useful, *
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of *
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
12 # GNU General Public License for more details. *
14 # You should have received a copy of the GNU General Public License *
15 # along with this program; if not, write to the *
16 # Free Software Foundation, Inc., *
17 # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *
18 #**************************************************************************/
20 package NDIRC::Commands::Intel;
27 use MooseX::MethodAttributes;
30 : Help(Usage: .sethostile X:Y:Z)
33 my ($self,$c,$msg) = @_;
34 my ($x,$y,$z) = $msg =~ /^(\d+)\D(\d+)\D(\d+)$/ or die 'ARGS';
37 my $findid = $dbh->prepare(q{SELECT planetid(?,?,?,tick())});
38 my ($id) = $dbh->selectrow_array($findid,undef,$x,$y,$z);
40 my $rv = $dbh->do(q{UPDATE planets SET planet_status = 'Hostile' WHERE id = $1}
43 $c->reply("$x:$y:$z is now marked s hostile");
44 $c->intel_log($id,"Set planet_status to: 'Hostile'");
50 : Help(Usage: .setnick X:Y:Z nick)
53 my ($self,$c,$msg) = @_;
54 my ($x,$y,$z,$nick) = $msg =~ /^(\d+)\D(\d+)\D(\d+) (\S+)$/ or die 'ARGS';
57 my $findid = $dbh->prepare(q{
58 SELECT nick, id, alliance_id FROM planets WHERE id = planetid(?,?,?,tick())
60 my $planet = $dbh->selectrow_hashref($findid,undef,$x,$y,$z);
61 unless($planet->{id}){
62 $c->reply("Couldn't find any planet with coords $x:$y:$z");
63 }elsif($planet->{alliance_id} ~~ 1){
64 $c->reply("This is an ND planet.");
67 $dbh->do(q{UPDATE planets SET nick = $1 WHERE id = $2}
68 ,undef,$nick,$planet->{id});
70 $c->reply("$x:$y:$z nick has been changed from <b>$planet->{nick}</b> to <b>$nick</b>");
72 $c->reply("$x:$y:$z nick has been set to $nick");
74 $c->intel_log($planet->{id},"Set nick to: $nick");
80 : Help(Usage: .setally X:Y:Z ally | % can be used for wildcards \%-crew\% will match [F-Crew])
83 my ($self,$c,$msg) = @_;
84 my ($x,$y,$z,$ally) = $msg =~ /^(\d+)\D(\d+)\D(\d+) (\S+)$/ or die 'ARGS';
88 if ($ally ne 'unknown'){
89 ($aid,$ally) = $dbh->selectrow_array(q{
90 SELECT id,name FROM alliances WHERE name ILIKE ?
94 $c->reply("Don't set ND planets manually.");
96 my $findid = $dbh->prepare(q{
97 SELECT id,alliance,alliance_id FROM current_planet_stats WHERE x = ? AND y = ? and z = ?
99 my ($id,$alliance,$alliance_id) = $dbh->selectrow_array($findid,undef,$x,$y,$z);
101 $c->reply("Couldn't find a planet at $x:$y:$z");
102 }elsif ($alliance_id ~~ 1){
103 $c->reply("$x:$y:$z is an ND planet.");
104 }elsif ($alliance_id ~~ $aid){
105 $c->reply("$x:$y:$z is already set to $ally");
108 $dbh->do(q{UPDATE planets SET alliance_id = $1 WHERE id = $2}
110 if (defined $alliance){
111 $c->reply("Changed $x:$y:$z from <b>$alliance</b> to <b>$ally</b>");
113 $c->reply("Setting $x:$y:$z as <b>$ally</b>");
115 $c->intel_log($id,"Set alliance_id to: $aid ($ally)");
119 $c->reply("Couldn't find such an alliance");
124 : Help(Usage: .setchannel X:Y:Z channel | Set channel or bot for a planet)
125 : ACL(irc_setchannel)
127 my ($self,$c,$msg) = @_;
128 my ($x,$y,$z,$channel) = $msg =~ /^(\d+)\D(\d+)\D(\d+) (\S+)$/ or die 'ARGS';
131 my $findid = $dbh->prepare_cached(q{SELECT id,channel FROM current_planet_stats
132 WHERE x = ? AND y = ? and z = ?});
133 my ($id,$oc) = $dbh->selectrow_array($findid,undef,$x,$y,$z);
134 if ($channel ~~ $oc){
135 $c->reply("$x:$y:$z already got $oc as channel");
138 $dbh->do(q{UPDATE planets SET channel = $1 WHERE id = $2}
139 ,undef,$channel,$id);
140 $c->intel_log($id,"Set channel to: $channel");
143 $c->reply("Changed $x:$y:$z from <b>$oc</b> to <b>$channel</b>");
145 $c->reply("Setting $x:$y:$z as <b>$channel</b>");
148 $c->reply("Couldn't find a planet at $x:$y:$z");