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

Diff of /trunk/lib/App/RoomReservation/Reservation.pm

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1095 by dpavlin, Sun Jun 28 18:51:49 2009 UTC revision 1121 by dpavlin, Tue Jun 30 13:24:03 2009 UTC
# Line 1  Line 1 
1  package App::RoomReservation::Reservation;  package App::RoomReservation::Reservation;
2  use Moose;  use Moose;
3    
4  extends 'Frey';  use Moose::Util::TypeConstraints;
5  with 'Frey::Web';  use Regexp::Common qw[Email::Address];
6    
7    subtype 'Email',
8            as 'Str',
9            where { /^$RE{Email}{Address}$/ },
10            message { "$_ is not valid e-mail" };
11    
12    extends 'App::RoomReservation';
13    
 use DBI;  
14  use lib 'lib';  use lib 'lib';
15  use Frey::PPI;  use Frey::PPI;
16    
# Line 58  has mobitel => ( Line 64  has mobitel => (
64    
65  has email => (  has email => (
66          is => 'rw',          is => 'rw',
67          isa => 'Str',          isa => 'Email',
68          required => 1,          required => 1,
69  );  );
70    
71  has email_verify => (  has email_verify => (
72          is => 'rw',          is => 'rw',
73          isa => 'Str',          isa => 'Email',
74          required => 1,          required => 1,
75  );  );
76    
77  has _confirmed => (  has _confirmed => (
78          is => 'rw',          is => 'rw',
79          isa => 'Bool',          isa => 'Bool',
80          required => 1,  #       required => 1,
81          default => sub { 0 },          default => sub { 0 },
82  );  );
83    
84  sub dsn { 'DBI:Pg:dbname=room-reservation' }  has _seat_number => (
85            is => 'rw',
86            isa => 'Int',
87    );
88    
89    sub BUILD {
90            my $self = shift;
91            die "e-mail not verified\n" unless $self->email eq $self->email_verify;
92            my $sth = $self->dbh->prepare(qq{
93                    select count(*) from reservation where email = ?
94            });
95            $sth->execute( $self->email );
96            my ($registred) = $sth->fetchrow_array;
97            die "e-mail address ", $self->email, " allready registred\n" if $registred;
98    }
99    
100  my @cols = Frey::PPI->new( class => __PACKAGE__ )->attribute_order;  my @cols = Frey::PPI->new( class => __PACKAGE__ )->attribute_order;
101  warn "# cols = ",join(',', @cols), $/;  warn "# cols = ",join(',', @cols), $/;
102    
103    sub token {
104            my $self = shift;
105            my $sth = $self->dbh->prepare(qq{
106                    select md5( id || email ) from reservation where email = ?
107            });
108            $sth->execute( $self->email );
109            $sth->fetchrow_array;
110    }
111    
112  sub create_as_markup {  sub create_as_markup {
113          my ($self) = @_;          my ($self) = @_;
114    
         my $dbh = DBI->connect( $self->dsn, '', '', { RaiseError => 1 } ) || die $DBI::errstr;  
         $dbh->do( qq{ set client_encoding='utf-8' } ) if $self->dsn =~ m{pg}i;  
   
115          my @vals;          my @vals;
116          my @p;          my @p;
117    
# Line 106  sub create_as_markup { Line 132  sub create_as_markup {
132    
133          warn "sql: $sql\n";          warn "sql: $sql\n";
134    
135          my $sth = $dbh->prepare( $sql );          my $sth = $self->dbh->prepare( $sql );
136          $sth->execute( @vals );          $sth->execute( @vals );
137    
138          $sth->rows;          return
139                    $self->ime . ' ' . $self->prezime
140                    . qq| we have accepted your registration!|
141                    . qq|
142                            <div style="color:red">
143                            You have to confirm your e-mail address and registration
144                            by clicking on link which should be in your e-mail INBOX shortly
145                            </div>
146                    |
147                    . qq|<a href="/App::RoomReservation::Reservation::Confirmation/verify_as_markup?token=|
148                    . $self->token
149                    . qq|">verify</a>|
150                    . ' or '
151                    . qq|<a href="/App::RoomReservation::Reservation::Confirmation/cancel_as_markup?token=|
152                    . $self->token
153                    . qq|">cancel</a>|
154                    ;
155  }  }
156    
157    
158  1;  1;

Legend:
Removed from v.1095  
changed lines
  Added in v.1121

  ViewVC Help
Powered by ViewVC 1.1.26