4 if (!defined('_ECRIRE_INC_VERSION')) {
9 * Une date au format JJ/MM/AAAA (avec séparateurs souples : espace / - .)
11 * - format : permet de préciser le format de la date jma pour jour/mois/année (par défaut), mja (pour mois / jour / année), amj (année/mois/jour)
12 * TODO : compléter les formats
13 * On pourrait faire mieux, genre vérifier les jours en fonction du mois
14 * Mais c'est pas très important, on reste simple
16 * @param string|array $valeur
17 * La valeur à vérifier, en chaîne pour une date seule, en tableau contenant deux entrées "date" et "heure" si on veut aussi l'heure
18 * @param array $options
20 * @param null $valeur_normalisee
21 * Si normalisation a faire, la variable sera rempli par la date normalisee.
23 * Retourne une chaine vide si c'est valide, sinon une chaine expliquant l'erreur.
25 function verifier_date_dist($valeur, $options = array(), &$valeur_normalisee = null) {
26 $erreur = _T('verifier:erreur_date_format');
27 $horaire = false; // par défaut on ne teste qu'une date
29 // Si ce n'est ni une chaîne ni un tableau : pas le bon format
30 if (!is_string($valeur) and !is_array($valeur)) {
34 // Si c'est un tableau
35 if (is_array($valeur)) {
36 // S'il y a les bonnes infos on les garde aux bons endroits
37 if (isset($valeur['date']) and is_string($valeur['date'])
38 and isset($valeur['heure']) and is_string($valeur['heure'])) {
39 $options['heure'] = $valeur['heure']; // l'heure pour la fonction de normalisation
40 $valeur = $valeur['date']; // valeur principale pour la date
41 $horaire = true; // on détecte une vérif avec horaire uniquement dans ce cas
43 // Sinon : pas le bon format
50 // On tolère différents séparateurs
51 $valeur = preg_replace('#\.|/| #i', '-', $valeur);
53 // On vérifie la validité du format
54 $format = isset($options['format']) ?
$options['format'] : 'jma';
57 if (!preg_match('#^[0-9]{1,2}-[0-9]{1,2}-[0-9]{4}$#', $valeur)) {
60 list($mois,$jour,$annee) = explode('-', $valeur);
61 } elseif ($format=='amj') {
62 if (!preg_match('#^[0-9]{4}-[0-9]{1,2}-[0-9]{1,2}$#', $valeur)) {
65 list($annee,$mois,$jour) = explode('-', $valeur);
67 // Format jma par défaut
68 if (!preg_match('#^[0-9]{1,2}-[0-9]{1,2}-[0-9]{4}$#', $valeur)) {
71 list($jour,$mois,$annee) = explode('-', $valeur);
74 // Validité de la date
75 $erreur = _T('verifier:erreur_date');
76 if (!checkdate($mois, $jour, $annee)) {
82 $options['heure'] = str_replace(array('h','m','min'), array(':','',''), $options['heure']);
83 if (!preg_match('#^([0-9]{1,2}):([0-9]{1,2})$#', $options['heure'], $hetm)) {
84 return _T('verifier:erreur_heure_format');
86 // Si c'est le bon format, on teste si les nombres donnés peuvent exister
87 $heures = intval($hetm[1]);
88 $minutes = intval($hetm[2]);
89 if ($heures < 0 or $heures > 23 or $minutes < 0 or $minutes > 59) {
90 return _T('verifier:erreur_heure');
92 // Si tout est bon pour l'heure, on recompose en ajoutant des 0 si besoin
93 $options['heure'] = sprintf('%02d:%02d', $heures, $minutes);
97 // normaliser si demandé
98 if ($options['normaliser'] and $options['normaliser'] == 'datetime') {
99 $valeur_normalisee = normaliser_date_datetime_dist($valeur, $options, $ok);
106 * Convertir une date en datetime
109 function normaliser_date_datetime_dist($valeur, $options, &$erreur) {
110 $defaut = '0000-00-00 00:00:00';
111 if (!$valeur or $valeur==array('date'=>'','heure'=>'')) {
115 $date = str_replace('-', '/', $valeur); // formater en jj/mm/aaaa
117 if (isset($options['heure'])) {
118 $date .= (' ' . $options['heure'] . ':00');
120 $date .= ' 00:00:00';
123 include_spip('inc/filtres');
124 if (!$date = recup_date($date)) {
125 $erreur = "Impossible d'extraire la date de $date";
129 if (!($date = mktime($date[3], $date[4], 0, (int)$date[1], (int)$date[2], (int)$date[0]))) {
130 // mauvais format de date
131 $erreur = 'Impossible de normaliser la date...';
135 $date = date('Y-m-d H:i:s', $date);
136 $date = vider_date($date); // enlever les valeurs considerees comme nulles (1 1 1970, etc...)