From e6fca326a576557d0a25c14cab9561846a8372ed Mon Sep 17 00:00:00 2001 From: Sebastian Helzle Date: Tue, 26 Sep 2023 12:24:35 +0200 Subject: [PATCH] BUGFIX: Reduce nodetype schema size MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit With this change the following optimisations are done to improve speed and reduce size of the schema generation: * Abstract nodetypes are not queried anymore for constraints as they are already resolved by the nodetype manager. * Entries in the inheritance map and constraints will be skipped if they don’t contain any data. These optimisations reduce the size of the schema in the Neos.Demo from ~380KB to ~307KB and improve the response time by ~20%. The more nodetypes a project has, the bigger the benefit is. --- .../Classes/Service/NodeTypeSchemaBuilder.php | 42 +++++++++++-------- 1 file changed, 24 insertions(+), 18 deletions(-) diff --git a/Neos.Neos/Classes/Service/NodeTypeSchemaBuilder.php b/Neos.Neos/Classes/Service/NodeTypeSchemaBuilder.php index 50f5347bee2..c9464c20770 100644 --- a/Neos.Neos/Classes/Service/NodeTypeSchemaBuilder.php +++ b/Neos.Neos/Classes/Service/NodeTypeSchemaBuilder.php @@ -12,7 +12,6 @@ */ use Neos\Flow\Annotations as Flow; -use Neos\ContentRepository\Domain\Model\NodeType; /** * Renders the Node Type Schema in a format the User Interface understands; additionally pre-calculating node constraints @@ -54,19 +53,24 @@ public function generateNodeTypeSchema() 'constraints' => $this->generateConstraints() ]; + // We need to include abstract nodetypes as the UI required some basic types like Neos.Neos:Document and Neos.Neos:Content $nodeTypes = $this->nodeTypeManager->getNodeTypes(true); - /** @var NodeType $nodeType */ foreach ($nodeTypes as $nodeTypeName => $nodeType) { if ($nodeType->isAbstract() === false) { $configuration = $nodeType->getFullConfiguration(); $schema['nodeTypes'][$nodeTypeName] = $configuration; $schema['nodeTypes'][$nodeTypeName]['label'] = $nodeType->getLabel(); + + // Remove the postprocessors, as they are not needed in the UI + unset($schema['nodeTypes'][$nodeTypeName]['postprocessors']); } - $schema['inheritanceMap']['subTypes'][$nodeTypeName] = []; - foreach ($this->nodeTypeManager->getSubNodeTypes($nodeType->getName(), true) as $subNodeType) { - /** @var NodeType $subNodeType */ - $schema['inheritanceMap']['subTypes'][$nodeTypeName][] = $subNodeType->getName(); + $subTypes = []; + foreach ($this->nodeTypeManager->getSubNodeTypes($nodeType->getName(), false) as $subNodeType) { + $subTypes[] = $subNodeType->getName(); + } + if ($subTypes) { + $schema['inheritanceMap']['subTypes'][$nodeTypeName] = $subTypes; } } @@ -81,29 +85,31 @@ public function generateNodeTypeSchema() protected function generateConstraints() { $constraints = []; - $nodeTypes = $this->nodeTypeManager->getNodeTypes(true); - /** @var NodeType $nodeType */ + $nodeTypes = $this->nodeTypeManager->getNodeTypes(false); foreach ($nodeTypes as $nodeTypeName => $nodeType) { - if ($nodeType->isAbstract()) { - continue; - } - $constraints[$nodeTypeName] = [ - 'nodeTypes' => [], - 'childNodes' => [] - ]; + $nodeTypeConstraints = []; + $childNodeConstraints = []; + foreach ($nodeTypes as $innerNodeTypeName => $innerNodeType) { if ($nodeType->allowsChildNodeType($innerNodeType)) { - $constraints[$nodeTypeName]['nodeTypes'][$innerNodeTypeName] = true; + $nodeTypeConstraints[$innerNodeTypeName] = true; } } - foreach ($nodeType->getAutoCreatedChildNodes() as $key => $_x) { + foreach (array_keys($nodeType->getAutoCreatedChildNodes()) as $key) { foreach ($nodeTypes as $innerNodeTypeName => $innerNodeType) { if ($nodeType->allowsGrandchildNodeType($key, $innerNodeType)) { - $constraints[$nodeTypeName]['childNodes'][$key]['nodeTypes'][$innerNodeTypeName] = true; + $childNodeConstraints[$key]['nodeTypes'][$innerNodeTypeName] = true; } } } + + if ($nodeTypeConstraints || $childNodeConstraints) { + $constraints[$nodeTypeName] = [ + 'nodeTypes' => $nodeTypeConstraints, + 'childNodes' => $childNodeConstraints, + ]; + } } return $constraints;