mirror of
https://gitlab.easter-eggs.com/ee/ldapsaisie.git
synced 2024-11-22 01:49:08 +01:00
LSattr_ldap:📅 replace unique format parameter by a list
This commit is contained in:
parent
fde66b2335
commit
05519c5432
2 changed files with 41 additions and 22 deletions
|
@ -18,7 +18,11 @@
|
|||
<citetitle>Structure</citetitle>...
|
||||
<![CDATA['ldap_options' => array (
|
||||
'timestamp' => [Booléen], // Si la date est stockée au format timestamp
|
||||
'format' => '[Format de stockage]', // Default : "YmdHisO"
|
||||
'formats' => array(
|
||||
'[Format de stockage principal]', // Par défaut : "YmdHisO"
|
||||
'[Formats de stockage alternatifs]', // Par défaut : "YmdHis.vO" & "YmdHis.uO"
|
||||
[...]
|
||||
),
|
||||
'timezone' => '[Fuseau horaire]', // Default : "UTC"
|
||||
),]]>
|
||||
...
|
||||
|
@ -39,26 +43,30 @@
|
|||
</varlistentry>
|
||||
|
||||
<varlistentry>
|
||||
<term>format</term>
|
||||
<term>formats</term>
|
||||
<listitem>
|
||||
<para>Format de stockage de la date dans l'annuaire. Ce format est composé à
|
||||
<para>Formats de stockage de la date dans l'annuaire. Ces formats sont composés à
|
||||
partir des motifs clés gérés par la fonction <function>date()</function>
|
||||
de &php;. Pour plus d'information, consulter
|
||||
<ulink url='http://www.php.net/date'>la documentation officielle</ulink>.
|
||||
<note><simpara>La valeur par défaut est <emphasis>YmdHisO</emphasis>,
|
||||
correspondant à la syntaxe <literal>Generalized Time</literal> (sans les
|
||||
micro-secondes) telle que définie dans la
|
||||
<ulink url='http://www.php.net/date'>la documentation officielle</ulink>. Plusieurs
|
||||
formats peuvent être définis, mais en cas de stockage d'une nouvelle valeur, se sera
|
||||
le premier format défini qui sera utilisé.
|
||||
<note><simpara>La valeur par défaut est <emphasis>["YmdHisO", "YmdHis.vO", "YmdHis.uO"]</emphasis>,
|
||||
correspondant à la syntaxe <literal>Generalized Time</literal> (sans et avec les milli-secondes
|
||||
ou micro-secondes) telle que définie dans la
|
||||
<ulink url='https://tools.ietf.org/html/rfc4517'>RFC4517</ulink>. Exemples :
|
||||
<literal>20091206230506Z</literal>
|
||||
<emphasis>(=2009/12/06 23:05:66 UTC)</emphasis> ou
|
||||
<emphasis>(=2009/12/06 23:05:66 UTC)</emphasis>,
|
||||
<literal>20190613143537+0200</literal>
|
||||
<emphasis>(=2019/06/13 14:35:37 UTC+0200)</emphasis>.</simpara></note>
|
||||
<emphasis>(=2019/06/13 14:35:37 UTC+0200)</emphasis> ou
|
||||
<literal>20230818121005.307+0200</literal>
|
||||
<emphasis>(=2023/08/18 12:10:05.307 UTC+0200)</emphasis>.</simpara></note>
|
||||
<warning><simpara>Si vous exploitez un attribut stockant une date incluant les
|
||||
micro-secondes, ce type d'attribut LDAP sera capable de gérer l'interpratation des
|
||||
valeurs stockées en configurant le format <literal>YmdHis.uO</literal>. En outre,
|
||||
le type d'attribut &LSattr_html_date;, s'appuyant sur les méthodes standards
|
||||
<literal>strftime()</literal> et <literal>strptime()</literal>, ne permettra pas
|
||||
aujourd'hui la saisie et l'affichage des millisecondes.</simpara></warning>
|
||||
milli-secondes ou les micro-secondes, ce type d'attribut LDAP sera capable de gérer
|
||||
l'interpratation des valeurs stockées, en outre le type d'attribut &LSattr_html_date;,
|
||||
s'appuyant sur les méthodes standards <literal>strftime()</literal> et
|
||||
<literal>strptime()</literal>, ne permettra pas aujourd'hui leur saisie et affichage.
|
||||
</simpara></warning>
|
||||
</para>
|
||||
|
||||
</listitem>
|
||||
|
|
|
@ -40,9 +40,12 @@ class LSattr_ldap_date extends LSattr_ldap {
|
|||
}
|
||||
$retval=array();
|
||||
foreach($data as $val) {
|
||||
$datetime = date_create_from_format($this -> getFormat(), $val);
|
||||
if ($datetime instanceof DateTime) {
|
||||
$retval[] = $datetime -> format('U');
|
||||
foreach($this -> getFormats() as $format) {
|
||||
$datetime = date_create_from_format($format, $val);
|
||||
if ($datetime instanceof DateTime) {
|
||||
$retval[] = $datetime -> format('U');
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
return $retval;
|
||||
|
@ -65,7 +68,7 @@ class LSattr_ldap_date extends LSattr_ldap {
|
|||
foreach($data as $val) {
|
||||
$datetime = date_create("@$val");
|
||||
$datetime -> setTimezone($timezone);
|
||||
$datetime_string = $datetime -> format($this -> getFormat());
|
||||
$datetime_string = $datetime -> format($this -> getFormats(true));
|
||||
|
||||
// Replace +0000 or -0000 end by Z
|
||||
$datetime_string = preg_replace('/[\+\-]0000$/', 'Z', $datetime_string);
|
||||
|
@ -76,12 +79,20 @@ class LSattr_ldap_date extends LSattr_ldap {
|
|||
}
|
||||
|
||||
/**
|
||||
* Return the storage date format
|
||||
* Return the storage date formats
|
||||
* Note: The first one will be used to store the value
|
||||
*
|
||||
* @return string The storage date format
|
||||
* @return array<string> The storage date formats
|
||||
**/
|
||||
public function getFormat() {
|
||||
return $this -> getConfig('ldap_options.format', 'YmdHisO');
|
||||
public function getFormats($first=false) {
|
||||
$formats = $this -> getConfig('ldap_options.formats', [], 'array');
|
||||
if (!$formats) {
|
||||
$format = $this -> getConfig('ldap_options.format');
|
||||
$formats = $format ? [$format] : ['YmdHisO', 'YmdHis.vO', 'YmdHis.uO'];
|
||||
}
|
||||
if ($first)
|
||||
return $formats?$formats[0]:null;
|
||||
return $formats;
|
||||
}
|
||||
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue