/[Frey]/trunk/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 /trunk/lib/App/RoomReservation/Confirmation.pm

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1178 - (hide annotations)
Tue Jul 7 20:11:44 2009 UTC (14 years, 10 months ago) by dpavlin
File size: 1968 byte(s)
use number of seats from room definition
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 dpavlin 1178 my $size = $self->room->seats;
20    
21 dpavlin 1121 my $sth = $dbh->prepare(qq{
22     update reservation
23     set
24     _confirmed = true,
25     _seat_number = (
26     select
27     min(seat.nr)
28 dpavlin 1178 from (select generate_series(1,$size) as nr) as seat
29 dpavlin 1121 full join reservation on reservation._seat_number = seat.nr
30     where id is null
31     group by seat.nr
32     order by seat.nr asc
33     limit 1
34     )
35 dpavlin 1151 where
36     md5(id||email) = ?
37     and _confirmed is false
38 dpavlin 1155 and _canceled is false
39 dpavlin 1098 });
40 dpavlin 1121
41 dpavlin 1165 my $token = $self->token;
42 dpavlin 1098
43 dpavlin 1165 $sth->execute( $token );
44    
45 dpavlin 1151 if ( $sth->rows == 0 ) {
46     warn "can't confirm ", $self->token, " check if it's allready confirmed";
47     $sth = $dbh->prepare(qq{
48     select 1
49     from reservation
50     where
51     md5(id||email) = ?
52     and _confirmed is true
53     });
54 dpavlin 1165 $sth->execute( $token );
55 dpavlin 1151 }
56    
57 dpavlin 1098 if ( $sth->rows == 1 ) {
58 dpavlin 1121
59 dpavlin 1165 die qq|<error>can't find account associated with $token</error>| unless $sth->rows == 1;
60 dpavlin 1134
61 dpavlin 1165 return $self->seat_confirmation_message( token => $token );
62 dpavlin 1147
63 dpavlin 1098 } else {
64 dpavlin 1165 die qq|<error>Can't find confirmation $token<br>
65     Did you copy-pasted whole URL in your browser?</error>|;
66 dpavlin 1098 }
67     }
68    
69     sub cancel_as_markup {
70     my ($self) = @_;
71    
72 dpavlin 1121 my $dbh = $self->dbh;
73    
74     my $sth = $dbh->prepare(qq{
75     update reservation
76     set
77 dpavlin 1155 _canceled = true,
78 dpavlin 1121 _seat_number = null
79 dpavlin 1151 where
80     md5(id||email) = ?
81     -- and _confirmed is true
82 dpavlin 1098 });
83     $sth->execute( $self->token );
84    
85     if ( $sth->rows == 1 ) {
86 dpavlin 1151 qq|
87     Your <em>reservation is canceled</em>, thanks for your effort to provide seat to somebody else
88     |;
89 dpavlin 1098 } else {
90 dpavlin 1165 die qq|<error>Can't find reservation which you are trying to cancel.<br>
91     Did you copy-pasted whole URL in your browser?</error>|;
92 dpavlin 1098 }
93     }
94    
95 dpavlin 1133 __PACKAGE__->meta->make_immutable;
96     no Moose;
97    
98 dpavlin 1098 1;

  ViewVC Help
Powered by ViewVC 1.1.26