source: trunk/lib/Vote/Controller/Admin.pm @ 226

Last change on this file since 226 was 226, checked in by nanardon, 15 years ago
  • prefer poll uid in url instead db id (if available)
File size: 7.6 KB
Line 
1package Vote::Controller::Admin;
2
3use strict;
4use warnings;
5use base 'Catalyst::Controller';
6
7=head1 NAME
8
9Vote::Controller::Admin - Catalyst Controller
10
11=head1 DESCRIPTION
12
13Catalyst Controller.
14
15=head1 METHODS
16
17=cut
18
19
20=head2 index
21
22=cut
23
24sub begin : Private {
25    my ( $self, $c, @args ) = @_;
26    $c->model('Vote')->rollback;
27}
28
29sub index : Private {
30    my ( $self, $c ) = @_;
31
32    $c->res->redirect($c->uri_for('/'));
33}
34
35sub modify_poll : Private {
36    my ( $self, $c) = @_;
37    my $id = $c->stash->{voteid};
38
39    my $poll = $c->model('Vote')->poll($id);
40    for ($poll->status || '') {
41    /^BEFORE$/ and do {
42        if ($c->req->param('addch')) {
43            $poll->add_choice($c->req->param('addch'))
44                and $poll->commit;
45        } elsif ($c->req->param('delch')) {
46            $poll->delete_choice($c->req->param('delch'))
47                and $poll->commit;
48        } elsif ($c->req->param('pollparam')) {
49            if ($c->req->param('dstart')) {
50                $c->req->param('start',
51                    $c->req->param('dstart') . ' ' . ($c->req->param('hstart') || '')
52                );
53            }
54            if ($c->req->param('dend')) {
55                $c->req->param('end',
56                    $c->req->param('dend') . ' ' . ($c->req->param('hend') || '')
57                );
58            }
59            if ($c->req->param('end') && $c->req->param('start')) {
60                if ($poll->check_date_max($c->req->param('start'))) {
61                    if (! $poll->check_date_max($c->req->param('end'), $c->req->param('start'))) {
62                        $c->stash->{dateerror} = "Le vote se termine avant de commencer";
63                        next;
64                    }
65                } else {
66                    $c->stash->{dateerror} = "Le debut du vote doit être dans le futur";
67                    next;
68                }
69            } elsif ($c->req->param('end') || $c->req->param('start')) {
70                $c->stash->{dateerror} = "Vous devez définir un debut et une fin";
71                next;
72            }
73            $poll->param(
74                map { $_ => ($c->req->param($_) || undef) }
75                grep { exists($c->req->params->{$_}) }
76                qw(label description start end choice_count free_choice elected_count elected_choice)
77            ) and $poll->commit;
78        } elsif ($c->req->param('encrypted')) {
79            my $passphrase = $c->req->param('passphrase') ||
80                $c->session->{'vpass' . $c->stash->{voteid}};
81            $poll->gen_poll_keys($passphrase)
82                and $poll->commit;
83        } elsif ($c->req->param('notcrypted')) {
84            $poll->param(public_key => undef, private_key => undef)
85                and $poll->commit;
86        }
87    };
88
89    /^(BEFORE|RUNNING)$/ and do {
90        if (my ($upload) = $c->req->upload('votinglist')) {
91            $poll->voting_from_file(
92                $upload->fh,
93                $c->req->param('delete'),
94            ) and $poll->commit;
95        } elsif($c->req->param('delvoting')) {
96            $poll->delete_voting($c->req->param('delvoting'))
97                and $poll->commit;
98        } elsif ($c->req->param('mail')) {
99            $poll->addupd_voting($c->req->param('mail'), $c->req->param('id'))
100                and $poll->commit;
101        } elsif($c->req->param('mailpasswd')) {
102            # TODO
103            foreach my $vkey ($poll->list_voting_no_passwd) {
104                my $voting = $poll->voting($vkey);
105                my $pass = $voting->gen_passwd;
106                $c->forward(
107                    q'Vote::View::Mail', 'render',
108                    [ 'voting_passwd.tt', {
109                        From => $poll->info->{owner},
110                        To => $voting->info->{mail},
111                        Subject => "Invitation à voter",
112                        mail => {
113                            voteid => $id,
114                            mail => $voting->info->{mail},
115                            passwd => $pass,
116                        }
117                    } ]
118                );
119            }
120        }
121    };
122
123    /^AFTER$/ and do {
124        if ($c->req->param('mapfrom')) {
125            $poll->map_value(
126                $c->req->param('mapfrom'),
127                $c->req->param('mapto') || undef,
128            );
129        }
130        foreach my $bid ($poll->list_ballot_needvalid) {
131            if (!$c->req->param($bid)) {
132                next;
133            } elsif($c->req->param($bid) eq 'invalid') {
134                $poll->ballot($bid)->mark_invalid(1);
135                $poll->commit;
136            } elsif($c->req->param($bid) eq 'valid') {
137                $poll->ballot($bid)->mark_invalid(0);
138                $poll->commit;
139            }
140        }
141        if ($c->req->param('decryptballot')) {
142            my $passphrase = $c->req->param('passphrase') ||
143                $c->session->{'vpass' . $c->stash->{voteid}};
144            if ($c->model('Vote')->
145                poll($c->stash->{voteid})->
146                private_key($passphrase)) {
147                $c->model('Vote')->poll($c->stash->{voteid})->decrypted_ballots(
148                    $passphrase
149                );
150            } else {
151            }
152        }   
153    };
154    }
155}
156
157sub auth : Private {
158    my ($self, $c) = @_;
159    my $poll = $c->model('Vote')->poll($c->stash->{voteid});
160    my $password = $c->session->{'vpass' . $c->stash->{voteid}} ||
161        $c->req->param('vpass' . $c->stash->{voteid});
162
163    if (!$poll->auth_poll($password)) {
164        $c->stash->{page}{title} = $poll->info('label') .
165            ': Login d\'administration';
166        $c->session->{'vpass' . $c->stash->{voteid}} = undef;
167        $c->stash->{template} = 'admin/login.tt';
168        return;
169    }
170    $c->session->{'vpass' . $c->stash->{voteid}} = $password;
171    return 1;
172}
173
174sub default : Private {
175    my ( $self, $c, undef, $id ) = @_;
176    $c->stash->{voteid} = $id;
177    my $poll = $c->model('Vote')->poll($id);
178
179    $poll->info or do {
180        $c->res->redirect($c->uri_for('/'));
181        return;
182    };
183
184    $c->forward('auth') or return;
185    $c->forward('modify_poll');
186    $c->stash->{page}{title} = $poll->info('label') . ': Administration';
187}
188
189sub voting: LocalRegex('^(\w+)/voting$') {
190    my ($self, $c) = @_;
191    ($c->stash->{voteid}) = @{ $c->req->snippets || [] };
192    my $poll = $c->model('Vote')->poll($c->stash->{voteid});
193
194    $poll->info or do {
195        $c->res->redirect($c->uri_for('/'));
196        return;
197    };
198
199    $c->forward('auth') or return;
200    $c->forward('modify_poll');
201    $c->stash->{page}{title} = $poll->info('label') . ': Administration, liste des electeurs';
202}
203
204sub ballot: LocalRegex('^(\w+)/ballot$') {
205    my ($self, $c) = @_;
206    ($c->stash->{voteid}) = @{ $c->req->snippets || [] };
207    my $poll = $c->model('Vote')->poll($c->stash->{voteid});
208
209    $poll->info or do {
210        $c->res->redirect($c->uri_for('/'));
211        return;
212    };
213
214    $c->forward('auth') or return;
215    $c->forward('modify_poll');
216    $c->stash->{page}{title} = $poll->info('label') . ': Administration, bulletin';
217}
218
219sub privatekey : LocalRegex('^(\w+)/privatekey$') {
220    my ($self, $c) = @_;
221    ($c->stash->{voteid}) = @{ $c->req->snippets || [] };
222    my $poll = $c->model('Vote')->poll($c->stash->{voteid});
223
224    $poll->info or do {
225        $c->res->redirect($c->uri_for('/'));
226        return;
227    };
228    $c->response->body($poll->info('private_key') || '');
229}
230
231sub end : Private {
232    my ($self, $c) = @_;
233    if ($c->res->body) { return }
234    elsif ($c->stash->{latex}) { $c->forward(qw/Vote::View::Latex/) }
235    else { $c->forward(qw/Vote::View::TT/) }
236}
237
238=head1 AUTHOR
239
240Thauvin Olivier
241
242=head1 LICENSE
243
244This library is free software, you can redistribute it and/or modify
245it under the same terms as Perl itself or CeCILL.
246
247=cut
248
2491;
Note: See TracBrowser for help on using the repository browser.