Skip to content
Snippets Groups Projects
README.txt 3.48 KiB
Newer Older
Full HTML documentation is available at http://lsc-project.org/

===== What is LSC? =====
Ldap Synchronization Connector reads from any data source including databases,
LDAP directories or files and transforms and compares this data to an LDAP
directory. These connectors can then be used to continuously synchronize a data
source to a directory, for a one shot import or just to compare differences by
outputting CSV or LDIF format reports.

LSC offers a powerful transformation engine, based on a scripting language, to
easily manipulate data on the fly.

Various identity management functions are included for directory-specific
compatibility - most notably Active Directory (changing passwords, account
status, last logon, etc ...). 

LSC is an open source project written in Java, available under the BSD license.


===== Philosophy =====

Make it possible: The main goal is to provide a simple and efficient way of
synchronizing any data source to a LDAP directory quickly.

Make it stable and safe: Many companies use home-grown scripts for this kind of
synchronization. LSC is an open source tool, and all the bugs you might write in
your scripts have been fixed already (and a few more). The code is in use
worldwide and is heavily tested. Simply put, LSC is about not reinventing the
wheel to synchronize data.

Make it faster and simpler: The added-value of LSC resides in the focus on
identity management tools - common transformations and directory-specific
behaviour come as part of the software. These functions are extensible to
include your own, to integrate into your existing infrastructure. Save time, by
reusing!


===== Feature overview =====

* Multiple source connectors: any LDAPv3 server, any database with a JDBC
  connector, flat files (or anything else you write a connector for)
* Support for LDAPv3 niceties and extensions: StartTLS, LDAPS, paged results,
  schema retrieval, LDAP Sync (rfc4533), LDAP persistent search
* Graphical setup wizard (use is optional)
* Fully configurable through plain text configuration files
* Written in Java, leveraging the ecosystem of available tools
* Simple wrapper shell scripts are provided, to ease use and system integration
* Runs on any Java-enabled platform - tested on Windows, Linux and MacOS X
* Simple attribute mapping from source to destination
* Three policies to update attributes, including forcing values, non-destructive
  updates and merging
* Advanced attribute manipulation via a built-in JavaScript engine
* Predefined libraries for use in JavaScript attribute manipulation:
	- LDAP server tools: standard bind operation can be checked on any
	  LDAPv3 server
	- Active Directory tools: password update (unicodePwd attribute),
	  account type and status manipulation (userAccountControl), unused
	  account detection (lastLogonTimestamp)
	- String manipulation: formatting for common tasks in identity
	  management, such as capitalizing first letters in a complex name,
	  filtering accents for login names, etc …
	- Security tools: password hashing, bi-directional encryption
* Conditions to only create, update, rename or delete entries depending on
  current values
* Detailed and configurable logging in LDIF (fully RFC-compliant) and CSV
  formats	
* Monitoring plugin for Nagios
* Possibility to extend any Java class to implement your own specific
  synchronization needs


===== Read more =====

Find more documentation, tutorials at http://lsc-project.org/.

Join us on IRC in #lsc-project on Freenode, or on mailing lists at
http://lists.lsc-project.org.