/[Frey]/branches/zimbardo/lib/App/RoomReservation/Confirmation.pm
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Annotation of /branches/zimbardo/lib/App/RoomReservation/Confirmation.pm

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1152 - (hide annotations)
Wed Jul 1 22:25:11 2009 UTC (14 years, 10 months ago) by dpavlin
Original Path: trunk/lib/App/RoomReservation/Confirmation.pm
File size: 1719 byte(s)
send verification message from single place
1 dpavlin 1122 package App::RoomReservation::Confirmation;
2 dpavlin 1098 use Moose;
3    
4     extends 'App::RoomReservation';
5    
6 dpavlin 1151 with 'App::RoomReservation::Email', 'App::RoomReservation::Messages';
7 dpavlin 1134
8 dpavlin 1098 has token => (
9     is => 'ro',
10     isa => 'Str',
11     required => 1,
12     );
13    
14     sub verify_as_markup {
15     my ($self) = @_;
16    
17 dpavlin 1121 my $dbh = $self->dbh;
18    
19     my $sth = $dbh->prepare(qq{
20     update reservation
21     set
22     _confirmed = true,
23     _seat_number = (
24     select
25     min(seat.nr)
26     from (select generate_series(1,600) as nr) as seat
27     full join reservation on reservation._seat_number = seat.nr
28     where id is null
29     group by seat.nr
30     order by seat.nr asc
31     limit 1
32     )
33 dpavlin 1151 where
34     md5(id||email) = ?
35     and _confirmed is false
36 dpavlin 1098 });
37 dpavlin 1121
38 dpavlin 1098 $sth->execute( $self->token );
39    
40 dpavlin 1151 if ( $sth->rows == 0 ) {
41     warn "can't confirm ", $self->token, " check if it's allready confirmed";
42     $sth = $dbh->prepare(qq{
43     select 1
44     from reservation
45     where
46     md5(id||email) = ?
47     and _confirmed is true
48     });
49     $sth->execute( $self->token );
50     }
51    
52 dpavlin 1098 if ( $sth->rows == 1 ) {
53 dpavlin 1121
54 dpavlin 1151 die "can't find account associated with ", $self->token unless $sth->rows == 1;
55 dpavlin 1134
56 dpavlin 1152 return $self->seat_confirmation_message( token => $self->token );
57 dpavlin 1147
58 dpavlin 1098 } else {
59 dpavlin 1121 die "Problem with confirmation.\n";
60 dpavlin 1098 }
61     }
62    
63     sub cancel_as_markup {
64     my ($self) = @_;
65    
66 dpavlin 1121 my $dbh = $self->dbh;
67    
68     my $sth = $dbh->prepare(qq{
69     update reservation
70     set
71     _confirmed = false,
72     _seat_number = null
73 dpavlin 1151 where
74     md5(id||email) = ?
75     -- and _confirmed is true
76 dpavlin 1098 });
77     $sth->execute( $self->token );
78    
79     if ( $sth->rows == 1 ) {
80 dpavlin 1151 qq|
81     Your <em>reservation is canceled</em>, thanks for your effort to provide seat to somebody else
82     |;
83 dpavlin 1098 } else {
84 dpavlin 1121 die "Problem with cancelation.\n";
85 dpavlin 1098 }
86     }
87    
88 dpavlin 1133 __PACKAGE__->meta->make_immutable;
89     no Moose;
90    
91 dpavlin 1098 1;

  ViewVC Help
Powered by ViewVC 1.1.26