summaryrefslogtreecommitdiffstats
path: root/library/Director/Data/DataArrayHelper.php
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-14 13:17:31 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-14 13:17:31 +0000
commitf66ab8dae2f3d0418759f81a3a64dc9517a62449 (patch)
treefbff2135e7013f196b891bbde54618eb050e4aaf /library/Director/Data/DataArrayHelper.php
parentInitial commit. (diff)
downloadicingaweb2-module-director-f66ab8dae2f3d0418759f81a3a64dc9517a62449.tar.xz
icingaweb2-module-director-f66ab8dae2f3d0418759f81a3a64dc9517a62449.zip
Adding upstream version 1.10.2.upstream/1.10.2
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'library/Director/Data/DataArrayHelper.php')
-rw-r--r--library/Director/Data/DataArrayHelper.php48
1 files changed, 48 insertions, 0 deletions
diff --git a/library/Director/Data/DataArrayHelper.php b/library/Director/Data/DataArrayHelper.php
new file mode 100644
index 0000000..442eb0f
--- /dev/null
+++ b/library/Director/Data/DataArrayHelper.php
@@ -0,0 +1,48 @@
+<?php
+
+namespace Icinga\Module\Director\Data;
+
+use InvalidArgumentException;
+use function array_diff;
+use function array_key_exists;
+use function implode;
+use function is_array;
+use function is_object;
+
+class DataArrayHelper
+{
+ public static function wantArray($value)
+ {
+ if (is_object($value)) {
+ return (array) $value;
+ }
+ if (! is_array($value)) {
+ throw new InvalidDataException('Object', $value);
+ }
+
+ return $value;
+ }
+
+ public static function failOnUnknownProperties(array $values, array $knownProperties)
+ {
+ $unknownProperties = array_diff($knownProperties, array_keys($values));
+
+ if (! empty($unknownProperties)) {
+ throw new InvalidArgumentException('Unexpected properties: ' . implode(', ', $unknownProperties));
+ }
+ }
+
+ public static function requireProperties(array $value, array $properties)
+ {
+ $missing = [];
+ foreach ($properties as $property) {
+ if (! array_key_exists($property, $value)) {
+ $missing[] = $property;
+ }
+ }
+
+ if (! empty($missing)) {
+ throw new InvalidArgumentException('Missing properties: ' . implode(', ', $missing));
+ }
+ }
+}