Started working on registration page on website, with validation
This commit is contained in:
parent
cb9819aa2e
commit
0a32b05b6c
6 changed files with 151 additions and 4 deletions
|
@ -30,6 +30,8 @@ sub startup {
|
||||||
});
|
});
|
||||||
my $config = $self->config;
|
my $config = $self->config;
|
||||||
|
|
||||||
|
$self->plugin('Pear::LocalLoop::Plugin::Validators');
|
||||||
|
|
||||||
$self->plugin('Authentication' => {
|
$self->plugin('Authentication' => {
|
||||||
'load_user' => sub {
|
'load_user' => sub {
|
||||||
my ( $c, $user_id ) = @_;
|
my ( $c, $user_id ) = @_;
|
||||||
|
@ -50,6 +52,8 @@ sub startup {
|
||||||
my $r = $self->routes;
|
my $r = $self->routes;
|
||||||
$r->get('/')->to('root#index');
|
$r->get('/')->to('root#index');
|
||||||
$r->post('/')->to('root#auth_login');
|
$r->post('/')->to('root#auth_login');
|
||||||
|
$r->get('/register')->to('register#index');
|
||||||
|
$r->post('/register')->to('register#register');
|
||||||
$r->any('/logout')->to('root#auth_logout');
|
$r->any('/logout')->to('root#auth_logout');
|
||||||
my $api = $r->under('/api' => sub {
|
my $api = $r->under('/api' => sub {
|
||||||
my $c = shift;
|
my $c = shift;
|
||||||
|
|
31
lib/Pear/LocalLoop/Controller/Register.pm
Normal file
31
lib/Pear/LocalLoop/Controller/Register.pm
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
package Pear::LocalLoop::Controller::Register;
|
||||||
|
use Mojo::Base 'Mojolicious::Controller';
|
||||||
|
|
||||||
|
sub index {
|
||||||
|
my $c = shift;
|
||||||
|
|
||||||
|
my $agerange_rs = $c->schema->resultset('AgeRange');
|
||||||
|
$agerange_rs->result_class('DBIx::Class::ResultClass::HashRefInflator');
|
||||||
|
$c->stash( ageranges => [ $agerange_rs->all ] );
|
||||||
|
}
|
||||||
|
|
||||||
|
sub register {
|
||||||
|
my $c = shift;
|
||||||
|
my $validation = $c->validation;
|
||||||
|
$validation->required('token')->in_resultset(
|
||||||
|
'accounttokenname',
|
||||||
|
$c->schema->resultset('AccountToken')->search_rs({used => 0}),
|
||||||
|
);
|
||||||
|
$validation->required('name', 'trim');
|
||||||
|
$validation->required('email')->email;
|
||||||
|
$validation->required('agerange')->in_resultset(
|
||||||
|
'agerangeid',
|
||||||
|
$c->schema->resultset('AgeRange'),
|
||||||
|
);
|
||||||
|
|
||||||
|
use Devel::Dwarn;
|
||||||
|
Dwarn $validation;
|
||||||
|
$c->redirect_to('/register');
|
||||||
|
}
|
||||||
|
|
||||||
|
1;
|
19
lib/Pear/LocalLoop/Plugin/Validators.pm
Normal file
19
lib/Pear/LocalLoop/Plugin/Validators.pm
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
package Pear::LocalLoop::Plugin::Validators;
|
||||||
|
use Mojo::Base 'Mojolicious::Plugin';
|
||||||
|
|
||||||
|
use Email::Valid;
|
||||||
|
|
||||||
|
sub register {
|
||||||
|
my ( $plugin, $app, $conf ) = @_;
|
||||||
|
|
||||||
|
$app->validator->add_check( email => sub {
|
||||||
|
my ( $validation, $name, $email ) = @_;
|
||||||
|
return Email::Valid->address( $email ) ? undef : 1;
|
||||||
|
});
|
||||||
|
$app->validator->add_check( in_resultset => sub {
|
||||||
|
my ( $validation, $name, $value, $key, $rs ) = @_;
|
||||||
|
return $rs->search({ $key => $value })->count ? undef : 1;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
1;
|
|
@ -14,6 +14,26 @@
|
||||||
%= content_for 'css';
|
%= content_for 'css';
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
<nav class="navbar navbar-toggleable-md fixed-top navbar-inverse bg-primary">
|
||||||
|
<button class="navbar-toggler navbar-toggler-right"
|
||||||
|
type="button"
|
||||||
|
data-toggle="collapse"
|
||||||
|
data-target="#navbarNav"
|
||||||
|
aria-controls="navbarNav"
|
||||||
|
aria-expanded="false"
|
||||||
|
aria-label="Toggle navigation">
|
||||||
|
<span class="navbar-toggler-icon"></span>
|
||||||
|
</button>
|
||||||
|
|
||||||
|
<a class="navbar-brand" href="<%= url_for '/home' %>">LocalLoop</a>
|
||||||
|
<div class="collapse navbar-collapse" id="navbarNav">
|
||||||
|
<div class="navbar-nav ml-auto">
|
||||||
|
<a class="nav-item nav-link<%= title eq 'Login' ? ' active' : '' %>" href="<%= url_for '/' %>">Login</a>
|
||||||
|
<a class="nav-item nav-link<%= title eq 'Register' ? ' active' : '' %>" href="<%= url_for '/register' %>">Register</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</nav>
|
||||||
|
|
||||||
<%= content %>
|
<%= content %>
|
||||||
%= content_for 'javascript';
|
%= content_for 'javascript';
|
||||||
</body>
|
</body>
|
||||||
|
|
76
templates/register/index.html.ep
Normal file
76
templates/register/index.html.ep
Normal file
|
@ -0,0 +1,76 @@
|
||||||
|
% layout 'default';
|
||||||
|
% title 'Register';
|
||||||
|
% content_for css => begin
|
||||||
|
<style>
|
||||||
|
body {
|
||||||
|
background: whitesmoke;
|
||||||
|
padding-top: 70px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.panel {
|
||||||
|
background: white;
|
||||||
|
padding: 16px;
|
||||||
|
-webkit-box-shadow: 0px 2px 4px 0px rgba(0,0,0,0.2);
|
||||||
|
-moz-box-shadow: 0px 2px 4px 0px rgba(0,0,0,0.2);
|
||||||
|
box-shadow: 0px 2px 4px 0px rgba(0,0,0,0.2);
|
||||||
|
}
|
||||||
|
|
||||||
|
</style>
|
||||||
|
% end
|
||||||
|
% content_for javascript => begin
|
||||||
|
% end
|
||||||
|
<div class="container">
|
||||||
|
% if ( my $error = flash 'error' ) {
|
||||||
|
<div class="alert alert-danger" role="alert">
|
||||||
|
<strong>Error!</strong> <%= $error %>
|
||||||
|
</div>
|
||||||
|
% } elsif ( my $success = flash 'success' ) {
|
||||||
|
<div class="alert alert-success" role="alert">
|
||||||
|
<strong>Success!</strong> <%= $success %>
|
||||||
|
</div>
|
||||||
|
% }
|
||||||
|
<div class="row justify-content-center">
|
||||||
|
<!-- Fluid Gird, this login box stay in the middle of screen -->
|
||||||
|
<div class="col-8">
|
||||||
|
|
||||||
|
<div class="register-form panel">
|
||||||
|
<form action="<%= url_for %>" method="post">
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="register-token">Invitation Token</label>
|
||||||
|
<input type="text" id="register-token" class="form-control" name="token" required>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="register-name">Full Name</label>
|
||||||
|
<input type="text" id="register-name" class="form-control" name="name" required>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="register-email">Email Address</label>
|
||||||
|
<input type="email" id="register-email" class="form-control" name="email" required>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="register-postcode">Postcode</label>
|
||||||
|
<input type="text" id="register-postcode" class="form-control" name="postcode" required>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="register-age">Age Range</label>
|
||||||
|
<select id="register-age" class="form-control" name="agerange">
|
||||||
|
% for my $agerange ( @$ageranges ) {
|
||||||
|
<option value="<%= $agerange->{agerangeid} %>"><%= $agerange->{agerangestring} %></option>
|
||||||
|
% }
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="login-password">Password</label>
|
||||||
|
<input type="password" id="login-password" class="form-control" name="password" required>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="login-password">Confirm Password</label>
|
||||||
|
<input type="password" id="login-password" class="form-control" name="password2" required>
|
||||||
|
</div>
|
||||||
|
<input type="submit" class="btn btn-block btn-primary" value="Register">
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div><!-- Container fluid-->
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
% layout 'default';
|
% layout 'default';
|
||||||
% title 'LocalLoop Admin - Login';
|
% title 'Login';
|
||||||
% content_for css => begin
|
% content_for css => begin
|
||||||
<style>
|
<style>
|
||||||
body {
|
body {
|
||||||
|
@ -22,9 +22,6 @@ body {
|
||||||
% end
|
% end
|
||||||
% content_for javascript => begin
|
% content_for javascript => begin
|
||||||
% end
|
% end
|
||||||
<nav class="navbar fixed-top navbar-inverse bg-primary">
|
|
||||||
<a class="navbar-brand" href="#"><%= title %></a>
|
|
||||||
</nav>
|
|
||||||
<div class="container-fluid">
|
<div class="container-fluid">
|
||||||
<div class="row justify-content-center">
|
<div class="row justify-content-center">
|
||||||
<!-- Fluid Gird, this login box stay in the middle of screen -->
|
<!-- Fluid Gird, this login box stay in the middle of screen -->
|
||||||
|
|
Reference in a new issue