X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FUtil%2FJsonLD.php;h=cf1e058a1478711535a950c5cb63bfe2f1c7f0f6;hb=55db2670d1662b32c6faa820c60c44e16cffab20;hp=c20d4846bfe58042f32a4779e520e5b134e00895;hpb=c21d991208c0ed454e41b851d726d195bbc2077f;p=friendica.git diff --git a/src/Util/JsonLD.php b/src/Util/JsonLD.php index c20d4846bf..cf1e058a14 100644 --- a/src/Util/JsonLD.php +++ b/src/Util/JsonLD.php @@ -1,6 +1,6 @@ $url]); + break; + } + $recursion = 0; $x = debug_backtrace(); @@ -69,19 +82,6 @@ class JsonLD return $data; } - private static function replaceSecurityLink(array $json) - { - if (!is_array($json['@context'])) { - return $json; - } - - if (($key = array_search('https://w3id.org/security/v1', $json['@context'])) !== false) { - $json['@context'][$key] = DI::baseUrl() . '/static/w3id-security-v1.json'; - } - - return $json; - } - /** * Normalises a given JSON array * @@ -92,8 +92,6 @@ class JsonLD */ public static function normalize($json) { - $json = self::replaceSecurityLink($json); - jsonld_set_document_loader('Friendica\Util\JsonLD::documentLoader'); $jsonobj = json_decode(json_encode($json, JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE)); @@ -128,19 +126,6 @@ class JsonLD */ public static function compact($json) { - $compacted = self::internalCompact($json, false); - if (empty($compacted)) { - $json['@context'] = ActivityPub::CONTEXT; - $compacted = self::internalCompact($json, true); - } - - return $compacted; - } - - private static function internalCompact($json, bool $error_log) - { - $json = self::replaceSecurityLink($json); - jsonld_set_document_loader('Friendica\Util\JsonLD::documentLoader'); $context = (object)['as' => 'https://www.w3.org/ns/activitystreams#', @@ -154,7 +139,9 @@ class JsonLD 'toot' => (object)['@id' => 'http://joinmastodon.org/ns#', '@type' => '@id'], 'litepub' => (object)['@id' => 'http://litepub.social/ns#', '@type' => '@id'], 'sc' => (object)['@id' => 'http://schema.org#', '@type' => '@id'], - 'pt' => (object)['@id' => 'https://joinpeertube.org/ns#', '@type' => '@id']]; + 'pt' => (object)['@id' => 'https://joinpeertube.org/ns#', '@type' => '@id'], + 'mobilizon' => (object)['@id' => 'https://joinmobilizon.org/ns#', '@type' => '@id'], + ]; // Preparation for adding possibly missing content to the context if (!empty($json['@context']) && is_string($json['@context'])) { @@ -164,7 +151,7 @@ class JsonLD // Workaround for servers with missing context // See issue https://github.com/nextcloud/social/issues/330 if (!empty($json['@context']) && is_array($json['@context'])) { - $json['@context'][] = DI::baseUrl() . '/static/w3id-security-v1.json'; + $json['@context'][] = 'https://w3id.org/security/v1'; } // Trying to avoid memory problems with large content fields @@ -180,9 +167,7 @@ class JsonLD } catch (Exception $e) { $compacted = false; - if ($error_log) { - Logger::error('compacting error', ['line' => $e->getLine(), 'message' => $e->getMessage(),'callstack' => System::callstack(20)]); - } + Logger::notice('compacting error', ['line' => $e->getLine(), 'exception' => $e]); } $json = json_decode(json_encode($compacted, JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE), true); @@ -210,7 +195,7 @@ class JsonLD } // If it isn't an array yet, make it to one - if (!is_int(key($array[$element]))) { + if (!is_array($array[$element]) || !is_int(key($array[$element]))) { $array[$element] = [$array[$element]]; }