raspisms/controllers/internals/Tool.php

146 lines
5.4 KiB
PHP
Raw Normal View History

2019-10-29 14:57:13 +01:00
<?php
namespace controllers\internals;
2019-10-29 18:36:25 +01:00
class Tool extends \descartes\InternalController
{
/**
* Cette fonction parse un numéro pour le retourner sans espaces, etc.
* @param string $number : Le numéro de téléphone à parser
* @return mixed : Si le numéro est bien un numéro de téléphone, on retourne le numéro parsé. Sinon, on retourne faux
*/
public static function parse_phone($number)
{
$number = preg_replace('#[^-0-9+]#', '', $number);
if (preg_match('#^(0|\+[1-9]{1,3}|\+1\-[0-9]{3})[1-9][0-9]{8,10}$#', $number)) {
return $number;
}
return false;
}
2019-10-29 14:57:13 +01:00
2019-10-29 18:36:25 +01:00
/**
* Cette fonction parse un numéro pour le retourner avec des espaces, etc.
* @param string $number : Le numéro de téléphone à parser
* @return mixed : Si le numéro est bien un numéro de téléphone, on retourne le numéro parsé. Sinon, on retourne faux
*/
public static function phone_add_space($number)
{
return preg_replace('#(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})#', '$1 $2 $3 $4 $5', $number);
}
2019-10-29 14:57:13 +01:00
2019-10-29 18:36:25 +01:00
/**
* Cette fonction fait la correspondance entre un type d'evenement et une icone font awesome.
* @param string $type : Le type de l'évenement à analyser
* @return string : Le nom de l'icone à afficher (ex : fa-user)
*/
public static function event_type_to_icon($type)
{
switch ($type) {
case 'USER_ADD':
$logo = 'fa-user';
break;
case 'CONTACT_ADD':
$logo = 'fa-user';
break;
case 'GROUP_ADD':
$logo = 'fa-group';
break;
case 'SCHEDULED_ADD':
$logo = 'fa-calendar';
break;
case 'COMMAND_ADD':
$logo = 'fa-terminal';
break;
default:
$logo = 'fa-question';
}
2019-10-29 14:57:13 +01:00
2019-10-29 18:36:25 +01:00
return $logo;
}
2019-10-29 14:57:13 +01:00
2019-10-29 18:36:25 +01:00
/**
* Cette fonction vérifie une date
* @param string $date : La date a valider
* @param string $format : Le format de la date
* @return boolean : Vrai si la date et valide, faux sinon
*/
public static function validate_date($date, $format)
{
$objectDate = \DateTime::createFromFormat($format, $date);
return ($objectDate && $objectDate->format($format) == $date);
}
2019-10-29 14:57:13 +01:00
2019-10-29 18:36:25 +01:00
/**
* Cette fonction parse un texte, pour en extraire des données contenu dans des drapeaux au format [FLAG:contenu du drapeau]
* @param string $texte : Le texte à parser
* @return mixed : Tableau de la forme 'FLAG' => 'contenu du drapeau'. si on trouve une forme correcte (Le contenu de FLAG sera mis en majuscule automatiquement). Sinon le tableau vide.
*/
public static function parse_for_flag($texte)
{
$returns = array();
$results = array();
while (preg_match('#\[(.*)(?<!\\\):(.*)(?<!\\\)\]#Uui', $texte, $results)) { //Tant qu'on recuèpre un flag
$returns[mb_strtoupper($results[1])] = $results[2];
$texte = str_replace($results[0], '', $texte);
}
return $returns;
}
2019-10-29 14:57:13 +01:00
2019-10-29 18:36:25 +01:00
/**
* Cette fonction retourne un mot de passe généré aléatoirement
* @param int $length : Taille du mot de passe à générer
* @return string : Le mot de passe aléatoire
*/
public static function generate_password($length)
{
$chars = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789_-@()?.:!%*$&/';
$password = '';
$chars_length = mb_strlen($chars) - 1;
$i = 0;
while ($i < $length) {
$i ++;
$password .= $chars[rand(0, $chars_length)];
}
return $password;
}
/**
* Cette fonction vérifie si un utilisateur et connecté, et si il ne l'est pas, redirige sur la page de connexion
* @return void
*/
public static function verifyconnect()
2019-10-29 18:36:25 +01:00
{
if (!isset($_SESSION['connect']) || !$_SESSION['connect']) {
header('Location: /');
die();
}
2019-10-29 14:57:13 +01:00
}
/**
* Check if the user is admin.
* @return Bool : True if admin, False else
2019-10-29 18:36:25 +01:00
*/
public static function is_admin()
{
if (!isset($_SESSION['user']) || !$_SESSION['connect']['admin']) {
2019-10-29 14:57:13 +01:00
return false;
}
return true;
}
/**
* Cette fonction s'occupe d'envoyer les emails
* @param string $to : L'adresse mail à laquelle envoyer le mail
* @param array $settings : Les settings du mail, type, sujet, template
* @param array $datas : Les données à fournir au template du mail
*/
public static function send_email($to, $settings, $datas = [])
2019-10-29 14:57:13 +01:00
{
$controller = new \descartes\Controller();
2019-10-29 14:57:13 +01:00
$content = $controller->render($settings['template'], $datas, true);
2019-10-29 18:36:25 +01:00
return true;#mail($to, $settings['subject'], $content);
2019-10-29 14:57:13 +01:00
}
2019-10-29 18:36:25 +01:00
}