Skip to content

Implementation of an LDAP server that delegates authentication to an Atlassian Crowd installation using the Crowd REST API.

License

Notifications You must be signed in to change notification settings

akurdyukov/crowd-ldap-server

 
 

Repository files navigation

Crowd LDAP Server

Implementation of an LDAP server that delegates authentication to an Atlassian Crowd installation using the Crowd REST API.

This service allows your favourite SSO authentication source to be used from many legacy devices, appliances and systems.

The LDAP implementation is based on the Apache Directory Server v1.5.7, which is distributed under the Apache v2.0 License.

Configuration

Crowd-LDAP-Server searcher for file crowd-ldap-server.properties in etc directory relative to current working directory. See example in the distro.

Available properties:

Name Description Default
listener.port Port the server listens to 10389
ssl.enabled LDAPS enabled? false
ssl.keystore Path to keystore file etc/crowd-ldap-server.keystore
ssl.certificate.password Certificate password changeit
emulate.ad.memberof emulate ActiveDirectory false
emulate.ad.include.nested emulate nested groups for ActiveDirectory false
map.member.cn
map.member.ou
map.member.dc
map.member.gid

Reference

Build

	mvn package

Configuration

Crowd Server

Password

Addresses

Crowd LDAP Server

vi etc/crowd.properties

#Crowd Server Configuration
session.lastvalidation=session.lastvalidation
session.isauthenticated=session.isauthenticated
application.password=<crowd application password>
application.name=crowd-openid-server
session.validationinterval=0
crowd.server.url=http://127.0.0.1/crowd/services/
session.tokenkey=session.tokenkey
application.login.url=http://127.0.0.1/crowd/console/

Run

./run

Test

➜  crowd-ldap-server git:(master) ldapsearch -x -D 'uid=jira,ou=users,dc=crowd' -W -H ldap://localhost:10389 -b ou=users,dc=crowd uid=jira
ldap_initialize( ldap://localhost:10389/??base )
Enter LDAP Password: 
filter: uid=jira
requesting: All userApplication attributes
# extended LDIF
#
# LDAPv3
# base <ou=users,dc=crowd> with scope subtree
# filter: uid=jira
# requesting: ALL
#

# jira, users, crowd
dn: dn=jira,ou=users,dc=crowd
uid: jira
sn: jira
mail: jira@...

➜  crowd-ldap-server git:(master) ✗ ldapsearch -x -D "uid=jira,ou=users,dc=crowd" -W -H ldap://localhost:10389 -b 'ou=users,dc=crowd' '(uid=liyan)' uid displayName mail cn
Enter LDAP Password: 
# extended LDIF
#
# LDAPv3
# base <ou=users,dc=crowd> with scope subtree
# filter: (uid=liyan)
# requesting: uid displayName mail cn 
#

# liyan, users, crowd
dn: dn=liyan,ou=users,dc=crowd
uid: liyan
mail: [email protected]
cn:: 5p2OIOeEsQ==

# search result
search: 2
result: 0 Success

# numResponses: 2
# numEntries: 1

About

Implementation of an LDAP server that delegates authentication to an Atlassian Crowd installation using the Crowd REST API.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Java 96.5%
  • Shell 2.9%
  • Batchfile 0.6%