summaryrefslogtreecommitdiff
path: root/server/vendor/php-opencloud/common/src/Common/JsonSchema
diff options
context:
space:
mode:
authormanzerbredes <loic.guegan_secondary@yahoo.fr>2016-03-15 16:17:39 +0100
committermanzerbredes <loic.guegan_secondary@yahoo.fr>2016-03-15 16:17:39 +0100
commit26d10bc0fa4befbac54453228ae1ce89021bdec2 (patch)
tree029d7240ecf7416205e5f76cf9107a6b5bdf8ca3 /server/vendor/php-opencloud/common/src/Common/JsonSchema
parent8ad216dedf017f3d6de047a25d08db3b98e16361 (diff)
parent03ef74d0cfe675a6e18a91f039182ca1b248d8f5 (diff)
Merge branch 'develop' into loic
Diffstat (limited to 'server/vendor/php-opencloud/common/src/Common/JsonSchema')
-rw-r--r--server/vendor/php-opencloud/common/src/Common/JsonSchema/JsonPatch.php115
-rw-r--r--server/vendor/php-opencloud/common/src/Common/JsonSchema/Schema.php72
2 files changed, 187 insertions, 0 deletions
diff --git a/server/vendor/php-opencloud/common/src/Common/JsonSchema/JsonPatch.php b/server/vendor/php-opencloud/common/src/Common/JsonSchema/JsonPatch.php
new file mode 100644
index 0000000..2c12ec0
--- /dev/null
+++ b/server/vendor/php-opencloud/common/src/Common/JsonSchema/JsonPatch.php
@@ -0,0 +1,115 @@
+<?php
+
+namespace OpenCloud\Common\JsonSchema;
+
+class JsonPatch
+{
+ const OP_ADD = 'add';
+ const OP_REPLACE = 'replace';
+ const OP_REMOVE = 'remove';
+
+ public static function diff($src, $dest)
+ {
+ return (new static)->makeDiff($src, $dest);
+ }
+
+ public function makeDiff($srcStruct, $desStruct, $path = '')
+ {
+ $changes = [];
+
+ if (is_object($srcStruct)) {
+ $changes = $this->handleObject($srcStruct, $desStruct, $path);
+ } elseif (is_array($srcStruct)) {
+ $changes = $this->handleArray($srcStruct, $desStruct, $path);
+ } elseif ($srcStruct != $desStruct) {
+ $changes[] = $this->makePatch(self::OP_REPLACE, $path, $desStruct);
+ }
+
+ return $changes;
+ }
+
+ protected function handleArray($srcStruct, $desStruct, $path)
+ {
+ $changes = [];
+
+ if ($diff = $this->arrayDiff($desStruct, $srcStruct)) {
+ foreach ($diff as $key => $val) {
+ if (is_object($val)) {
+ $changes = array_merge($changes, $this->makeDiff($srcStruct[$key], $val, $this->path($path, $key)));
+ } else {
+ $op = array_key_exists($key, $srcStruct) && !in_array($srcStruct[$key], $desStruct, true)
+ ? self::OP_REPLACE : self::OP_ADD;
+ $changes[] = $this->makePatch($op, $this->path($path, $key), $val);
+ }
+ }
+ } elseif ($srcStruct != $desStruct) {
+ foreach ($srcStruct as $key => $val) {
+ if (!in_array($val, $desStruct, true)) {
+ $changes[] = $this->makePatch(self::OP_REMOVE, $this->path($path, $key));
+ }
+ }
+ }
+
+ return $changes;
+ }
+
+ protected function handleObject($srcStruct, $desStruct, $path)
+ {
+ $changes = [];
+
+ if ($this->shouldPartiallyReplace($srcStruct, $desStruct)) {
+ foreach ($desStruct as $key => $val) {
+ if (!property_exists($srcStruct, $key)) {
+ $changes[] = $this->makePatch(self::OP_ADD, $this->path($path, $key), $val);
+ } elseif ($srcStruct->$key != $val) {
+ $changes = array_merge($changes, $this->makeDiff($srcStruct->$key, $val, $this->path($path, $key)));
+ }
+ }
+ } elseif ($this->shouldPartiallyReplace($desStruct, $srcStruct)) {
+ foreach ($srcStruct as $key => $val) {
+ if (!property_exists($desStruct, $key)) {
+ $changes[] = $this->makePatch(self::OP_REMOVE, $this->path($path, $key));
+ }
+ }
+ }
+
+ return $changes;
+ }
+
+ protected function shouldPartiallyReplace($o1, $o2)
+ {
+ return count(array_diff_key((array) $o1, (array) $o2)) < count($o1);
+ }
+
+ protected function arrayDiff(array $a1, array $a2)
+ {
+ $result = [];
+
+ foreach ($a1 as $key => $val) {
+ if (!in_array($val, $a2, true)) {
+ $result[$key] = $val;
+ }
+ }
+
+ return $result;
+ }
+
+ protected function path($root, $path)
+ {
+ if ($path === '_empty_') {
+ $path = '';
+ }
+
+ return rtrim($root, '/') . '/' . ltrim($path, '/');
+ }
+
+ protected function makePatch($op, $path, $val = null)
+ {
+ switch ($op) {
+ default:
+ return ['op' => $op, 'path' => $path, 'value' => $val];
+ case self::OP_REMOVE:
+ return ['op' => $op, 'path' => $path];
+ }
+ }
+}
diff --git a/server/vendor/php-opencloud/common/src/Common/JsonSchema/Schema.php b/server/vendor/php-opencloud/common/src/Common/JsonSchema/Schema.php
new file mode 100644
index 0000000..a1cd380
--- /dev/null
+++ b/server/vendor/php-opencloud/common/src/Common/JsonSchema/Schema.php
@@ -0,0 +1,72 @@
+<?php
+
+namespace OpenCloud\Common\JsonSchema;
+
+use JsonSchema\Validator;
+
+class Schema
+{
+ private $body;
+ private $validator;
+
+ public function __construct($body, Validator $validator = null)
+ {
+ $this->body = (object) $body;
+ $this->validator = $validator ?: new Validator();
+ }
+
+ public function getPropertyPaths()
+ {
+ $paths = [];
+
+ foreach ($this->body->properties as $propertyName => $property) {
+ $paths[] = sprintf("/%s", $propertyName);
+ }
+
+ return $paths;
+ }
+
+ public function normalizeObject($subject, array $aliases)
+ {
+ $out = new \stdClass;
+
+ foreach ($this->body->properties as $propertyName => $property) {
+ $name = isset($aliases[$propertyName]) ? $aliases[$propertyName] : $propertyName;
+ if (isset($property->readOnly) && $property->readOnly === true) {
+ continue;
+ } elseif (property_exists($subject, $name)) {
+ $out->$propertyName = $subject->$name;
+ } elseif (property_exists($subject, $propertyName)) {
+ $out->$propertyName = $subject->$propertyName;
+ }
+ }
+
+ return $out;
+ }
+
+ public function validate($data)
+ {
+ $this->validator->check($data, $this->body);
+ }
+
+ public function isValid()
+ {
+ return $this->validator->isValid();
+ }
+
+ public function getErrors()
+ {
+ return $this->validator->getErrors();
+ }
+
+ public function getErrorString()
+ {
+ $msg = "Provided values do not validate. Errors:\n";
+
+ foreach ($this->getErrors() as $error) {
+ $msg .= sprintf("[%s] %s\n", $error['property'], $error['message']);
+ }
+
+ return $msg;
+ }
+}