2017 © Pedro Peláez
 

library acl

Biblioteca para gerenciar acessos a sistemas

image

toneladas/acl

Biblioteca para gerenciar acessos a sistemas

  • Sunday, February 26, 2017
  • by vanildosouto
  • Repository
  • 1 Watchers
  • 0 Stars
  • 41 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 2 Versions
  • 3 % Grown

The README.md

ACL

Biblioteca para manipular acesso de usuário a sistemas, (*1)

USO

Instalação

composer require toneladas/acl, (*2)

Configurando

Você pode usar a biblioteca usando uma conexão PDO "pura"* ou usando uma entidade da Doctrine., (*3)

A biblioteca utiliza as funções password_hash e password_verify, então ao salvar os dados do usuário no banco, utilize essas funções., (*4)

Usando PDO "pura"

Configure a conexão usando setWithDatabase:, (*5)

<?php

$conn = new \PDO('sqlite::memory:');

$acl = new \Toneladas\Acl();
$acl->setWithDatabase($conn); // Objeto da PDO usado para conexão no banco de dados
$acl->setTable('usuarios'); // Nome da tabela usada no banco para guardar os usuários
$acl->setFieldUser('email'); // Nome do campo na tabela usado como o nome do usuário
$acl->setFieldPassword('senha'); // Nome do campo na tabela usado como a senha do usuário

Usando uma entidade Doctrine

Configure a conexão usando setWithDoctrine:, (*6)

<?php

$acl = new \Toneladas\Acl();
$this->acl->setWithDoctrine($entityManager); // Instancia do EntityManager do Doctrine
$this->acl->setEntity('\tests\Entities\User'); // Nome da entidade que refere-se a tabela de usuarios
$this->acl->setFieldUser('user'); // Nome no campo na tabela usado como o nome do usuário
$this->acl->setMethodPassword('getPassword'); // Metodo da entidade para pegar a senha

Você também pode configurar que o usuário é um email, assim a biblioteca irá verificar se o email vindo do formulário é válido:, (*7)

<?php

$acl->isEmail();

$acl->verify('usuario', '123'); // Irá jogar uma exception, pois 'usuario' não é um endereço de email válido

Verificando

Para verificar se o usuário e senha estão corretos, passe os dados vindo do formulários como parametros do método verify:, (*8)

<?php

try {
  $acl->verify($usuario, $senha);

  // Deu tudo certo, seguimos em frente
} catch (\Exception $exp) {
  // Alguma coisa deu errada
}

Ele pode retornar três Exceptions:, (*9)

  • \Toneladas\Exceptions\UserWrongException: Usuário passado não foi encontrado no banco
  • \Toneladas\Exceptions\PasswordWrongException: A senha informada está errada
  • \Toneladas\Exceptions\EmailInvalidException: Caso tenha configurado a verificação de usuário como um email

Você pode ainda tratar as exceptions diferente para cada situação:, (*10)

<?php

try {
  $acl->verify($usuario, $senha);

  // Deu tudo certo, seguimos em frente
} catch (\Toneladas\Exceptions\UserWrongException $exp) {
  // O usuário não foi encontrado, então faço alguma coisa
} catch (\Toneladas\Exceptions\PasswordWrongException $exp) {
  // A senha está incorreta, então faço outra coisa
}

Lembrando que é boa prática não informar ao usuário qual dos dois deu errado, mas só informar que ocorreu um erro, (*11)

* Eu sei que o Doctrine também usa a PDO para conexão com o banco, (*12)

Licença

Licenciado sobre a licença MIT

Veja o arquivo LICENSE para mais detalhes., (*13)

The Versions

26/02 2017

dev-master

9999999-dev

Biblioteca para gerenciar acessos a sistemas

  Sources   Download

MIT

The Requires

  • php >=5.5

 

The Development Requires

by Vanildo Souto Mangueira

acl library security

26/02 2017

v1.0.0

1.0.0.0

Biblioteca para gerenciar acessos a sistemas

  Sources   Download

MIT

The Requires

  • php >=5.5

 

The Development Requires

by Vanildo Souto Mangueira

acl library security