1 #**************************************************************************
2 # Copyright (C) 2008 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::Channel;
27 use MooseX::MethodAttributes;
30 : Alias(qw/deop voice devoice/)
31 : Help(syntax: .op [nicks] | Gives op to the specified nicks, or yourself if no command is given)
34 my ($self,$c,$msg) = @_;
36 $self->name =~ /(de)?(op|voice)/;
38 my $mod = $1 ? '-' : '';
42 push @access, "auto_$access[0]";
46 SELECT DISTINCT LOWER(flag) FROM users u
47 JOIN groupmembers g USING (uid)
48 JOIN channel_group_flags gf USING (gid)
49 JOIN channel_flags f USING (flag)
50 WHERE uid = $1 AND channel = $2 AND f.name = ANY($3);
52 if ($c->check_user_roles(qw/irc_masterop/)){
53 $mode = substr $access[0], 0,1;
55 ($mode) = $c->model->selectrow_array($mode,undef,$c->uid,$c->channel,\@access);
58 $c->command(mode => $c->channel, "$mod$mode", $msg);
60 $c->reply("No access to " . $self->name . " in this channel");
65 :Help(Syntax: invite [channel] | If no channel is specified it invites you to all channel you have auto invite access on)
68 my ($self,$c,$msg) = @_;
70 my ($channel) = $msg =~ /^\s*(\S+)?\s*$/ or die 'ARGS';
73 if ($channel && $c->check_user_roles('irc_masterinvite')){
74 push @channels,$channel;
77 push @access, 'I' if $channel;
78 my $channels = $c->model->prepare(q{
79 SELECT DISTINCT channel FROM users u
80 JOIN groupmembers g USING (uid)
81 JOIN channel_group_flags gf USING (gid)
82 WHERE uid = $1 AND COALESCE(channel = $2,TRUE)
85 $channels->execute($c->uid,$channel,\@access);
86 while (my ($channel) = $channels->fetchrow()){
87 push @channels,$channel;
91 $c->command(invite => $c->nick, $_);
96 : Help(Shows your hostname, as seen by the bots.)
98 my ($self,$c,$msg) = @_;
100 $c->reply('Your hostname is: '.$c->host);
103 ###########################################################
104 # Written by Guy Malachi http://guymal.com
106 ###########################################################
107 sub generate_random_string
109 my $length_of_randomstring=shift;# the length of
110 # the random string to generate
112 my @chars=('a'..'z','A'..'Z','0'..'9','_');
114 foreach (1..$length_of_randomstring)
116 # rand @chars will generate a random
117 # number between 0 and scalar @chars
118 $random_string .= $chars[rand @chars];
120 return $random_string;
124 : Help(Gives new users a random password.)
127 my ($self,$c,$msg) = @_;
130 my $password = generate_random_string 10;
131 my $update = $dbh->do(q{
132 UPDATE users SET password = MD5( ? )
133 WHERE uid = ? AND password =''
134 },undef,$password,$c->uid);
136 $c->reply("Password set to: $password (you can change it on webbie)");
138 $c->reply("Couldn't set password. Either it has already been set or you don't have an account");