174 lines
4.8 KiB
Perl
174 lines
4.8 KiB
Perl
package Pear::LocalLoop::Controller::Api::User;
|
|
use Mojo::Base 'Mojolicious::Controller';
|
|
use Mojo::JSON;
|
|
|
|
has error_messages => sub {
|
|
return {
|
|
day => {
|
|
is_iso_datetime => { message => 'Invalid ISO8601 Datetime', status => 400 },
|
|
},
|
|
name => {
|
|
required => { message => 'No name sent or was blank.', status => 400 },
|
|
},
|
|
display_name => {
|
|
required => { message => 'No display name sent or was blank.', status => 400 },
|
|
},
|
|
full_name => {
|
|
required => { message => 'No full name sent or was blank.', status => 400 },
|
|
},
|
|
email => {
|
|
required => { message => 'No email sent.', status => 400 },
|
|
email => { message => 'Email is invalid.', status => 400 },
|
|
},
|
|
postcode => {
|
|
required => { message => 'No postcode sent.', status => 400 },
|
|
postcode => { message => 'Postcode is invalid', status => 400 },
|
|
},
|
|
password => {
|
|
required => { message => 'No password sent.', status => 400 },
|
|
},
|
|
street_name => {
|
|
required => { message => 'No street_name sent.', status => 400 },
|
|
},
|
|
town => {
|
|
required => { message => 'No town sent.', status => 400 },
|
|
},
|
|
};
|
|
};
|
|
|
|
sub post_day {
|
|
my $c = shift;
|
|
|
|
my $validation = $c->validation;
|
|
|
|
$validation->input( $c->stash->{api_json} );
|
|
|
|
$validation->optional('day')->is_iso_datetime;
|
|
|
|
return $c->api_validation_error if $validation->has_error;
|
|
|
|
$c->render( json => {
|
|
success => Mojo::JSON->true,
|
|
});
|
|
}
|
|
|
|
sub post_account {
|
|
my $c = shift;
|
|
|
|
my $user = $c->stash->{api_user};
|
|
my $user_result = $c->schema->resultset('User')->find({ id => $c->stash->{api_user}->id });
|
|
|
|
if ( defined $user_result ) {
|
|
my $email = $user_result->email;
|
|
my $full_name;
|
|
my $display_name;
|
|
my $postcode;
|
|
|
|
#Needs elsif added for trader page for this similar relevant entry
|
|
if ( $user_result->type eq 'customer' ) {
|
|
$full_name = $user_result->entity->customer->full_name;
|
|
$display_name = $user_result->entity->customer->display_name;
|
|
$postcode = $user_result->entity->customer->postcode;
|
|
} elsif ( $user_result->type eq 'organisation' ) {
|
|
$display_name = $user_result->entity->organisation->name;
|
|
} else {
|
|
return;
|
|
}
|
|
|
|
return $c->render( json => {
|
|
success => Mojo::JSON->true,
|
|
full_name => $full_name,
|
|
display_name => $display_name,
|
|
email => $email,
|
|
postcode => $postcode,
|
|
});
|
|
}
|
|
return $c->render(
|
|
json => {
|
|
success => Mojo::JSON->false,
|
|
message => 'Email or password is invalid.',
|
|
},
|
|
status => 401
|
|
);
|
|
}
|
|
|
|
sub post_account_update {
|
|
my $c = shift;
|
|
|
|
my $user = $c->stash->{api_user};
|
|
|
|
my $validation = $c->validation;
|
|
$validation->input( $c->stash->{api_json} );
|
|
$validation->required('password');
|
|
|
|
return $c->api_validation_error if $validation->has_error;
|
|
|
|
if ( ! $user->check_password($validation->param('password')) ) {
|
|
return $c->render(
|
|
json => {
|
|
success => Mojo::JSON->false,
|
|
message => 'password is invalid.',
|
|
},
|
|
status => 401
|
|
);
|
|
}
|
|
|
|
my $user_rs = $c->schema->resultset('User')->search({
|
|
id => { "!=" => $user->id },
|
|
});
|
|
|
|
$validation->required('email')->not_in_resultset( 'email', $user_rs );
|
|
$validation->required('postcode')->postcode;
|
|
$validation->optional('new_password');
|
|
|
|
if ( $user->type eq 'customer' ) {
|
|
$validation->required('display_name');
|
|
$validation->required('full_name');
|
|
} elsif ( $user->type eq 'organisation' ) {
|
|
$validation->required('name');
|
|
$validation->required('street_name');
|
|
$validation->required('town');
|
|
$validation->required('sector');
|
|
}
|
|
|
|
return $c->api_validation_error if $validation->has_error;
|
|
|
|
if ( $user->type eq 'customer' ){
|
|
|
|
$c->schema->txn_do( sub {
|
|
$user->entity->customer->update({
|
|
full_name => $validation->param('full_name'),
|
|
display_name => $validation->param('display_name'),
|
|
postcode => $validation->param('postcode'),
|
|
});
|
|
$user->update({
|
|
email => $validation->param('email'),
|
|
( defined $validation->param('new_password') ? ( password => $validation->param('new_password') ) : () ),
|
|
});
|
|
});
|
|
|
|
}
|
|
elsif ( $user->type eq 'organisation' ) {
|
|
|
|
$c->schema->txn_do( sub {
|
|
$user->entity->organisation->update({
|
|
name => $validation->param('name'),
|
|
street_name => $validation->param('street_name'),
|
|
town => $validation->param('town'),
|
|
sector => $validation->param('sector'),
|
|
postcode => $validation->param('postcode'),
|
|
});
|
|
$user->update({
|
|
email => $validation->param('email'),
|
|
( defined $validation->param('new_password') ? ( password => $validation->param('new_password') ) : () ),
|
|
});
|
|
});
|
|
}
|
|
|
|
return $c->render( json => {
|
|
success => Mojo::JSON->true,
|
|
message => 'Edited Account Successfully',
|
|
});
|
|
}
|
|
|
|
1;
|