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/Admin/Users.pm
2021-03-20 23:26:52 +00:00

206 lines
6 KiB
Perl

package Pear::LocalLoop::Controller::Admin::Users;
use Mojo::Base 'Mojolicious::Controller';
use Try::Tiny;
use Data::Dumper;
has user_result_set => sub {
my $c = shift;
return $c->schema->resultset('User');
};
has customer_result_set => sub {
my $c = shift;
return $c->schema->resultset('Customer');
};
has organisation_result_set => sub {
my $c = shift;
return $c->schema->resultset('Organisation');
};
## no critic (Subroutines::ProhibitBuiltinHomonyms)
sub index {
## use critic
my $c = shift;
my $user_rs = $c->user_result_set->search(
undef,
{
prefech => { entity => [qw/ customer organisation /] },
page => $c->param('page') || 1,
rows => 10,
order_by => { -asc => 'email' },
}
);
$c->stash( user_rs => $user_rs );
return 1;
}
## no critic (Subroutines::ProhibitBuiltinHomonyms)
sub read {
## use critic
my $c = shift;
my $id = $c->param('id');
if ( my $user = $c->user_result_set->find($id) ) {
my $transactions = $user->entity->purchases->search(
undef,
{
page => $c->param('page') || 1,
rows => 10,
order_by => { -desc => 'submitted_at' },
},
);
$c->stash(
user => $user,
transactions => $transactions,
);
}
else {
$c->flash( error => 'No User found' );
$c->redirect_to('/admin/users');
}
return 1;
}
## no critic (Subroutines::ProhibitBuiltinHomonyms)
sub update {
## use critic
my ( $c, $error ) = @_;
my $id = $c->param('id');
my $user;
unless ( $user = $c->user_result_set->find($id) ) {
$c->flash( error => 'No User found' );
return $c->redirect_to( '/admin/users/' . $id );
}
my $validation = $c->validation;
my $not_myself_user_rs = $c->user_result_set->search(
{
id => { "!=" => $user->id },
}
);
$validation->required('email')
->email->not_in_resultset( 'email', $not_myself_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->optional('sector');
}
if ( $validation->has_error ) {
$c->flash( error => 'The validation has failed' );
return $c->redirect_to( '/admin/users/' . $id );
}
my $location =
$c->get_location_from_postcode( $validation->param('postcode'),
$user->type, );
if ( $user->type eq 'customer' ) {
try {
$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'),
(
defined $location
? (%$location)
: ( latitude => undef, longitude => undef )
),
}
);
$user->update(
{
email => $validation->param('email'),
(
defined $validation->param('new_password')
? ( password =>
$validation->param('new_password') )
: ()
),
}
);
}
);
}
finally {
if ($error) {
$c->flash( error => 'Something went wrong Updating the User' );
$c->app->log->warn( Dumper $error );
}
else {
$c->flash( success => 'Updated User' );
}
}
}
elsif ( $user->type eq 'organisation' ) {
try {
$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'),
(
defined $location
? (%$location)
: ( latitude => undef, longitude => undef )
),
}
);
$user->update(
{
email => $validation->param('email'),
(
defined $validation->param('new_password')
? ( password =>
$validation->param('new_password') )
: ()
),
}
);
}
);
}
finally {
if ($error) {
$c->flash( error => 'Something went wrong Updating the User' );
$c->app->log->warn( Dumper $error );
}
else {
$c->flash( success => 'Updated User' );
}
}
}
$c->redirect_to( '/admin/users/' . $id );
return 1;
}
1;