ldap-api is a small read-only Ruby Rack application intended to be a REST service providing access to users and groups stored in a LDAP backend with optional caching configuration.
For conveninence we named current version as number 1 to be prepared if a meaningfull change in future releases will not affect your installed applications using v1 service.
This fact means that every request to services provided will need to be prefixed with:
/v1
This API will return all results in JSON format
/:version/users
Returns a list of users from LDAP. List might be truncated if LDAP server limits response size
Example Response:
[
{
"uid": "NEBELUNg",
"manager": {
"rdns": [
{
"uid": "oJosazuLEs"
},
{
"ou": "People"
},
{
"dc": "kittens"
},
{
"dc": "net"
}
]
},
"mail": "[email protected]",
"employeenumber": "000001",
"uidnumber": 20244
},
{
"uid": "pixiebob",
"manager": {
"rdns": [
{
"uid": "balinese"
},
{
"ou": "People"
},
{
"dc": "kittens"
},
{
"dc": "net"
}
]
},
"mail": "[email protected]",
"employeenumber": "000002",
"uidnumber": 20245
}
]
This service only receives one parameter named filter which will be used to filter users by specified attributes in config file, using special character * (asterisk) as wildcard character
An example list of users whose name begins with chrod is issued by the following URL:
http://SERVER_NAME/API_BASE/v1/users?filter=chrod*
See documentation section to configure filtering attributes for users
/:version/users/:username
Return a single user maching specified username
/:version/users/:username/groups
Returns a list of groups specified username is member of
/:version/groups
Returns a list of groups from LDAP. List might be truncated if LDAP server limits response size
This service only receives one parameter named filter which will be used to filter gorups by specified attributes in config file, using special character * (asterisk) as wildcard character
An example list of groups whose name begins with vpn is issued by the following URL:
http://SERVER_NAME/API_BASE/v1/groups?filter=vpn*
See documentation section to configure filtering attributes for users
/:version/groups/:name/members
Returns a list of users that are members of specified group
This simple RACK application is configured using a yml file. This file should be named config/config.yml
.
This application requires two environment variables to be set:
export LDAP_PASSWORD=<password>
- The password to use for API -> LDAP authenticationexport CONFIG_PATH=config/config.example.yml
- The path to the configuration file
Now all configuration is done in the config/config.yml
file from here on out.
Here is an example configuration file that the API uses:
ldap:
cache:
ttl: 3600 # cache ttl in seconds
limit_results: -1 # -1 for no limit - the number of results to return from LDAP
connection:
host: "localhost" # LDAP server host
port: 389 # LDAP server port (389 is default, 636 is for LDAPS)
base: dc=kittens,dc=net # LDAP base DN
bind_dn: uid=emmy,ou=Service_Accounts,dc=kittens,dc=net # LDAP bind DN when making a connection
# password: kittens !deprecated! # Please use the environment variable LDAP_PASSWORD
# method: :plain # :ssl, :tls, :plain allowed # Please let ActiveLdap decide for you
user:
dn_attribute: uid
prefix: ou=People
classes:
- organizationalPerson
filter: (|(uid=%s)) # attributes you can query string filter on ex: /users?filter=chrod*
attributes:
uid: uid
# sn: sn
# givenname: givenname
# cn: cn
uidnumber: uidnumber
group:
dn_attribute: cn
member_attribute: uniquemember
user_membership_attribute: dn
classes:
- groupOfUniqueNames
attributes:
cn: name
A sample configuration file is provided in the config
directory.
ttl
: is a time in seconds to cache results in memory by server, without quering LDAP for same result just queried
Once you have configured caching, you will see the Cache-Ttl
header in responses from the API. This header indicates how much longer in seconds the response will be cached for.
limit_results
: numbers of entries to return when searching users or groups. If removed, limit is not set and all entries are returned or limited by server
host
: LDAP host serverport
: LDAP port. Default is389
for LDAP and636
for LDAPSbase
: LDAP base dnbind_dn
: LDAP user to bind into LDAP asallow_anonymous
: if specified anonymous access to LDAP will be used
dn_attribute
: attribute used as dn: for example uid or cnprefix
: prefix where users reside. If omited, ldap.base will be usedclassess
: array of objectclass retrieved users must meet. Array elements must be listed in separate lines prefixed with minus signfilter
: filter to be used when filtering user listingattributes
: attribute mapping array. You must define a dictionary (hash) of attribute mappings from LDAP attribute name on the left, to a service name attribute on the right. In the given example above, you can see that cn ldap attribute will be retrieved as display_name by rest service
dn_attribute
: attribute used as dn: for example cnprefix
: prefix where groups reside. If omited, ldap.base will be usedclassess
: array of objectclass retrieved groups must meet. Array elements must be listed in separate lines prefixed with minus signmember_attribute
: attribute used by ldap groups to specify members. For example: memberuser_membership_attribute
: attribute used by group membership to reference a user. For example: dn means users are specified as full dnfilter
: filter to be used when filtering group listingattributes
: attribute mapping array. You must define a dictionary (hash) of attribute mappings from LDAP attribute name on the left, to a service name attribute on the right. In the given example above, you can see that cn ldap attribute will be retrieved as name by rest service
To run this application, do the following:
- Ensure that you have a
config/config.yml
file with all the correct settings - Run
script/bootstrap
to install all dependencies - Run
script/server
to start the server
Your application will now be running at localhost:8080
and you can begin making requests to it.
To test locally, this project comes with a pre-configured docker-compose.yml
file with a mock LDAP server. To test locally with this mock server, do the following:
- Run
script/bootstrap
to install all dependencies - Use the
config/config.example.yml
file included in this project with all of its defaults (no need to change anything at all here). Now set the following environment variables to use this file:export LDAP_PASSWORD=kittens
export CONFIG_PATH=config/config.example.yml
- Run
make run
to spin up the docker-compose stack - Run
script/server
to start the API server - Make requests to
localhost:8080
and get back mock data - get users example