Textos com a tag: acl
phpGACL
23.09.2008 | php
Tags: acl, dicas, php
Um dia depois de eu atualizar o blog, o Rafael me mandou um link pro phpGACL, uma ferramente Genérica de controle de acessos em PHP. Sendo genérica, não importa se você utiliza alguma framework ou se desenvolve PHP na unha, é só incluir a classe e utilizar.
Ao contrário da ACL do Cake, ela é muito melhor documentada e bem mais complexa, mas nem por isso menos simples. Vem com instalador, suporta praticamente todos os bancos de dados (foi desenvolvido utilizando o ADOdb) e ainda possui uma interface de administração.
No pacote vem um manual explicando o conceito da ACL (aqui eles utilizam os personagens de Star Wars) e a documentação da API das classes para referência.
Nesse link tem um tutorial de instalação de um pacote para integrar o phpGACL no CakePHP. Particularmente não fui com a cara desse plugin/componente (talvez pelo fato de ser argentino :P) e preferi fazer a integração na mão e criei meu próprio componente.
Utilizando o ACL no CakePHP
18.09.2008 | CakePHP
Tags: acl, CakePHP, dicas, php
Estamos começando um novo projeto aqui na empresa e para ele decidimos usar o CakePHP como framework de desenvolvimento. Desde semana passada estou estudando a utilização do ACL para controle de acesso às páginas do sistema, mas como muitos devem saber, o book do site do Cake não é tão explicativo quanto deveria. :P
Quer dizer, o exemplo do conceito sendo explicado utilizando os personagens d’O Senhor dos Anéis é sensacional! Mas só serve pra isso mesmo, explicar o conceito. Por que na prática, a coisa é um pouco mais complexa.
Pra tentar entender o funcionamento, criei o blog de exemplo do próprio “Livro de Receitas” do CakePHP. Porém ele é simples demais e nem tem usuários. Então criei uma tabela para armazenar somente um login e senha de acesso. Nada muito difÃcil para quem já mexeu com o Cake pelo menos uma vez.
Aà vem outro problema: por padrão, o ACL vem pronto pra trabalhar com CRUD, e dificilmente teremos um sistema que só utilize os métodos do CRUD. O que fazer então? Depois de dias lendo documentação sobre o assunto, chegou até mim um texto (perdi o link, desculpem. :/) que dizia, resumidamente, que era só associar os actions como ACOs normalmente, e na hora de salvar no banco, dar acesso total nos
Então, supondo que esteja tudo pronto, vamos resolver o grande problema que encontrei nos blogs que li: Os métodos de criação dos AROs e dos ACOs, bem como seus relacionamentos, não devem ficar espalhados pela aplicação. Crie um arquivo PHP separado para executar somente quando você precisar popular o banco de dados com as informações de acesso.
Então vamos começar criando um pequeno script que cria os AROs do nosso “sistema”:
1 2 3 4 5 6 7 8 9 10 | $aro = new aro(); $groups = array( 0 => array( 'alias' => 'Admins' ), 1 => array( 'alias' => 'Authors' ), 2 => array( 'alias' => 'Spammers' ) ); foreach( $groups as $group ) { $aro->create(); $aro->save( $group ); } |
Esse script vai gerar grupos de usuários do sistema. temos os administradores, os autores do blog e spammers, que são usuários que não terão acesso a nada.
Agora vamos criar alguns usuários:
1 2 3 4 5 6 7 8 9 10 | $aro = new aro(); $users = array( 0 => array( 'alias' => Pedro, 'parent_id' => 1 , 'model' => 'User', 'foreign_key' => 1 ), 1 => array( 'alias' => Rafael, 'parent_id' => 2 , 'model' => 'User', 'foreign_key' => 2 ), 2 => array( 'alias' => Adriana, 'parent_id' => 3 , 'model' => 'User', 'foreign_key' => 3 ) ); foreach( $users as $user ) { $aro->create(); $aro->save( $user ); } |
Acima estou criando 3 usuários apenas, um para cada grupo. O campo parent_id aponta para o grupo que o usuário faz parte. O campo model, como o próprio nome diz, especifica um modelo. No caso, ele guarda o nome do modelo que o id armazenado em foreign_key pertence. Então no exemplo acima, o id do Pedro na tabela User é 1.
Agora vamos criar algumas ACOs:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | $aco = new aco(); $group = array( 'alias' => 'Post' ); $aco->create(); $aco->save( $group ); $actions = array( 0 => array( 'alias' => 'index' , 'parent_id' => 1 ), 1 => array( 'alias' => 'view' , 'parent_id' => 1 ), 2 => array( 'alias' => 'add' , 'parent_id' => 1 ), 3 => array( 'alias' => 'delete' , 'parent_id' => 1 ), 4 => array( 'alias' => 'edit' , 'parent_id' => 1 ) ); foreach( $actions as $action ) { $aco->create(); $aco->save( $action ); } |
O processo para criação é exatamente o mesmo do utilizado no ARO. Aqui, primeiro criei um grupo com o nome do próprio controller, assim fica mais fácil organizar. Depois, criei uma ACO para cada action do controller e as relacionei com o grupo criado anteriormente.
Se você não definir nenhum tipo de permissão de acesso, por padrão, é tudo negado. Então vamos definir algumas permissões:
1 2 3 4 | $this->Acl->allow( 'Admins' , 'Post' , '*' ); $this->Acl->allow( 'Authors' , 'Post' , '*' ); $this->Acl->deny( 'Authors' , 'Post/delete' , '*' ); $this->Acl->deny( 'Spammers' , 'Post' , '*' ); |
Na primeira linha, dei acesso total à todas as actions do controller Post para os usuários que fizerem parte do grupo Admins. Na segunda linha, dei acesso total também aos autores do blog, mas na terceira eu tirei a permissão deles de deletar algum post, ou seja, eles podem tudo, menos deletar o texto que escreveram. Assim é mais fácil do que ficar fazendo um allow para cada action do controller. Na quarta linha tirei a permissão de acesso à todas as actions do controller para quem for do grupo spammers.
Para verificar quem tem acesso ou não, dentro do seu controller, no método beforeFilter por exemplo, basta fazer o seguinte:
1 | $this->Acl->check( 'Authors' , 'Post/delete' ) |
No nosso caso vai retornar FALSE.
Basicamente é isso. Tem outras coisas interessantes para se trabalhar junto com o ACL, como o ACLBehavior e o ACL Management Plugin. Uma boa leitura que pode ajudar um bocado é esse tutorial de utilização que um cara fez pro caso dele, tem até um sitezinho de exemplo.
[ 1 ]
