Skip to content

Commit

Permalink
Remove OpenLDAP conf
Browse files Browse the repository at this point in the history
  • Loading branch information
melaniekung committed Mar 12, 2024
1 parent 238d60f commit 7b287f5
Show file tree
Hide file tree
Showing 4 changed files with 1 addition and 115 deletions.
2 changes: 1 addition & 1 deletion admin-manual/customization/authentication.rst
Original file line number Diff line number Diff line change
Expand Up @@ -155,7 +155,7 @@ Enabling LDAP authentication in AtoM requires manually installing the LDAP exten
and editing a few AtoM configuration files. For more general information on how
to do this, see :ref:`Manage AtoM configuration files <customization-config-files>`.

First, we'll need to make install the php LDAP extension:
First, we'll need to install the php LDAP extension:

.. code-block:: bash
Expand Down
114 changes: 0 additions & 114 deletions dev-manual/env/compose.rst
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,6 @@
Docker Compose
==============

.. |gears| image:: images/gears.png
:height: 18
:width: 18

Linux containers and Docker have radically changed the way applications are
developed, built, distributed and deployed. The AtoM team is experimenting
with new workflows that make use of containers. This document introduces our
Expand Down Expand Up @@ -94,10 +90,6 @@ It's time to use Docker Compose in order to provision our containers:
latest version before creating the containers. It has to be based on Alpine
v3.8 or higher to be able to install some packages.

.. NOTE::

To enable LDAP authentication with Docker, please skip to :ref:`docker-ldap-auth`.

.. code-block:: bash
# Create and start containers. This may take a while the first time you run
Expand Down Expand Up @@ -203,112 +195,6 @@ stop and remove related containers, network and volumes by running:
docker-compose down --volumes
.. _docker-ldap-auth:

LDAP Authentication
===================

Docker Configuration
++++++++++++++++++++

To enable LDAP authentication using docker, we need to create two new files and
update the existing ``docker-compose.dev.yml`` file. These files are required to
create a network for LDAP and to configure users for LDAP.

First, create a custom network for authentication in a new file called
``docker-compose.auth-network.yml`` and put it in the ``docker`` directory. Copy the
following into the file:

.. code-block:: bash
networks:
default:
name: auth-network
external: true
Then set up docker compose to use the new network by appending the following to
the end of the existing ``docker-compose.dev.yml`` file:

.. code-block:: bash
networks:
auth-network:
name: auth-network
Lastly, configure LDAP credentials in a LDAP Data Interchange Format (LDIF) file,
let's call it ``config-ldap.ldif``. The following example creates 1 user, ``example``, with
Administrator permissions. Please refer to the
`LDAP documentation <https://ldap.com/ldif-the-ldap-data-interchange-format/>`__ for more help.

.. code-block:: bash
dn: cn=example,ou=People,dc=example,dc=org
objectClass: person
objectClass: inetOrgPerson
sn: example
cn: example
mail: [email protected]
userpassword: example
dn: ou=Groups,dc=example,dc=org
objectClass: organizationalUnit
ou: Groups
dn: cn=Administrator,ou=Groups,dc=example,dc=org
objectClass: groupOfNames
cn: Administrator
member: cn=example,ou=People,dc=example,dc=org
Finally, we can start AtoM using ``auth-network``:

``docker compose -f docker-compose.yml -f docker/docker-compose.auth-network.yml up -d``

AtoM Configuration
++++++++++++++++++

.. SEEALSO::

* :ref:`ldap-enabling`

To enable LDAP Authentication, change the ``myUser`` value to ``ldapUser`` in
``config/factories.yml``:

.. code-block:: bash
user:
class: ldapUser
Clear cache and restart ``atom_worker`` for the changes to appear. After doing so,
a new configuration section will be available in |gears| **Admin > Settings**,
where you can define your LDAP authentication settings:

.. image:: images/ldap-config.*
:align: center
:width: 90%
:alt: An image of the LDAP authentication settings

To determine the Host IP for this example based on your docker configuration, run
``docker inspect auth-network`` to determine the Host IP (``IPv4Address``) used
for ``openldap``.

.. NOTE::

The Host IP value is dynamic and may be different each time.

Other values that we will use for this example are as follows:

- Port: 389
- Base DN: ou=People,dc=example,dc=org
- Bind Lookup Attribute: cn

.. NOTE::

Although we've defined the openldap port to ``1389`` in ``docker-compose.dev.yml``,
``LDAP_PORT`` should still be running on port ``389``. This can be confirmed
by running ``docker compose logs openldap``, and you should be able to see the
defined ``LDAP_PORT``.


Connect to AtoM
===============

Expand Down
Binary file removed dev-manual/env/images/gears.png
Binary file not shown.
Binary file removed dev-manual/env/images/ldap-config.png
Binary file not shown.

0 comments on commit 7b287f5

Please sign in to comment.