]> ruin.nu Git - NDIRC.git/blobdiff - Commands/Channel.pm
Basic conversion to POE::Component::IRC
[NDIRC.git] / Commands / Channel.pm
index d309ce00ae1ac4e533f08f66f90101db2fe28159..9207b0c4cadf71645339da18cab0eaec2756c1bc 100644 (file)
@@ -33,8 +33,9 @@ sub op
 {
        my ($self,$c,$msg) = @_;
 
-       $self->name =~ /(op|voice)/;
-       my @access = ($1);
+       $self->name =~ /(de)?(op|voice)/;
+       my @access = ($2);
+       my $mod = $1 ? '-' : '';
 
        if ($msg =~ /^\s*$/){
                $msg = $c->nick;
@@ -42,19 +43,19 @@ sub op
        }
 
        my $mode = q{
-SELECT DISTINCT channel FROM users u
+SELECT DISTINCT LOWER(flag) FROM users u
        JOIN groupmembers g USING (uid)
        JOIN channel_group_flags gf USING (gid)
        JOIN channel_flags f USING (flag)
 WHERE u.hostmask ILIKE $1 AND channel = $2 AND f.name = ANY($3);
                };
        if ($c->check_user_roles(qw/irc_masterop/)){
-               $mode = 1;
+               $mode = substr $access[0], 0,1;
        }else{
                ($mode) = $c->model->selectrow_array($mode,undef,$c->host,$c->channel,\@access);
        }
        if ($mode){
-               $c->server->command($self->name . " " . $c->channel . " $msg");
+               $c->command(mode => $c->channel, "$mod$mode", $msg);
        }else{
                $c->reply("No access to " . $self->name . " in this channel");
        }
@@ -88,7 +89,7 @@ WHERE u.hostmask ILIKE $1 AND COALESCE(channel = $2,TRUE)
                }
        }
        for (@channels){
-               $c->server->command("invite ". $c->nick ." $_");
+               $c->command(invite => $c->nick, $_);
        }
 }