This project provides the simple alfresco with kerberos enabled env for testing purposes.
- Run the environment
- Configure kerberos client against the environment
- Configure browser to support the kerberos authentication
- Open the application url
To run the environment, use the start.sh shell script.
./start.sh # start the docker compose created env
Try to execute the startsh shell script to run the environment. click here for example logs
- ACS - comes with 2 days free license
- APS - keep the licence inside
process-services/license
folder
- update the OS hosts file
<docker machine ip> example.com
or dns for docker-compose toexample.com
- install the kerberos client
sudo apt-get install krb5-user
- update the configuration to reach the docker compose server ⬇️
Add/update the file /etc/krb5.conf
[libdefaults]
default_realm = EXAMPLE.COM
ignore_acceptor_hostname = true
[realms]
EXAMPLE.COM = {
kdc = example.com:88
admin_server = example.com:749
}
[domain_realm]
.example.com = EXAMPLE.COM
example.com = EXAMPLE.COM
kinit <optional username>
# login with system user or give userklist
# list the available session
Here is command for chrome with kerberos. read here for other browser
google-chrome --auth-server-whitelist="http://example.com" --auth-negotiate-delegate-whitelist="http://example.com" http://example.com/workspace
Below table provide info about scaffold users
Username | Password |
---|---|
alice | password |
bob | password |
dhrn | password |
administrator | password |
Creating volume "alfresco-kerberos_vol-openldap-ldap" with default driver
Creating volume "alfresco-kerberos_vol-openldap-slapd" with default driver
Creating volume "alfresco-kerberos_shared-file-store-volume" with default driver
Creating alfresco-kerberos_elasticsearch_1 ... done
Creating workspace ... done
Creating alfresco-kerberos_postgres_1 ... done
Creating alfresco-kerberos_activemq_1 ... done
Creating alfresco-kerberos_shared-file-store_1 ... done
Creating alfresco-kerberos_postgres-process_1 ... done
Creating alfresco-kerberos_solr6_1 ... done
Creating openldap ... done
Creating alfresco ... done
Creating kerberos ... done
Creating alfresco-kerberos_transform-router_1 ... done
Creating alfresco-kerberos_transform-core-aio_1 ... done
Creating process ... done
Creating share ... done
Creating proxy ... done
======== wait for ldap and kerberos sync ========
======== indexing the LDAP user with Kerberos ========
Authenticating as principal root/[email protected] with password.
WARNING: no policy specified for [email protected]; defaulting to no policy
Principal "[email protected]" created.
Authenticating as principal root/[email protected] with password.
WARNING: no policy specified for [email protected]; defaulting to no policy
Principal "[email protected]" created.
Authenticating as principal root/[email protected] with password.
WARNING: no policy specified for [email protected]; defaulting to no policy
Principal "[email protected]" created.
Authenticating as principal root/[email protected] with password.
WARNING: no policy specified for [email protected]; defaulting to no policy
Principal "[email protected]" created.
======== create kerberos principles for server ========
Authenticating as principal root/[email protected] with password.
WARNING: no policy specified for HTTP/[email protected]; defaulting to no policy
Principal "HTTP/[email protected]" created.
Authenticating as principal root/[email protected] with password.
Entry for principal HTTP/[email protected] with kvno 2, encryption type aes256-cts-hmac-sha1-96 added to keytab WRFILE:example.keytab.
Entry for principal HTTP/[email protected] with kvno 2, encryption type aes128-cts-hmac-sha1-96 added to keytab WRFILE:example.keytab.
======== available principles in the kerberos ========
Authenticating as principal root/[email protected] with password.
[email protected]
[email protected]
[email protected]
[email protected]
HTTP/[email protected]
K/[email protected]
krbtgt/[email protected]
kadmin/[email protected]
kadmin/[email protected]
kiprop/[email protected]
kadmin/[email protected]
kadmin/[email protected]
======== configure the Alfresco with Kerberos ========
Restarting alfresco ... done
Restarting process ... done
======== kerberos configuration is over ========
usefull commands :
docker logs -f process
docker logs -f alfresco
docker exec -it process sh
docker exec -it alfresco sh
======== completed ========
If you are facing any issues with kerberos, just try to rerun the ./start.sh
Sometime kerberos server fails to start becase of port issue, check it before retrying
BaseDn: cn=admin,dc=example,dc=com
Password: admin
Review permissions of volume mounts to ensure file permissions are at least 644.
# Start services using Docker Compose
docker-compose up
# Verify valid keytab file generated
docker exec kerberos kinit HTTP/[email protected] -k -t /etc/keytabs/alfresco.keytab
# List and destroy Kerberos ticket
docker exec kerberos klist
docker exec kerberos kdestroy
# Verify permissions of shared keytab file to ensure it can be read by Keycloak
docker exec --user root alfresco chmod 644 /etc/keytabs/alfresco.keytab
Creating users is now a two-step process:
-
Create new user with ldapadd.
-
Create new KDC entry using
addprinc
(for Kerberos Authentication) and link it to the DN. E.g.:docker exec -ti kerberos kadmin.local -q "addprinc -pw password -x dn=uid=alice,ou=People,dc=example,dc=com alice" docker exec -ti kerberos kadmin.local -q "addprinc -pw password -x dn=uid=alice,ou=People,dc=example,dc=com bob"
Run the following commands in
kerberos
container:docker exec -it kerberos bash
Default password forldapsearch
command is provided using-w
flag. Use-W
for interactive password prompt.
# Verify LDAP credentials
ldapwhoami -x -D "cn=admin,dc=example,dc=com" -w admin
ldapwhoami -x -D "uid=alice,ou=People,dc=example,dc=com" -w password
# Verify krbContainer container exists (numEntries: 1)
ldapsearch -L -x -D cn=admin,dc=example,dc=com -b dc=example,dc=com -w admin cn=krbContainer
# Verify ACL for kdc-service and kadmin-service (numEntries: 12)
ldapsearch -L -x -D uid=kdc-service,dc=example,dc=com -b cn=krbContainer,dc=example,dc=com -w password
ldapsearch -L -x -D uid=kadmin-service,dc=example,dc=com -b cn=krbContainer,dc=example,dc=com -w password
# Verify Kerberos services are started
service krb5-kdc status
service krb5-admin-server status
# Validate Kerberos token can be obtained using keytab file
kinit HTTP/[email protected] -k -t /etc/keytabs/alfresco.keytab
klist
kdestroy
# Cleanup
docker-compose down -v