Mojolicious-Plugin-ContextAuth
view release on metacpan or search on metacpan
lib/Mojolicious/Plugin/ContextAuth/DB/Context.pm view on Meta::CPAN
my $error;
try {
$self->dbh->db->insert( corbac_contexts => \%params);
}
catch {
$self->error( 'Invalid parameter' );
$error = $_;
};
return if $error;
my $context = $self->load( $params{context_id} );
return $context;
}
sub delete ($self, $id = $self->context_id) {
$self->error('');
if ( !$id ) {
$self->error( "Need context id" );
return;
}
if ( ref $id ) {
$self->error( "Invalid context id" );
return;
}
my $result;
my $error;
try {
my $tx = $self->dbh->db->begin;
$self->dbh->db->delete(
corbac_roles => { context_id => $id },
);
$self->dbh->db->delete(
corbac_user_context_roles => { context_id => $id }
);
$result = $self->dbh->db->delete(
corbac_contexts => {
context_id => $id,
}
);
$tx->commit;
}
catch {
$self->error( "Cannot delete context: " . $_ );
$error = 1;
};
return if $error;
return $result->rows;
}
sub update ($self, @params) {
$self->error('');
my $id = @params % 2 ? shift @params : $self->context_id;
my %to_update = @params;
if ( exists $to_update{context_name} && (
length $to_update{context_name} > 255 ||
length $to_update{context_name} < 3 )
) {
$self->error( 'Invalid parameter' );
return;
}
delete $to_update{context_id};
my $result;
my $error;
try {
$result = $self->dbh->db->update(
corbac_contexts => \%to_update,
{ context_id => $id }
);
}
catch {
$self->error( 'Invalid parameter' );
$error = $_;
};
return if $error;
if ( !$result->rows ) {
$self->error( 'No context updated' );
return;
}
return $self->load( $id );
}
sub search ($self, %params) {
$self->error('');
my $error;
my @context_ids;
try {
my $result = $self->dbh->db->select(
corbac_contexts => ['context_id'] => \%params,
);
while ( my $next = $result->hash ) {
push @context_ids, $next->{context_id};
}
}
catch {
$self->error('Cannot search for contexts');
$error = $_;
};
return if $error;
return @context_ids;
( run in 0.629 second using v1.01-cache-2.11-cpan-0bb4e1dffa6 )