]> ruin.nu Git - NDIRC.git/commitdiff
Converted the .setnick command
authorMichael Andreen <harv@ruin.nu>
Sat, 16 May 2009 21:58:59 +0000 (23:58 +0200)
committerMichael Andreen <harv@ruin.nu>
Sat, 16 May 2009 21:58:59 +0000 (23:58 +0200)
Commands/Intel.pm
Intel.pm
database/roles.sql

index 5e79c96a6c859db3ab2df9a16470968a60a99b76..e529018a6ea6d29bbf1a10438ecbbdbc71ef8e25 100644 (file)
@@ -46,4 +46,34 @@ sub sethostile
        $dbh->commit;
 }
 
+sub setnick
+       : Help(Usage: .setnick X:Y:Z nick)
+       : ACL(irc_setnick)
+{
+       my ($self,$c,$msg) = @_;
+       my ($x,$y,$z,$nick) = $msg =~ /^(\d+)\D(\d+)\D(\d+) (\S+)$/ or die 'ARGS';
+       my $dbh = $c->model;
+
+       my $findid = $dbh->prepare(q{
+SELECT nick, id, alliance_id FROM planets WHERE id = planetid(?,?,?,tick())
+               });
+       my $planet = $dbh->selectrow_hashref($findid,undef,$x,$y,$z);
+       unless($planet->{id}){
+               $c->reply("Couldn't find any planet with coords $x:$y:$z");
+       }elsif($planet->{alliance_id} ~~ 1){
+               $c->reply("This is an ND planet.");
+       }else{
+               $dbh->begin_work;
+               $dbh->do(q{UPDATE planets SET nick = $1 WHERE id = $2}
+                       ,undef,$nick,$planet->{id});
+               if ($planet->{nick}){
+                       $c->reply("$x:$y:$z nick has been changed from <b>$planet->{nick}</b> to <b>$nick</b>");
+               }else{
+                       $c->reply("$x:$y:$z nick has been set to $nick");
+               }
+               $c->intel_log($planet->{id},"Set nick to: $nick");
+               $dbh->commit;
+       }
+}
+
 1;
index 7594c09ac75bb9282d71add33718c6aaba96ae4e..4d98d80880dda96a3718dcf45c25f8ec9f1d6be9 100644 (file)
--- a/Intel.pm
+++ b/Intel.pm
@@ -27,37 +27,7 @@ require Exporter;
 
 our @ISA = qw/Exporter/;
 
-our @EXPORT = qw/setNick setAlly setChannel/;
-
-sub setNick {
-       my ($msg, $command) = @_;
-       my ($x,$y,$z,$nick);
-       if(defined $msg && $msg =~ /^(\d+)\D(\d+)\D(\d+) (\S+)$/){
-               $x = $1;
-               $y = $2;
-               $z = $3;
-               $nick = $4;
-       }else{
-               $ND::server->command("notice $ND::nick Usage: .$command X:Y:Z nick");
-               return;
-       }
-       if (my $user = intel){
-               my $findid = $ND::DBH->prepare_cached(q{SELECT nick, id FROM planets
-                       WHERE id = planetid(?,?,?,tick())});
-               my ($oldnick,$id) = $ND::DBH->selectrow_array($findid,undef,$x,$y,$z);
-               if ($id && $ND::DBH->do('UPDATE planets SET nick = $1 WHERE id = $2'
-                               ,undef,$nick,$id)){
-                       unless (defined $oldnick){
-                               $ND::server->command("msg $ND::target $x:$y:$z nick has been set to $ND::B$nick");
-                       }else{
-                               $ND::server->command("msg $ND::target $x:$y:$z nick has been changed from $ND::B$oldnick$ND::B to $ND::B$nick");
-                       }
-                       intel_log $user->{uid},$id,"Set nick to: $nick";
-               }else{
-                       $ND::server->command("msg $ND::target Couldn't find any planet with coords $x:$y:$z");
-               }
-       }
-}
+our @EXPORT = qw/setAlly setChannel/;
 
 sub setAlly {
        my ($msg, $command) = @_;
index b84e53d8d604854dd4aa36fde909e9467dbe6065..5ff09a02ba17de05c7e581f235a74e37f71239b9 100644 (file)
@@ -25,6 +25,7 @@ INSERT INTO roles VALUES('irc_d');
 INSERT INTO roles VALUES('irc_s');
 INSERT INTO roles VALUES('irc_h');
 INSERT INTO roles VALUES('irc_sethostile');
+INSERT INTO roles VALUES('irc_setnick');
 
 INSERT INTO group_roles (gid,role) VALUES(1,'irc_p_nick');
 INSERT INTO group_roles (gid,role) VALUES(1,'irc_p_intel');
@@ -51,6 +52,7 @@ INSERT INTO group_roles (gid,role) VALUES(1,'irc_d');
 INSERT INTO group_roles (gid,role) VALUES(1,'irc_s');
 INSERT INTO group_roles (gid,role) VALUES(1,'irc_h');
 INSERT INTO group_roles (gid,role) VALUES(1,'irc_sethostile');
+INSERT INTO group_roles (gid,role) VALUES(1,'irc_setnick');
 
 INSERT INTO group_roles (gid,role) VALUES(2,'irc_gs');
 INSERT INTO group_roles (gid,role) VALUES(2,'irc_scan');
@@ -79,6 +81,7 @@ INSERT INTO group_roles (gid,role) VALUES(3,'irc_d');
 INSERT INTO group_roles (gid,role) VALUES(3,'irc_s');
 INSERT INTO group_roles (gid,role) VALUES(3,'irc_h');
 INSERT INTO group_roles (gid,role) VALUES(3,'irc_sethostile');
+INSERT INTO group_roles (gid,role) VALUES(3,'irc_setnick');
 
 INSERT INTO group_roles (gid,role) VALUES(4,'irc_points_others');
 INSERT INTO group_roles (gid,role) VALUES(4,'irc_a');
@@ -86,6 +89,7 @@ INSERT INTO group_roles (gid,role) VALUES(4,'irc_a');
 INSERT INTO group_roles (gid,role) VALUES(5,'irc_p_nick');
 INSERT INTO group_roles (gid,role) VALUES(5,'irc_p_intel');
 INSERT INTO group_roles (gid,role) VALUES(5,'irc_sethostile');
+INSERT INTO group_roles (gid,role) VALUES(5,'irc_setnick');
 
 INSERT INTO group_roles (gid,role) VALUES(6,'irc_p_intel');
 INSERT INTO group_roles (gid,role) VALUES(6,'irc_points_others');