Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/lsc-project/lsc

LSC engine
https://github.com/lsc-project/lsc

etl identity-management ldap ldap-synchronization-connector

Last synced: about 2 months ago
JSON representation

LSC engine

Awesome Lists containing this project

README

        

# LDAP Synchronization Connector

[![Build Status](https://github.com/lsc-project/lsc/actions/workflows/maven.yml/badge.svg)](https://github.com/lsc-project/lsc/actions/workflows/maven.yml)

Full HTML documentation is available at https://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 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 Script engine (include
support for JavaScript and Groovy scripting languages)
* 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 https://lsc-project.org/.

Join us on IRC in #lsc-project on Libera Chat, or on mailing lists on OW2 server,
see https://lsc-project.org/community#mailing_lists.