* * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . * or see http://www.gnu.org/ */ /** * \file htdocs/core/lib/ldap.lib.php * \brief Ensemble de fonctions de base pour le module LDAP * \ingroup ldap */ /** * Initialize the array of tabs for customer invoice * * @return array Array of head tabs */ function ldap_prepare_head() { global $langs, $conf, $user; $langs->load("ldap"); // Onglets $head=array(); $h = 0; $head[$h][0] = DOL_URL_ROOT."/admin/ldap.php"; $head[$h][1] = $langs->trans("LDAPGlobalParameters"); $head[$h][2] = 'ldap'; $h++; if (! empty($conf->global->LDAP_SYNCHRO_ACTIVE)) { $head[$h][0] = DOL_URL_ROOT."/admin/ldap_users.php"; $head[$h][1] = $langs->trans("LDAPUsersSynchro"); $head[$h][2] = 'users'; $h++; } if (! empty($conf->global->LDAP_SYNCHRO_ACTIVE)) { $head[$h][0] = DOL_URL_ROOT."/admin/ldap_groups.php"; $head[$h][1] = $langs->trans("LDAPGroupsSynchro"); $head[$h][2] = 'groups'; $h++; } if (! empty($conf->societe->enabled) && ! empty($conf->global->LDAP_CONTACT_ACTIVE)) { $head[$h][0] = DOL_URL_ROOT."/admin/ldap_contacts.php"; $head[$h][1] = $langs->trans("LDAPContactsSynchro"); $head[$h][2] = 'contacts'; $h++; } if (! empty($conf->adherent->enabled) && ! empty($conf->global->LDAP_MEMBER_ACTIVE)) { $head[$h][0] = DOL_URL_ROOT."/admin/ldap_members.php"; $head[$h][1] = $langs->trans("LDAPMembersSynchro"); $head[$h][2] = 'members'; $h++; } return $head; } /** * Show button test LDAP synchro * * @param string $butlabel Label * @param string $testlabel Label * @param string $key Key * @param string $dn Dn * @param string $objectclass Class * @return void */ function show_ldap_test_button($butlabel,$testlabel,$key,$dn,$objectclass) { global $langs, $conf, $user; //print 'key='.$key.' dn='.$dn.' objectclass='.$objectclass; print '
'; if (! function_exists("ldap_connect")) { print ''.$butlabel.''; } else if (empty($conf->global->LDAP_SERVER_HOST)) { print ''.$butlabel.''; } else if (empty($key) || empty($dn) || empty($objectclass)) { $langs->load("errors"); print ''.$butlabel.''; } else { print ''.$butlabel.''; } print '

'; } /** * Show a LDAP array into an HTML output array. * * @param array $result Array to show. This array is already encoded into charset_output * @param int $level Level * @param int $count Count * @param string $var Var * @param int $hide Hide * @param int $subcount Subcount * @return int */ function show_ldap_content($result,$level,$count,$var,$hide=0,$subcount=0) { global $bc, $conf; $count--; if ($count == 0) return -1; // To stop loop if (! is_array($result)) return -1; foreach($result as $key => $val) { if ("$key" == "objectclass") continue; if ("$key" == "count") continue; if ("$key" == "dn") continue; if ("$val" == "objectclass") continue; $lastkey[$level]=$key; if (is_array($val)) { $hide=0; if (! is_numeric($key)) { print ''; print ''; print $key; print ''; if (strtolower($key) == 'userpassword') $hide=1; } show_ldap_content($val,$level+1,$count,$var,$hide,$val["count"]); } else if ($subcount) { $subcount--; $newstring=dol_htmlentitiesbr($val); if ($hide) print preg_replace('/./i','*',$newstring); else print $newstring; print '
'; } if ("$val" != $lastkey[$level] && !$subcount) print ''; } return 1; }