]> ruin.nu Git - ndwebbie.git/commitdiff
Converted mail page
authorMichael Andreen <harv@ruin.nu>
Fri, 18 Jul 2008 22:18:28 +0000 (00:18 +0200)
committerMichael Andreen <harv@ruin.nu>
Fri, 18 Jul 2008 22:18:28 +0000 (00:18 +0200)
NDWeb/Pages/Mail.pm [deleted file]
lib/NDWeb/Controller/Users.pm
root/lib/site/leftbar.tt2
root/src/users/mail.tt2 [new file with mode: 0644]
templates/mail.tmpl [deleted file]

diff --git a/NDWeb/Pages/Mail.pm b/NDWeb/Pages/Mail.pm
deleted file mode 100644 (file)
index 897976e..0000000
+++ /dev/null
@@ -1,83 +0,0 @@
-#**************************************************************************
-#   Copyright (C) 2006 by Michael Andreen <harvATruinDOTnu>               *
-#                                                                         *
-#   This program is free software; you can redistribute it and/or modify  *
-#   it under the terms of the GNU General Public License as published by  *
-#   the Free Software Foundation; either version 2 of the License, or     *
-#   (at your option) any later version.                                   *
-#                                                                         *
-#   This program is distributed in the hope that it will be useful,       *
-#   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
-#   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
-#   GNU General Public License for more details.                          *
-#                                                                         *
-#   You should have received a copy of the GNU General Public License     *
-#   along with this program; if not, write to the                         *
-#   Free Software Foundation, Inc.,                                       *
-#   51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.         *
-#**************************************************************************/
-
-package NDWeb::Pages::Mail;
-use strict;
-use warnings FATAL => 'all';
-use CGI qw/:standard/;
-use Mail::Sendmail;
-
-use NDWeb::Forum;
-use NDWeb::Include;
-
-use base qw/NDWeb::XMLPage/;
-
-$NDWeb::Page::PAGES{mail} = __PACKAGE__;
-
-sub render_body {
-       my $self = shift;
-       my ($BODY) = @_;
-
-       my $DBH = $self->{DBH};
-
-       $self->{TITLE} = 'Mail members';
-
-       return $self->noAccess unless $self->isHC;
-
-       my $groups = $DBH->prepare(q{SELECT gid,groupname FROM groups WHERE gid > 0 ORDER BY gid});
-       $groups->execute;
-       my @groups;
-       push @groups,{gid => -1, groupname => 'Pick a group'};
-       while (my $group = $groups->fetchrow_hashref){
-               push @groups,$group;
-       }
-       $BODY->param(Groups => \@groups);
-
-       if (defined param('cmd') && param('group') > 0){
-               my $emails = $DBH->prepare(q{SELECT email FROM users
-                       WHERE uid IN (SELECT uid FROM groupmembers WHERE gid = $1)
-                               AND email is not null});
-               $emails->execute(param('group'));
-               my @emails;
-               while (my $email = $emails->fetchrow_hashref){
-                       push @emails,$email->{email};
-               }
-               $ND::ERROR .= p (join ', ',@emails);
-
-               my %mail = (
-                       smtp => 'ruin.nu',
-                       BCC      => (join ',',@emails),
-                       From    => 'NewDawn Command <nd@ruin.nu>',
-                       'Content-type' => 'text/plain; charset="UTF-8"',
-                       Subject => param('subject'),
-                       Message => param('message'),
-               );
-
-               if (sendmail %mail) {
-                       $ND::ERROR .= p "Mail sent OK.\n" 
-               }else {
-                       $ND::ERROR .= p $Mail::Sendmail::error;
-               }
-       }elsif(defined param('message')) {
-               $BODY->param(Subject => param('subject'));
-               $BODY->param(Message => param('message'));
-       }
-       return $BODY;
-}
-1;
index 36b94c30256ad15172984ff6001220185ccd83ca..781fc73e58e95a8e8b3cd774fb2238f37c95a287 100644 (file)
@@ -5,6 +5,7 @@ use warnings;
 use parent 'Catalyst::Controller';
 
 use ND::Include;
+use Mail::Sendmail;
 
 =head1 NAME
 
@@ -139,6 +140,58 @@ sub findUser : Private {
        $c->stash(u => $user);
 }
 
+sub mail : Local {
+       my ( $self, $c ) = @_;
+       my $dbh = $c->model;
+
+       $c->stash(ok => $c->flash->{ok});
+       $c->stash(error => $c->flash->{error});
+       $c->stash(subject => $c->flash->{subject});
+       $c->stash(message => $c->flash->{message});
+
+       my $groups = $dbh->prepare(q{SELECT gid,groupname FROM groups WHERE gid > 0 ORDER BY gid});
+       $groups->execute;
+       my @groups;
+       push @groups,{gid => -1, groupname => 'Pick a group'};
+       while (my $group = $groups->fetchrow_hashref){
+               push @groups,$group;
+       }
+       $c->stash(groups => \@groups);
+}
+
+sub postmail : Local {
+       my ( $self, $c ) = @_;
+       my $dbh = $c->model;
+
+       my $emails = $dbh->prepare(q{SELECT email FROM users
+               WHERE uid IN (SELECT uid FROM groupmembers WHERE gid = $1)
+                       AND email is not null});
+       $emails->execute($c->req->param('group'));
+       my @emails;
+       while (my $email = $emails->fetchrow_hashref){
+               push @emails,$email->{email};
+       }
+
+       my %mail = (
+               smtp => 'ruin.nu',
+               BCC      => (join ',',@emails),
+               From    => 'NewDawn Command <nd@ruin.nu>',
+               'Content-type' => 'text/plain; charset="UTF-8"',
+               Subject => $c->req->param('subject'),
+               Message => $c->req->param('message'),
+       );
+
+       if (sendmail %mail) {
+               $c->flash(ok => );
+       }else {
+               $c->flash(error => $Mail::Sendmail::error);
+               $c->flash(subject => $c->req->param('subject'));
+               $c->flash(message => $c->req->param('message'));
+       }
+
+       $c->res->redirect($c->uri_for('mail'));
+}
+
 =head1 AUTHOR
 
 Micahel Andreen (harv@ruin.nu)
index 12794f0077bb159e4b845e47374d68fd69f60c49..73f7b013a373074739a49a452b41ab2e2bb1d59b 100644 (file)
        <li><a href="/intel/members">Member Intel</a></li>
        <li><a href="/alliances/resources">Alliance resources</a></li>
        <li><a href="/planetNaps">Planet Naps</a></li>
-       <li><a href="/mail">Mail</a></li>
+       <li><a href="/users/mail">Mail</a></li>
 </ul>
 [% END %]
diff --git a/root/src/users/mail.tt2 b/root/src/users/mail.tt2
new file mode 100644 (file)
index 0000000..8613d8a
--- /dev/null
@@ -0,0 +1,17 @@
+[% META title = 'Mail' %]
+
+[% IF ok %]
+<h3>Mail sent successfully</h3>
+<p>[% ok.join(', ') %]</p>
+[% END %]
+
+<form action="[% c.uri_for('postmail') %]" method="post"><fieldset> <legend>Mail</legend>
+       <p>Subject: <input type="text" name="subject" value="[% subject %]"></p>
+       <p>To: <select name="group">
+[% FOR g IN groups %]
+               <option value="[% g.gid %]">[% g.groupname %]</option>
+[% END %]
+       </select></p>
+       <br><textarea rows="20" cols="50" name="message">[% message %]</textarea>
+       <br><input type="submit" name="cmd" value="Submit">
+</fieldset></form>
diff --git a/templates/mail.tmpl b/templates/mail.tmpl
deleted file mode 100644 (file)
index 246de10..0000000
+++ /dev/null
@@ -1,16 +0,0 @@
-<TMPL_VAR NAME=Error>
-<TMPL_LOOP Scans>
-<p><TMPL_VAR NAME=Scan> <TMPL_VAR NAME=Message></p>
-</TMPL_LOOP>
-
-<form action="<TMPL_VAR NAME=PAGE>" method="post"><fieldset> <legend>Mail</legend>
-       Subject: <input type="text" name="subject" value="<TMPL_VAR NAME=Subject>"/>
-       <br/>To: <select name="group">
-               <TMPL_LOOP Groups>
-               <option value="<TMPL_VAR NAME=GID>"><TMPL_VAR NAME=GroupName></option>
-               </TMPL_LOOP>
-       </select>
-       <br/><textarea rows="20" cols="50" name="message"><TMPL_VAR NAME=Message></textarea>
-       <input type="hidden" name="page" value="<TMPL_VAR NAME=PAGE>"/>
-       <br/><input type="submit" name="cmd" value="Submit"/>
-</fieldset></form>