startLSsession() ) { $_ERRORS = 'LSsession : Impossible d\'initialiser la LSsession.'; } } $data=NULL; if (!isset($_ERRORS)) { switch($_REQUEST['template']) { case 'login': switch($_REQUEST['action']) { case 'onLdapServerChanged': if ( isset($_REQUEST['server']) ) { $GLOBALS['LSsession'] -> setLdapServer($_REQUEST['server']); if ( $GLOBALS['LSsession'] -> LSldapConnect() ) { session_start(); $list = $GLOBALS['LSsession'] -> getSubDnLdapServerOptions($_SESSION['LSsession_topDn']); if (is_string($list)) { $list=""; $data = array( 'list_topDn' => $list, 'levelLabel' => $GLOBALS['LSsession'] -> getLevelLabel() ); } } } break; } break; case 'LSform': switch($_REQUEST['action']) { case 'onAddFieldBtnClick': if ((isset($_REQUEST['attribute'])) && (isset($_REQUEST['objecttype'])) && (isset($_REQUEST['objectdn'])) && (isset($_REQUEST['idform'])) && (isset($_REQUEST['img'])) ) { if ($GLOBALS['LSsession'] -> loadLSobject($_REQUEST['objecttype'])) { $object = new $_REQUEST['objecttype'](); $object -> loadData($_REQUEST['objectdn']); $form = $object -> getForm($_REQUEST['idform']); $emptyField=$form -> getEmptyField($_REQUEST['attribute']); if ( $emptyField ) { $data = array( 'html' => $form -> getEmptyField($_REQUEST['attribute']), 'img' => $_REQUEST['img'], 'fieldtype' => get_class($form -> getElement($_REQUEST['attribute'])) ); } } else { $GLOBALS['LSerror'] -> addErrorCode(1004,$_REQUEST['objecttype']); } } break; case 'refreshField': if ((isset($_REQUEST['attribute'])) && (isset($_REQUEST['objecttype'])) && (isset($_REQUEST['objectdn'])) && (isset($_REQUEST['idform'])) ) { if ($GLOBALS['LSsession'] -> loadLSobject($_REQUEST['objecttype'])) { $object = new $_REQUEST['objecttype'](); $form = $object -> getForm($_REQUEST['idform']); $field=$form -> getElement($_REQUEST['attribute']); $val = $field -> getDisplay(true); if ( $val ) { $data = array( 'html' => $val['html'] ); } } else { $GLOBALS['LSerror'] -> addErrorCode(1004,$_REQUEST['objecttype']); } } break; case 'generatePassword': if ((isset($_REQUEST['attribute'])) && (isset($_REQUEST['objecttype'])) && (isset($_REQUEST['viewBtnId'])) && (isset($_REQUEST['fieldId'])) && (isset($_REQUEST['idform'])) ) { if ($GLOBALS['LSsession'] -> loadLSobject($_REQUEST['objecttype'])) { $object = new $_REQUEST['objecttype'](); $form = $object -> getForm($_REQUEST['idform']); $field=$form -> getElement($_REQUEST['attribute']); $val = $field -> generatePassword(); if ( $val ) { $data = array( 'generatePassword' => $val, 'fieldId' => $_REQUEST['fieldId'], 'viewBtnId' => $_REQUEST['viewBtnId'] ); } } else { $GLOBALS['LSerror'] -> addErrorCode(1004,$_REQUEST['objecttype']); } } break; case 'verifyPassword': if ((isset($_REQUEST['attribute'])) && (isset($_REQUEST['objecttype'])) && (isset($_REQUEST['fieldId'])) && (isset($_REQUEST['fieldValue'])) && (isset($_REQUEST['idform'])) && (isset($_REQUEST['objectdn'])) ) { if ($GLOBALS['LSsession'] -> loadLSobject($_REQUEST['objecttype'])) { $object = new $_REQUEST['objecttype'](); $form = $object -> getForm($_REQUEST['idform']); $object -> loadData($_REQUEST['objectdn']); $field=$form -> getElement($_REQUEST['attribute']); $val = $field -> verifyPassword($_REQUEST['fieldValue']); $data = array( 'verifyPassword' => $val, 'fieldId' => $_REQUEST['fieldId'] ); } else { $GLOBALS['LSerror'] -> addErrorCode(1004,$_REQUEST['objecttype']); } } break; } break; case 'LSrelation': switch($_REQUEST['action']) { case 'refreshSession': if ((isset($_REQUEST['id'])) && (isset($_REQUEST['href'])) ) { if (isset($_SESSION['LSrelation'][$_REQUEST['id']])) { $conf = $_SESSION['LSrelation'][$_REQUEST['id']]; if ($GLOBALS['LSsession']->loadLSobject($conf['objectType'])) { $object = new $conf['objectType'](); if (($object -> loadData($conf['objectDn'])) && (isset($object->config['relations'][$conf['relationName']]))) { $relationConf = $object->config['relations'][$conf['relationName']]; if ($GLOBALS['LSsession'] -> loadLSobject($relationConf['LSobject'])) { if ($GLOBALS['LSsession'] -> relationCanEdit($object -> getValue('dn'),$object -> getType(),$conf['relationName'])) { if (method_exists($relationConf['LSobject'],$relationConf['list_function'])) { $objRel = new $relationConf['LSobject'](); $list = $objRel -> $relationConf['list_function']($object); $_SESSION['LSselect'][$relationConf['LSobject']]=array(); if (is_array($list)) { foreach($list as $o) { $_SESSION['LSselect'][$relationConf['LSobject']][] = $o -> getDn(); } } $data = array( 'href' => $_REQUEST['href'], 'id' => $_REQUEST['id'] ); } else { $GLOBALS['LSerror'] -> addErrorCode(1013,$relationName); } } else { $GLOBALS['LSerror'] -> addErrorCode(1011); } } else { $GLOBALS['LSerror'] -> addErrorCode(1004,$relationConf['LSobject']); } } else { $GLOBALS['LSerror'] -> addErrorCode(1012); } } else { $GLOBALS['LSerror'] -> addErrorCode(1012); } } else { $GLOBALS['LSerror'] -> addErrorCode(1012); } } break; case 'refreshList': if (isset($_REQUEST['id'])) { if (isset($_SESSION['LSrelation'][$_REQUEST['id']])) { $conf = $_SESSION['LSrelation'][$_REQUEST['id']]; if ($GLOBALS['LSsession']->loadLSobject($conf['objectType'])) { $object = new $conf['objectType'](); if (($object -> loadData($conf['objectDn'])) && (isset($object->config['relations'][$conf['relationName']]))) { $relationConf = $object->config['relations'][$conf['relationName']]; if ($GLOBALS['LSsession'] -> loadLSobject($relationConf['LSobject'])) { if ($GLOBALS['LSsession'] -> relationCanEdit($object -> getValue('dn'),$object -> getType(),$conf['relationName'])) { if (is_array($_SESSION['LSselect'][$relationConf['LSobject']])) { if (method_exists($relationConf['LSobject'],$relationConf['update_function'])) { $objRel = new $relationConf['LSobject'](); if($objRel -> $relationConf['update_function']($object,$_SESSION['LSselect'][$relationConf['LSobject']])) { if (method_exists($relationConf['LSobject'],$relationConf['list_function'])) { $list = $objRel -> $relationConf['list_function']($object); if (is_array($list)&&(!empty($list))) { foreach($list as $o) { $data['html'].= "