This repository has been archived on 2023-08-16. You can view files and clone it, but cannot push or open issues or pull requests.
Foodloop-Server/lib/Pear/LocalLoop/Controller/Api/User.pm

193 lines
5.5 KiB
Perl
Raw Normal View History

package Pear::LocalLoop::Controller::Api::User;
use Mojo::Base 'Mojolicious::Controller';
2017-04-23 15:59:35 +00:00
use Mojo::JSON;
has error_messages => sub {
return {
day => {
is_iso_datetime => { message => 'Invalid ISO8601 Datetime', status => 400 },
},
2017-07-26 18:05:35 +00:00
name => {
required => { message => 'No name sent or was blank.', status => 400 },
},
display_name => {
required => { message => 'No display name sent or was blank.', status => 400 },
2017-07-26 18:05:35 +00:00
},
full_name => {
required => { message => 'No full name sent or was blank.', status => 400 },
2017-07-26 18:05:35 +00:00
},
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 },
},
2017-09-04 16:05:10 +00:00
sector => {
required => { message => 'No sector sent.', status => 400 },
},
2017-04-23 15:59:35 +00:00
};
};
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;
2017-08-31 18:08:22 +00:00
if ( $user_result->type eq 'customer' ) {
2017-09-04 15:12:03 +00:00
my $full_name = $user_result->entity->customer->full_name;
my $display_name = $user_result->entity->customer->display_name;
my $postcode = $user_result->entity->customer->postcode;
return $c->render( json => {
success => Mojo::JSON->true,
full_name => $full_name,
display_name => $display_name,
email => $email,
postcode => $postcode,
});
2017-08-31 18:08:22 +00:00
} elsif ( $user_result->type eq 'organisation' ) {
2017-09-04 15:12:03 +00:00
my $name = $user_result->entity->organisation->name;
my $postcode = $user_result->entity->organisation->postcode;
my $street_name = $user_result->entity->organisation->street_name;
my $town = $user_result->entity->organisation->town;
2017-09-04 16:05:10 +00:00
my $sector = $user_result->entity->organisation->sector;
2017-09-04 15:12:03 +00:00
return $c->render( json => {
success => Mojo::JSON->true,
town => $town,
name => $name,
2017-09-04 16:05:10 +00:00
sector => $sector,
2017-09-04 15:12:03 +00:00
street_name => $street_name,
email => $email,
postcode => $postcode,
});
} else {
2017-09-04 15:12:03 +00:00
return $c->render(
json => {
success => Mojo::JSON->false,
message => 'Invalid Server Error.',
},
status => 500
);
}
}
return $c->render(
json => {
success => Mojo::JSON->false,
message => 'Email or password is invalid.',
},
status => 401
);
}
sub post_account_update {
2017-07-26 17:57:13 +00:00
my $c = shift;
my $user = $c->stash->{api_user};
2017-07-26 17:57:13 +00:00
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
);
}
2017-07-26 17:57:13 +00:00
my $user_rs = $c->schema->resultset('User')->search({
id => { "!=" => $user->id },
});
2017-07-26 17:57:13 +00:00
$validation->required('email')->not_in_resultset( 'email', $user_rs );
2017-07-26 17:57:13 +00:00
$validation->required('postcode')->postcode;
$validation->optional('new_password');
2017-07-26 17:57:13 +00:00
2017-08-31 18:08:22 +00:00
if ( $user->type eq 'customer' ) {
2017-07-26 17:57:13 +00:00
$validation->required('display_name');
$validation->required('full_name');
2017-08-31 18:08:22 +00:00
} elsif ( $user->type eq 'organisation' ) {
2017-07-26 17:57:13 +00:00
$validation->required('name');
$validation->required('street_name');
$validation->required('town');
$validation->required('sector');
2017-07-26 17:57:13 +00:00
}
return $c->api_validation_error if $validation->has_error;
2017-08-31 18:08:22 +00:00
if ( $user->type eq 'customer' ){
2017-07-26 17:57:13 +00:00
$c->schema->txn_do( sub {
2017-08-31 18:08:22 +00:00
$user->entity->customer->update({
2017-07-26 17:57:13 +00:00
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') ) : () ),
2017-07-26 17:57:13 +00:00
});
});
}
2017-08-31 18:08:22 +00:00
elsif ( $user->type eq 'organisation' ) {
2017-07-26 17:57:13 +00:00
$c->schema->txn_do( sub {
2017-08-31 18:08:22 +00:00
$user->entity->organisation->update({
2017-07-26 17:57:13 +00:00
name => $validation->param('name'),
street_name => $validation->param('street_name'),
town => $validation->param('town'),
sector => $validation->param('sector'),
2017-07-26 17:57:13 +00:00
postcode => $validation->param('postcode'),
});
$user->update({
2017-07-26 17:57:13 +00:00
email => $validation->param('email'),
( defined $validation->param('new_password') ? ( password => $validation->param('new_password') ) : () ),
2017-07-26 17:57:13 +00:00
});
});
}
return $c->render( json => {
success => Mojo::JSON->true,
message => 'Edited Account Successfully',
});
}
2017-04-23 15:59:35 +00:00
1;