diff --git a/apps/user_ldap/appinfo/app.php b/apps/user_ldap/appinfo/app.php
new file mode 100644
index 0000000000..67b61989f7
--- /dev/null
+++ b/apps/user_ldap/appinfo/app.php
@@ -0,0 +1,39 @@
+.
+*
+*/
+
+require_once('apps/user_ldap/user_ldap.php');
+
+// define LDAP_DEFAULT_PORT
+define("OC_USER_BACKEND_LDAP_DEFAULT_PORT", 389);
+
+// register user backend
+OC_USER::useBackend( "LDAP" );
+
+// add settings page to navigation
+$entry = array(
+ 'id' => "user_ldap_settings",
+ 'order'=>1,
+ 'href' => OC_HELPER::linkTo( "user_ldap", "settings.php" ),
+ 'name' => 'LDAP'
+);
+OC_APP::addNavigationSubEntry( "core_users", $entry);
diff --git a/apps/user_ldap/appinfo/info.xml b/apps/user_ldap/appinfo/info.xml
new file mode 100644
index 0000000000..9a6ee1436f
--- /dev/null
+++ b/apps/user_ldap/appinfo/info.xml
@@ -0,0 +1,10 @@
+
+
+ user_ldap
+ LDAP user backend
+ Authenticate Users by LDAP
+ 0.1
+ AGPL
+ Dominik Schmidt
+ 2
+
diff --git a/apps/user_ldap/settings.php b/apps/user_ldap/settings.php
new file mode 100644
index 0000000000..f7aff1b461
--- /dev/null
+++ b/apps/user_ldap/settings.php
@@ -0,0 +1,52 @@
+.
+ *
+ */
+
+require_once('../../lib/base.php');
+require( 'template.php' );
+
+if( !OC_USER::isLoggedIn() || !OC_GROUP::inGroup( OC_USER::getUser(), 'admin' )){
+ header( "Location: ".OC_HELPER::linkTo( "index.php" ));
+ exit();
+}
+
+$params = array('ldap_host', 'ldap_port', 'ldap_dn', 'ldap_password', 'ldap_base', 'ldap_filter');
+
+foreach($params as $param){
+ if(isset($_POST[$param])){
+ OC_APPCONFIG::setValue('user_ldap', $param, $_POST[$param]);
+ }
+}
+OC_APP::setActiveNavigationEntry( "user_ldap_settings" );
+
+
+// fill template
+$tmpl = new OC_TEMPLATE( 'user_ldap', 'settings', 'admin' );
+foreach($params as $param){
+ $value = OC_APPCONFIG::getValue('user_ldap', $param,'');
+ $tmpl->assign($param, $value);
+}
+
+// ldap_port has a default value
+$tmpl->assign( 'ldap_port', OC_APPCONFIG::getValue('user_ldap', 'ldap_port', OC_USER_BACKEND_LDAP_DEFAULT_PORT));
+
+$tmpl->printPage();
diff --git a/apps/user_ldap/templates/settings.php b/apps/user_ldap/templates/settings.php
new file mode 100644
index 0000000000..5dddb71a02
--- /dev/null
+++ b/apps/user_ldap/templates/settings.php
@@ -0,0 +1,27 @@
+
\ No newline at end of file
diff --git a/apps/user_ldap/user_ldap.php b/apps/user_ldap/user_ldap.php
new file mode 100644
index 0000000000..1ee9809b3b
--- /dev/null
+++ b/apps/user_ldap/user_ldap.php
@@ -0,0 +1,99 @@
+.
+ *
+ */
+
+require_once('User/backend.php');
+
+class OC_USER_LDAP extends OC_USER_BACKEND {
+
+ protected $ds;
+
+ // cached settings
+ protected $ldap_host;
+ protected $ldap_port;
+ protected $ldap_dn;
+ protected $ldap_password;
+ protected $ldap_base;
+ protected $ldap_filter;
+
+ function __construct() {
+ $this->ldap_host = OC_APPCONFIG::getValue('user_ldap', 'ldap_host','');
+ $this->ldap_port = OC_APPCONFIG::getValue('user_ldap', 'ldap_port', OC_USER_BACKEND_LDAP_DEFAULT_PORT );
+ $this->ldap_dn = OC_APPCONFIG::getValue('user_ldap', 'ldap_dn','');
+ $this->ldap_password = OC_APPCONFIG::getValue('user_ldap', 'ldap_password','');
+ $this->ldap_base = OC_APPCONFIG::getValue('user_ldap', 'ldap_base','');
+ $this->ldap_filter = OC_APPCONFIG::getValue('user_ldap', 'ldap_filter','');
+ }
+
+ function __destruct() {
+ // close the connection
+ if( $this->ds )
+ ldap_unbind($this->ds);
+ }
+
+ private function getDs() {
+ if(!$this->ds) {
+ $this->ds = ldap_connect( $this->ldap_host, $this->ldap_port );
+ }
+
+ // login
+ if(!empty($this->ldap_dn)) {
+ $ldap_login = @ldap_bind( $this->ds, $this->ldap_dn, $this->ldap_password );
+ if(!$ldap_login)
+ return false;
+ }
+
+ return $this->ds;
+ }
+
+ private function getDn( $uid ) {
+ // connect to server
+ $ds = $this->getDs();
+ if( !$ds )
+ return false;
+
+ // get dn
+ $filter = str_replace("%uid", $uid, $this->ldap_filter);
+ $sr = ldap_search( $this->getDs(), $this->ldap_base, $filter );
+ $entries = ldap_get_entries( $this->getDs(), $sr );
+
+ if( $entries["count"] == 0 )
+ return false;
+
+ return $entries[0]["dn"];
+ }
+ public function checkPassword( $uid, $password ) {
+ $dn = $this->getDn( $uid );
+ if( !$dn )
+ return false;
+
+ return @ldap_bind( $this->getDs(), $dn, $password );
+ }
+
+ public function userExists( $uid ) {
+ $dn = getDn($uid);
+ return !empty($dn);
+ }
+
+}
+
+?>