. * */ defined('APP_ROOT') || die(_('No es posible acceder directamente a este archivo')); /** * Esta clase es encargada de ejecutar acciones comunes para las funciones */ class SP_Common { /** * Enviar un email utilizando la clase PHPMailer. * * @param array $message con el nombre de la accióm y el texto del mensaje * @param string $mailTo con el destinatario * @param bool $isEvent para indicar si es um * @return bool */ public static function sendEmail($message, $mailTo = '', $isEvent = true) { if (!SP_Util::mailIsEnabled()) { return false; } if (!is_array($message)) { return false; } $mail = self::getEmailObject($mailTo, $message['action']); if (!is_object($mail)) { return false; } $mail->isHTML(); $newline = '
'; if ($isEvent === true) { $performer = (isset($_SESSION["ulogin"])) ? $_SESSION["ulogin"] : _('N/D'); $body[] = SP_Html::strongText(_('Acción') . ": ") . $message['action']; $body[] = SP_Html::strongText(_('Realizado por') . ": ") . $performer . ' (' . $_SERVER['REMOTE_ADDR'] . ')'; $mail->addCC(SP_Config::getValue('mail_from')); } $body[] = (is_array($message['text'])) ? implode($newline, $message['text']) : ''; $body[] = ''; $body[] = '--'; $body[] = SP_Html::getAppInfo('appname') . ' - ' . SP_Html::getAppInfo('appdesc'); $body[] = SP_Html::anchorText(SP_Init::$WEBURI); $mail->Body = implode($newline, $body); $sendMail = $mail->send(); // Enviar correo if ($sendMail) { $log['text'][] = _('Correo enviado'); } else { $log['text'][] = _('Error al enviar correo'); $log['text'][] = 'ERROR: ' . $mail->ErrorInfo; } $log['text'][] = ''; $log['text'][] = _('Destinatario') . ": $mailTo"; $log['text'][] = ($isEvent === true) ? _('CC') . ": " . SP_Config::getValue('mail_from') : ''; $log['action'] = _('Enviar Email'); SP_Log::wrLogInfo($log); return $sendMail; } /** * Inicializar la clase PHPMailer. * * @param string $mailTo con la dirección del destinatario * @param string $action con la acción realizada * @return false|object */ public static function getEmailObject($mailTo, $action) { $appName = SP_Html::getAppInfo('appname'); $mailFrom = SP_Config::getValue('mail_from'); $mailServer = SP_Config::getValue('mail_server'); $mailPort = SP_Config::getValue('mail_port', 25); $mailAuth = SP_Config::getValue('mail_authenabled', FALSE); if ($mailAuth) { $mailUser = SP_Config::getValue('mail_user'); $mailPass = SP_Config::getValue('mail_pass'); } if (!$mailServer) { return false; } if (empty($mailTo)) { $mailTo = $mailFrom; } $phpmailerPath = EXTENSIONS_DIR . DIRECTORY_SEPARATOR . 'phpmailer'; require_once $phpmailerPath . DIRECTORY_SEPARATOR . 'class.phpmailer.php'; require_once $phpmailerPath . DIRECTORY_SEPARATOR . 'class.smtp.php'; $mail = new PHPMailer(); $mail->isSMTP(); $mail->CharSet = 'utf-8'; $mail->SMTPAuth = $mailAuth; $mail->Host = $mailServer; $mail->Port = $mailPort; $mail->Username = $mailUser; $mail->Password = $mailPass; $mail->SMTPSecure = strtolower(SP_Config::getValue('mail_security')); //$mail->SMTPDebug = 2; //$mail->Debugoutput = 'error_log'; $mail->setFrom($mailFrom, $appName); $mail->addAddress($mailTo); $mail->addReplyTo($mailFrom, $appName); $mail->WordWrap = 100; $mail->Subject = $appName . ' (' . _('Aviso') . ') - ' . $action; return $mail; } /** * Devuelve una respuesta en formato XML con el estado y el mensaje. * * @param string $description mensaje a devolver * @param int $status devuelve el estado * @return bool */ public static function printXML($description, $status = 1) { if (!is_string($description)) { return false; } $arrStrFrom = array("&", "<", ">", "\"", "\'"); $arrStrTo = array("&", "<", ">", """, "'"); $cleanDescription = str_replace($arrStrFrom, $arrStrTo, $description); $xml = "\n"; $xml .= "\n" . $status . "\n " . $cleanDescription . "\n"; header("Content-Type: application/xml"); exit($xml); } /** * Devuelve una respuesta en formato JSON con el estado y el mensaje. * * @param string $description mensaje a devolver * @param int $status devuelve el estado * @param string $action con la accion a realizar * @return bool */ public static function printJSON($description, $status = 1, $action = '') { if (!is_string($description)) { return false; } $arrStrFrom = array("\\", '"', "'"); $arrStrTo = array("\\", '\"', "\'"); $cleanDescription = str_replace($arrStrFrom, $arrStrTo, $description); $json = array('status' => $status, 'description' => $cleanDescription, 'action' => $action); header('Content-type: application/json'); exit(json_encode($json)); } /** * Devuelve un icono de ayuda con el mensaje. * * @param int $type tipo de mensaje * @param int $id id del mensaje * @return string Con la etiqueta html del icono de ayuda */ public static function printHelpButton($type, $id) { $msgHelp[0] = _('Indicar el usuario de conexión a la base de datos de phpPMS'); $msgHelp[1] = _('Indicar el nombre de la base de datos de phpPMS'); $msgHelp[2] = _('Indicar el servidor de la base de datos de phpPMS'); $msgHelp[3] = _('Habilita el nombre de la cuenta de la búsqueda, como enlace a los detalles de la cuenta'); $msgHelp[4] = _('Número de resultados por página a mostrar, al realizar una búsqueda'); $msgHelp[5] = _('Habilita la subida/descarga de archivos para las cuentas'); $msgHelp[6] = _('Establece el tamaño máximo para subir archivos') . "

" . _('El máximo absuluto es de 16MB'); $msgHelp[7] = _('Habilita la opción de añadir un enlace a Wiki externa para los resultados de la búsqueda'); $msgHelp[8] = _('URL que utiliza la wiki para realizar una búsqueda de una página en esta') . "

" . _('Como parámetro se utiliza el nombre del cliente') . "

" . _('Ejemplo') . ":

https://wiki.cygnux.org/search.php?phrase="; $msgHelp[9] = _('URL que utiliza la wiki para acceder a los detalles de una página de ésta') . "

" . _('El nombre de la cuenta se utiliza como parámetro de la variable de búsqueda de la Wiki') . "

" . _('Ejemplo') . ":

https://wiki.cygnux.org/show.php?name="; $msgHelp[10] = _('Prefijo para determinar qué cuentas tienen un enlace a una página de la Wiki') . "

" . _('Ejemplos') . ": serv- | srv- | vm-"; $msgHelp[11] = _('Habilita de autentificación mediante servidor LDAP') . "

" . _('Este método utilizará MySQL en caso de fallo'); $msgHelp[12] = _('Usuario para conectar con el servicio de LDAP') . "

" . _('Ejemplo') . ":

cn=syspass,ou=Users,dc=cygnux,o=org"; $msgHelp[13] = _('Base en la que realizar la búsqueda de usuarios de LDAP') . "

" . _('Ejemplo') . ":

dc=cygnux,o=org"; $msgHelp[14] = _('Grupo de LDAP al que debe de pertenecer el usuario para permitir el acceso') . "

" . _('Ejemplo') . ":

cn=GRP_SPUSERS,ou=USERS | GRP_SPUSERS"; $msgHelp[15] = _('Nombre o dirección IP del servidor de LDAP'); $msgHelp[16] = _('Establece una nueva clave maestra sin re-encriptar las cuentas'); $msgHelp[17] = _('Clave del usuario de conexión a LDAP'); $msgHelp[18] = _('En este modo no se puede acceder a la aplicación. Para deshabilitarlo es necesario modificar el archivo de configuración'); $msgHelp[19] = _('Muestra información relativa a la configuración de la aplicación y rendimiento'); $msgHelp[20] = _('Guarda las acciones realizadas en la aplicación'); $msgHelp[21] = _('Comprobar actualizaciones de la aplicación (sólo para los usuarios administradores)'); $msgHelp[22] = _('Extensiones de máximo 4 caracteres.') . "

" . _('Escribir extensión y pulsar intro para añadir.'); $msgHelp[23] = _('Importar desde KeePass o KeePassX. El nombre del cliente será igual a KeePass o KeePassX') . "

" . _('Importar desde un archivo CSV con el formato') . ":

" . _('nombre_de_cuenta;cliente;categoría;url;usuario;clave;notas') . "

" . _('Si el cliente o la categoría no están creados, se crean automáticamente.'); $msgHelp[24] = _('Permite que las cuentas sin acceso sean visibles sólo para las búsquedas.'); $msgHelp[25] = _('Muestra los resultados de búsqueda de cuentas en formato tarjeta.'); $msgHelp[26] = _('Habilita el modo de conexión con LDAP de Active Directory.'); $msgHelp[27] = _('Define el grupo de usuarios por defecto para los nuevos usuarios de LDAP.'); $msgHelp[28] = _('Define el perfil de usuario por defecto para los nuevos usuarios de LDAP.'); if (array_key_exists($id, $msgHelp)) { return ''; } } /** * Devuelve un hash para verificación de formularios. * Esta función genera un hash que permite verificar la autenticidad de un formulario * * @param bool $new si es necesrio regenerar el hash * @return string con el hash de verificación */ public static function getSessionKey($new = false) { $hash = sha1(time()); // Generamos un nuevo hash si es necesario y lo guardamos en la sesión if (!isset($_SESSION["sk"]) || $new === true) { $_SESSION["sk"] = $hash; return $hash; } return $_SESSION["sk"]; } /** * Comprobar el hash de verificación de formularios. * * @param string $key con el hash a comprobar * @return bool|string si no es correcto el hash devuelve bool. Si lo es, devuelve el hash actual. */ public static function checkSessionKey($key) { if (!isset($_SESSION["sk"]) || $_SESSION["sk"] == "" || !$key) { return false; } return ($_SESSION["sk"] == $key); } /** * Obtener los valores de variables $_GET, $_POST, $_REQUEST o $_SESSION * y devolverlos limpios con el tipo correcto o esperado. * * @param string $method con el método a utilizar * @param string $param con el parámetro a consultar * @param mixed $default opcional, valor por defecto a devolver * @param bool $onlyCHeck opcional, comprobar si el parámetro está presente * @param mixed $force opcional, valor devuelto si el parámeto está definido * @param bool $sanitize opcional, escapar/eliminar carácteres especiales * @return bool|string si está presente el parámeto en la petición devuelve bool. Si lo está, devuelve el valor. */ public static function parseParams($method, $param, $default = '', $onlyCHeck = false, $force = false, $sanitize = true) { $out = ''; switch ($method) { case 'g': if (!isset($_GET[$param])) { return $default; } $out = $_GET[$param]; break; case 'p': if (!isset($_POST[$param])) { return $default; } $out = $_POST[$param]; break; case 's': if (!isset($_SESSION[$param])) { return $default; } $out = $_SESSION[$param]; break; case 'r': if (!isset($_REQUEST[$param])) { return $default; } $out = $_REQUEST[$param]; break; default : return false; } if ($onlyCHeck) { return true; } if ($force) { return $force; } if ((is_numeric($out) && !is_string($default)) || is_numeric($default)) { return intval($out); } if (is_string($out)) { return ($method != 's' && $sanitize === true) ? SP_Html::sanitize($out) : $out; } if (is_array($out)) { return $out; } } }