É possível utilizar uma parte do pedido URI como um contributo para o mod_authnz_ldap Require ldap-group
directiva?
Estou tentando verificar dinamicamente o acesso a vários diretórios de projetos diferentes, todos em http://testserver.com/projects/ , para que um usuário acessando /projects/abc
seja verificado quanto à associação cn=abc,ou=groups,dc=test
. Idealmente, eu gostaria de fazer isso sem criar uma diretiva Location separada para cada projeto, pois pode haver centenas delas.
Eu vim com isso, que ilustra o conceito geral, mas que não funciona (project_name não recupera o conteúdo real da variável):
<Location /projects>
SetEnvIf Request_URI "/projects/([-a-z0-9A-Z_]+)/" project_name=$1
AuthType Basic
AuthBasicProvider ldap
AuthName "Restricted Resource - SVN (LDAP)"
AuthLDAPURL "ldap://127.0.0.1:389/dc=test?uid"
AuthLDAPGroupAttributeIsDN off
AuthLDAPGroupAttribute memberUid
Require ldap-group cn=%{project_name},ou=groups,dc=test
</Location>
Socorro?
Respostas:
Acredito que o Apache 2.4 tenha mais a oferecer nesta área do que 2,2 ... pode valer a pena olhar.
Como alternativa, pode valer a pena procurar criar seu próprio módulo personalizado; não é tão assustador quanto parece - supondo que você esteja confortável em C.
Da mesma forma, o mod_perl não oferece muito em estender o Apache através de ganchos?
fonte
Você pode tentar adicionar um filtro ao parâmetro AuthLDAPURL: https://httpd.apache.org/docs/2.4/en/mod/mod_authnz_ldap.html#authldapurl
Talvez algo como:
fonte