function updateUserOrganization($idUser, $name, $md5password, $password1, $extension, $fax_extension, $countryCode, $areaCode, $clidNumber, $cldiName, $idGrupo, $quota, $userLevel1, &$reAsterisk) { require_once "apps/general_settings/libs/paloSantoGlobalsPBX.class.php"; $pACL = new paloACL($this->_DB); $pEmail = new paloEmail($this->_DB); $pFax = new paloFax($this->_DB); $continuar = true; $Exito = false; $error = ""; $cExten = false; $cFExten = false; $arrBackup = array(); $editFax = false; $faxProperties = array(); $arrUser = $pACL->getUsers2($idUser); if ($arrUser === false || count($arrUser) == 0 || !isset($idUser)) { $this->errMsg = _tr("User dosen't exist"); return false; } if ($pACL->isUserSuperAdmin($arrUser[0]['username'])) { $this->errMsg = _tr("Invalid Action"); return false; } $arrOrgz = $this->getOrganizationById($arrUser[0]['id_organization']); $username = $arrUser[0]['username']; $oldExten = $arrUser[0]['extension']; $oldFaxExten = $arrUser[0]['fax_extension']; $pDevice = new paloDevice($arrOrgz["domain"], "sip", $this->_DB); $arrExtUser = $pDevice->getExtension($oldExten); $listFaxs = $pFax->getFaxList(array("exten" => $oldFaxExten, "organization_domain" => $arrOrgz['domain'])); $faxUser = $listFaxs[0]; if ($name == "") { $name = $username; } if ($userLevel1 == "other") { $extension = $arrUser[0]['extension']; $fax_extension = $arrUser[0]['fax_extension']; $quota = $pACL->getUserProp($idUser, "email_quota"); $idGrupo = $arrUser[0]['id_group']; $modificarExts = false; } else { //verificar si el usuario cambio de extension y si es asi que no este siendo usado por otro usuario if ($extension != $oldExten) { if ($pDevice->existDevice($extension, "{$arrOrgz["code"]}_{$extension}", $arrExtUser["tech"]) == true) { $this->errMsg = $pDevice->errMsg; return false; } else { $cExten = true; } } if ($fax_extension != $oldFaxExten) { //si el usairo quiere cambiar el patron de marcado asociado al fax verificar que el nuevo //patron de marcado no este siendo usado dentro de la organizacion if ($pDevice->tecnologia->existExtension($fax_extension, $pDevice->getDomain())) { $this->errMsg = $pDevice->errMsg; return false; } else { $cFExten = true; } } //para cambiar al usuario de extension o faxextension es necesario que se haya llenado el campo password para //poder crear las extensiones con la clave correcta if ($cExten || $cFExten) { if (is_null($md5password) || $md5password == "" || is_null($password1) || $password1 == "") { $this->errMsg = _tr("Please set a password"); return false; } } } if (empty($clidNumber) && $clidNumber != 0) { $clidNumber = $faxUser['clid_number']; } if (empty($cldiName) && $cldiName != 0) { $cldiName = $faxUser['clid_name']; } if (empty($country_code)) { $country_code = $faxUser['country_code']; } if (empty($area_code)) { $area_code = $faxUser['area_code']; } $this->_DB->beginTransaction(); //actualizamos la informacion de usuario que esta en la tabla acl_user if ($pACL->updateUser($idUser, $name, $extension, $fax_extension)) { //actualizamos el grupo al que pertennece el usuario if ($pACL->addToGroup($idUser, $idGrupo)) { $old_quota = $pACL->getUserProp($idUser, "email_quota"); if ($old_quota === false) { $old_quota = 1; } //actualizamos la quota de correo if (isset($quota) && $quota != "" && $continuar) { if ($pEmail->updateQuota($old_quota * 1024, $quota * 1024, $username)) { if (!$pACL->setUserProp($idUser, "email_quota", $quota, "email")) { $error = _tr("Error setting email quota") . $pACL->errMsg; $pEmail->updateQuota($quota, $old_quota); $this->_DB->rollBack(); $continuar = false; } } else { $error = _tr("Error setting email quota") . $pEmail->errMsg; $continuar = false; } } if ($continuar) { if ($cExten && $userLevel1 != "other") { if (!$this->modificarExtensionUsuario($arrOrgz["domain"], $oldExten, $extension, $password1, $name, $username, $arrBackup)) { $error = "Couldn't updated user extension. " . $this->errMsg; $continuar = false; } } } //actualizamos el password del usuario if ($password1 !== "" && $continuar) { if ($pACL->changePassword($idUser, $md5password)) { //en caso que no se hayan modificado la extensiones del usuario //entonces es necesario actualizar el passoword para la extension y el fax if (!$cExten) { if (!$pDevice->changePasswordExtension($password1, $extension)) { $this->errMsg = _tr("Extension password couldn't be updated") . $pDevice->errMsg; $continuar = false; } } //editamos la configuracion del fax if ($continuar) { if ($cFExten && $userLevel1 != "other") { //cuando se cambia el patron de marcado asociado al fax del usuario //es necesario incluir el parametro oldFaxExten entre los parametros para //la actualizacion correcta de los datos if (!$pFax->editFaxToUser(array("idUser" => $idUser, "oldFaxExten" => $oldFaxExten, "country_code" => $countryCode, "area_code" => $areaCode, "clid_name" => $cldiName, "clid_number" => $clidNumber))) { $error = "Couldn't updated user fax. " . $pFax->errMsg; $continuar = false; } } else { if (!$pFax->editFaxToUser(array("idUser" => $idUser, "country_code" => $countryCode, "area_code" => $areaCode, "clid_name" => $cldiName, "clid_number" => $clidNumber))) { $error = "Couldn't updated user fax. " . $pFax->errMsg; $continuar = false; } } } if ($continuar) { if (!$pEmail->setAccountPassword($username, $password1)) { $continuar = false; $error = _tr("Password couldn't be updated") . " " . $pEmail->errMsg; $editFax = true; } } //debemos actualizar el password en las variable de session if ($continuar && $_SESSION['elastix_user'] == $username) { $_SESSION['elastix_pass'] = $md5password; $_SESSION['elastix_pass2'] = $password1; } } else { $error = _tr("Password couldn't be updated") . " " . $pACL->errMsg; $continuar = false; } } else { //editamos la configuracion del fax if ($continuar) { if ($cFExten && $userLevel1 != "other") { //cuando se cambia el patron de marcado asociado al fax del usuario //es necesario incluir el parametro oldFaxExten entre los parametros para //la actualizacion correcta de los datos if (!$pFax->editFaxToUser(array("idUser" => $idUser, "oldFaxExten" => $oldFaxExten, "country_code" => $countryCode, "area_code" => $areaCode, "clid_name" => $cldiName, "clid_number" => $clidNumber))) { $error = "Couldn't updated user fax. " . $pFax->errMsg; $continuar = false; } } else { if (!$pFax->editFaxToUser(array("idUser" => $idUser, "country_code" => $countryCode, "area_code" => $areaCode, "clid_name" => $cldiName, "clid_number" => $clidNumber))) { $error = "Couldn't updated user fax. " . $pFax->errMsg; $continuar = false; } } } } if ($continuar) { $Exito = true; $this->_DB->commit(); //recargamos la configuracion en realtime de los dispositivos para que tomen efectos los cambios if ($cExten) { //se cambio la extension del usuario hay que eliminar de cache la anterior $pDevice->tecnologia->prunePeer($arrExtUser["device"], $arrExtUser["tech"]); } else { $pDevice->tecnologia->prunePeer($arrExtUser["device"], $arrExtUser["tech"]); $pDevice->tecnologia->loadPeer($arrExtUser["device"], $arrExtUser["tech"]); } if ($cFExten) { //se cambio la faxextension del usuario hay que eliminar de cache la anterior $pDevice->tecnologia->prunePeer($faxUser["device"], $faxUser["tech"]); } else { //se recarga la faxextension del usuario por los cambios que pudo haber $pDevice->tecnologia->prunePeer($faxUser["device"], $faxUser["tech"]); $pDevice->tecnologia->loadPeer($faxUser["device"], $faxUser["tech"]); } $pFax->restartService(); } else { $this->_DB->rollBack(); if ($editFax == true) { $pFax->editFaxFileConfig($faxUser['dev_id'], $faxUser['country_code'], $faxUser['area_code'], $faxUser['clid_name'], $faxUser['clid_number'], $arrUser[0]['md5_password'], 0, $arrOrgz['domain']); } if ($cExten == true) { $pDevice->deleteAstDBExt($extension, "sip"); $pDevice->restoreBackupAstDBEXT($arrBackup); } } } else { $error = _tr("Failed Updated Group") . " " . $pACL->errMsg; $this->_DB->rollBack(); } } else { $error = _tr("User couldn't be update") . " " . $pACL->errMsg; $this->_DB->rollBack(); } if ($cExten || $cFExten) { $reAsterisk = true; } $this->errMsg = $error . " " . $this->errMsg; return $Exito; }
function compose_email($smarty, $module_name, $local_templates_dir, $arrConf, &$pImap) { $jsonObject = new PaloSantoJSON(); global $arrCredentials; $idUser = $arrCredentials['idUser']; //obtenemos el name del usuario $pDB = new paloDB($arrConf['elastix_dsn']['elastix']); $pACL = new paloACL($pDB); $result = $pACL->getUsers2($idUser); if ($result == false) { $jsonObject->set_error("Error to get user info"); return $jsonObject->createJSON(); } else { $name = $result[0]['name']; } $pCompose = new paloComposeEmail($_SESSION['elastix_user'], $_SESSION['elastix_pass2'], $name, $pImap); $headers['to'] = getParameter("to"); $headers['cc'] = getParameter("cc"); $headers['bcc'] = getParameter("bcc"); $headers['reply_to'] = getParameter("reply_to"); $subject = getParameter("subject"); $content = getParameter("bodyMsg"); $attachments = null; if (isset($_SESSION['elastix_emailAttachs'])) { $pCompose->setAttachments($_SESSION['elastix_emailAttachs']); } if ($pCompose->sendEmail($headers, $subject, $content)) { $strError = $pCompose->getErrorMsg(); $jsonObject->set_message(_tr("Message was sent successfully.") . " {$strError}"); unset($_SESSION['elastix_emailAttachs']); } else { $jsonObject->set_error($pCompose->getErrorMsg()); } return $jsonObject->createJSON(); }
function deleteFaxByUser($idUser) { $pACL = new paloACL($this->_DB); // 1) obtenemos los datos dle usuario para el cual se esta creando el fax // comprobando de que este realmente exista if (empty($idUser)) { $this->errMsg = _tr("Invalid User"); return false; } $arrUser = $pACL->getUsers2($idUser); if ($arrUser === false) { $this->errMsg = _tr("An error has occured when retrieved user data."); return false; } elseif (count($arrUser) == 0) { $this->errMsg = _tr("User does not exist."); return false; } $user = $arrUser[0]; $domain = $this->getDomainOrganization($user["id_organization"]); //obtenemos el fax del usuario $arrFax = $this->getFaxList(array('exten' => $user['fax_extension'], 'organization_domain' => $domain)); if ($arrFax == false) { $this->errMsg = $arrFax === false ? 'Error to retrieved fax from given user' : 'User does not have a fax'; return false; } $fax = $arrFax[0]; $devId = $fax['dev_id']; $device = $fax['device']; //borramos el fax de la tabla fax $query = "DELETE FROM fax WHERE id=?"; if (!$this->_DB->genQuery($query, array($fax['id']))) { $this->errMsg = _tr("Error to delete fax from database"); return false; } //borramos el peer $query = "DELETE FROM iax WHERE name=? and organization_domain=?"; if (!$this->_DB->genQuery($query, array($device, $domain))) { $this->errMsg = _tr("Error to delete fax peer"); return false; } return $this->deleteFaxConfiguration($devId); }