Mojolicious-Plugin-ContextAuth

 view release on metacpan or  search on metacpan

lib/Mojolicious/Plugin/ContextAuth/DB/Resource.pm  view on Meta::CPAN


    my $error;
    try {
        $self->dbh->db->insert( corbac_resources => \%params);
    } 
    catch {
        $self->error( 'Invalid parameter' );
        $error = $_;
    };

    return if $error;

    my $resource = $self->load( $params{resource_id} );
    return $resource;
}

sub delete ($self, $id = $self->resource_id) {
    $self->error('');
    
    if ( !$id ) {
        $self->error( "Need resource id" );
        return;
    }

    if ( ref $id ) {
        $self->error( "Invalid resource id" );
        return;
    }

    my $error;
    my $result;
    
    try {
        my $tx = $self->dbh->db->begin;

        $self->dbh->db->delete(
            corbac_role_permissions => { resource_id => $id },
        );

        $self->dbh->db->delete(
            corbac_permissions => { resource_id => $id }
        );

        $result = $self->dbh->db->delete(
            corbac_resources => {
                resource_id => $id,
            }
        );

        $tx->commit;
    }
    catch {
        $self->error( "Cannot delete resource: " . $_ );
        $error = 1;
    };

    return if $error;
    return $result->rows;
}

sub update ($self, @params) {
    $self->error('');
    
    my $id = @params % 2 ? shift @params : $self->resource_id;
    my %to_update = @params;

    if ( exists $to_update{resource_name} && (
        length $to_update{resource_name} > 255 ||
        length $to_update{resource_name} < 3
     ) ) {
        $self->error( 'Invalid parameter' );
        return;
    }

    delete $to_update{resource_id};

    my $result;
    my $error;
    try {
        $result = $self->dbh->db->update(
            corbac_resources => \%to_update,
            { resource_id => $id }
        );
    }
    catch {
        $self->error( 'Invalid parameter' );
        $error = $_;
    };

    return if $error;
    return $self->load( $id );
}

sub search ($self, %params) {
    $self->error('');

    my $error;
    my @resource_ids;

    try {
        my $result = $self->dbh->db->select(
            corbac_resources => ['resource_id'] => \%params,
        );

        while ( my $next = $result->hash ) {
            push @resource_ids, $next->{resource_id};
        }
    }
    catch {
        $self->error('Cannot search for resources');
        $error = $_;
    };

    return if $error;
    return @resource_ids;
}

1;

=pod



( run in 1.020 second using v1.01-cache-2.11-cpan-0bb4e1dffa6 )