nur-sery/src/schema/input/Input.php

60 lines
1.7 KiB
PHP
Raw Normal View History

2023-11-09 10:03:35 +04:00
<?php
2023-11-09 10:34:36 +04:00
namespace nur\sery\schema\input;
2023-11-09 10:03:35 +04:00
2023-11-27 22:39:35 +04:00
#XXX available permet de préciser qu'une valeur doit exister et être non vide
# pour être considérée. en faire un paramètre, à moins que ce soit au niveau du
# type qu'il faille le gérer?
2023-11-28 08:20:33 +04:00
use nulib\cl;
2023-11-09 10:03:35 +04:00
/**
* Class Input: accès à une valeur
*
* cette implémentation lit depuis et écrit dans une référence
*/
class Input {
2023-11-28 08:20:33 +04:00
const ALLOW_EMPTY = true;
function __construct(&$dest=null, ?array $params=null) {
2023-11-27 22:39:35 +04:00
$this->dest =& $dest;
2023-11-28 08:20:33 +04:00
$allowEmpty = cl::get($params, "allow_empty");
if ($allowEmpty === null) $allowEmpty = static::ALLOW_EMPTY;
$this->allowEmpty = $allowEmpty;
2023-11-09 10:03:35 +04:00
}
2023-11-27 22:39:35 +04:00
protected $dest;
2023-11-09 10:03:35 +04:00
2023-11-28 08:20:33 +04:00
/** tester si la valeur existe sans tenir compte de $allowEmpty */
2023-12-03 22:44:29 +04:00
function isPresent($key=null): bool {
2023-11-28 08:20:33 +04:00
if ($key === null) return true;
$dest = $this->dest;
return $dest !== null && array_key_exists($key, $dest);
}
/**
* @var bool comment considérer une chaine vide: "" si allowEmpty, null sinon
*/
protected $allowEmpty;
/** tester si la valeur est disponible en tenant compte de $allowEmpty */
2023-12-03 22:44:29 +04:00
function isAvailable($key=null): bool {
2023-11-09 10:03:35 +04:00
if ($key === null) return true;
2023-11-28 08:20:33 +04:00
$dest = $this->dest;
if ($dest === null || !array_key_exists($key, $dest)) return false;
return $this->allowEmpty || $dest[$key] !== "";
2023-11-09 10:03:35 +04:00
}
function get($key=null) {
2023-11-28 08:20:33 +04:00
$dest = $this->dest;
if ($key === null) return $dest;
if ($dest === null || !array_key_exists($key, $dest)) return null;
$value = $dest[$key];
if ($value === "" && !$this->allowEmpty) return null;
return $value;
2023-11-09 10:03:35 +04:00
}
function set($value, $key=null): void {
2023-11-27 22:39:35 +04:00
if ($key === null) $this->dest = $value;
else $this->dest[$key] = $value;
2023-11-09 10:03:35 +04:00
}
}