Add ldap container
This commit is contained in:
parent
ade9cd5547
commit
bfe9eb4694
|
@ -0,0 +1,21 @@
|
|||
FROM flitter/init
|
||||
MAINTAINER Nick Stenning <nick@whiteink.com>
|
||||
|
||||
ENV HOME /root
|
||||
|
||||
# Use baseimage-docker's init system.
|
||||
CMD ["/sbin/my_init"]
|
||||
|
||||
# Configure apt
|
||||
RUN apt-get -y update &&\
|
||||
LC_ALL=C DEBIAN_FRONTEND=noninteractive apt-get install -y slapd &&\
|
||||
apt-get clean && rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
|
||||
|
||||
# Default configuration: can be overridden at the docker command line
|
||||
ENV LDAP_ROOTPASS toor
|
||||
ENV LDAP_ORGANISATION Acme Widgets Inc.
|
||||
ENV LDAP_DOMAIN example.com
|
||||
|
||||
EXPOSE 389
|
||||
|
||||
ADD slapd.sh /etc/service/slapd/run
|
|
@ -0,0 +1,38 @@
|
|||
## slapd
|
||||
|
||||
A basic configuration of the OpenLDAP server, slapd, with support for data
|
||||
volumes.
|
||||
|
||||
This image will initialize a basic configuration of slapd. Most common schemas
|
||||
are preloaded (all the schemas that come preloaded with the default Ubuntu
|
||||
Precise install of slapd), but the only record added to the directory will be
|
||||
the root organisational unit.
|
||||
|
||||
You can (and should) configure the following by providing environment variables
|
||||
to `docker run`:
|
||||
|
||||
- `LDAP_DOMAIN` sets the LDAP root domain. (e.g. if you provide `foo.bar.com`
|
||||
here, the root of your directory will be `dc=foo,dc=bar,dc=com`)
|
||||
- `LDAP_ORGANISATION` sets the human-readable name for your organisation (e.g.
|
||||
`Acme Widgets Inc.`)
|
||||
- `LDAP_ROOTPASS` sets the LDAP admin user password (i.e. the password for
|
||||
`cn=admin,dc=example,dc=com` if your domain was `example.com`)
|
||||
|
||||
For example, to start a container running slapd for the `mycorp.com` domain,
|
||||
with data stored in `/data/ldap` on the host, use the following:
|
||||
|
||||
docker run -v /data/ldap:/var/lib/ldap \
|
||||
-e LDAP_DOMAIN=mycorp.com \
|
||||
-e LDAP_ORGANISATION="My Mega Corporation" \
|
||||
-e LDAP_ROOTPASS=s3cr3tpassw0rd \
|
||||
-d nickstenning/slapd
|
||||
|
||||
You can find out which port the LDAP server is bound to on the host by running
|
||||
`docker ps` (or `docker port <container_id> 389`). You could then load an LDIF
|
||||
file (to set up your directory) like so:
|
||||
|
||||
ldapadd -h localhost -p <host_port> -c -x -D cn=admin,dc=mycorp,dc=com -W -f
|
||||
data.ldif
|
||||
|
||||
**NB**: Please be aware that by default docker will make the LDAP port
|
||||
accessible from anywhere if the host firewall is unconfigured.
|
|
@ -0,0 +1,42 @@
|
|||
#!/bin/sh
|
||||
|
||||
set -eu
|
||||
|
||||
status () {
|
||||
echo "---> ${@}" >&2
|
||||
}
|
||||
|
||||
set -x
|
||||
: LDAP_ROOTPASS=${LDAP_ROOTPASS}
|
||||
: LDAP_DOMAIN=${LDAP_DOMAIN}
|
||||
: LDAP_ORGANISATION=${LDAP_ORGANISATION}
|
||||
|
||||
if [ ! -e /var/lib/ldap/docker_bootstrapped ]; then
|
||||
status "configuring slapd for first run"
|
||||
|
||||
cat <<EOF | debconf-set-selections
|
||||
slapd slapd/internal/generated_adminpw password ${LDAP_ROOTPASS}
|
||||
slapd slapd/internal/adminpw password ${LDAP_ROOTPASS}
|
||||
slapd slapd/password2 password ${LDAP_ROOTPASS}
|
||||
slapd slapd/password1 password ${LDAP_ROOTPASS}
|
||||
slapd slapd/dump_database_destdir string /var/backups/slapd-VERSION
|
||||
slapd slapd/domain string ${LDAP_DOMAIN}
|
||||
slapd shared/organization string ${LDAP_ORGANISATION}
|
||||
slapd slapd/backend string HDB
|
||||
slapd slapd/purge_database boolean true
|
||||
slapd slapd/move_old_database boolean true
|
||||
slapd slapd/allow_ldap_v2 boolean false
|
||||
slapd slapd/no_configuration boolean false
|
||||
slapd slapd/dump_database select when needed
|
||||
EOF
|
||||
|
||||
dpkg-reconfigure -f noninteractive slapd
|
||||
|
||||
touch /var/lib/ldap/docker_bootstrapped
|
||||
else
|
||||
status "found already-configured slapd"
|
||||
fi
|
||||
|
||||
status "starting slapd"
|
||||
set -x
|
||||
exec /usr/sbin/slapd -h "ldap:///" -u openldap -g openldap -d 0
|
Loading…
Reference in New Issue