pg_connect[] = 'dbname=${davical_dbname} user=${davical_username} host=${davical_dbhost}'; \$c->admin_email = '${davical_admin_email}'; \$c->restrict_setup_to_admin = true; \$c->home_calendar_name = 'calendar'; \$c->home_addressbook_name = 'addressbook'; \$c->default_privileges = array('read-free-busy', 'schedule-deliver'); \$c->external_refresh = 60; \$c->default_locale = 'en'; \$c->allow_get_email_visibility = true; \$c->trust_x_forwarded = true; \$c->authenticate_hook['call'] = 'LDAP_check'; \$c->authenticate_hook['config'] = array( 'uri' => '${ldap_uri}', 'host' => '${ldap_hosts}', 'port' => '389', 'sasl' => 'yes', 'sasl_mech' => 'GSSAPI', 'baseDNUsers' => '${people_basedn}', 'baseDNGroups' => '${groups_basedn}', /* Must use scope=onelevel here because if davical picks up a user and group * with the same name, then the group takes precedence and the user is lost. * Sad for us because we store user private groups in LDAP. */ 'scope' => 'onelevel', 'protocolVersion' => 3, 'optReferrals' => 0, 'filterUsers' => '(memberOf=cn=${davical_access_role},${roles_basedn})', 'filterGroups' => '(objectclass=groupOfMembers)', 'mapping_field' => array('username' => 'uid', 'modified' => 'modifyTimestamp', 'fullname' => 'cn', 'email' => 'mailAddress'), 'group_mapping_field' => array('name' => 'cn', 'fullname' => 'cn', 'modified' => 'modifyTimestamp', 'email' => 'mailAddress', 'members' => 'member'), 'group_member_dnfix' => true, 'default_value' => array('date_format_type' => 'I','locale' => 'en'), 'format_updated' => array('Y' => array(0,4), 'm' => array(4,2), 'd' => array(6,2), 'H' => array(8,2), 'M' => array(10,2), 'S' => array(12,2)), 'i_use_mode_kerberos' => 'allow_fallback_to_ldap_auth', ); include_once('drivers_ldap.php');