From 6d9e8f6aebb2f9b8f9bcdd0058afbfebbc198b23 Mon Sep 17 00:00:00 2001 From: Guy Sartorelli Date: Mon, 4 Dec 2023 17:49:54 +1300 Subject: [PATCH] ENH Respect new has_one config has_one can now optionally have an array configuration to allow supporting multiple reciprocal has_many in a single has_one relation. --- composer.json | 4 ++-- src/RecursivePublishable.php | 19 ++++++++++++++----- 2 files changed, 16 insertions(+), 7 deletions(-) diff --git a/composer.json b/composer.json index 1321d201..fec7e9b2 100755 --- a/composer.json +++ b/composer.json @@ -20,7 +20,7 @@ ], "require": { "php": "^8.1", - "silverstripe/framework": "^5", + "silverstripe/framework": "^5.2", "symfony/cache": "^6.1", "silverstripe/vendor-plugin": "^2" }, @@ -44,4 +44,4 @@ }, "minimum-stability": "dev", "prefer-stable": true -} \ No newline at end of file +} diff --git a/src/RecursivePublishable.php b/src/RecursivePublishable.php index c25698bc..0407b353 100644 --- a/src/RecursivePublishable.php +++ b/src/RecursivePublishable.php @@ -381,7 +381,9 @@ public function unlinkDisownedRelationship($source, $targetStage, $relationship) } // Find table and field to join on - $joinField = $schema->getRemoteJoinField(get_class($owner), $relationship, 'has_many', $polymorphic); + $hasManyDetails = $schema->getHasManyComponentDetails(get_class($owner), $relationship); + $polymorphic = $hasManyDetails['polymorphic']; + $joinField = $hasManyDetails['joinField']; $joinTable = DataObject::getSchema()->tableForField( $joinClass, $polymorphic ? "{$joinField}ID" : $joinField @@ -391,13 +393,20 @@ public function unlinkDisownedRelationship($source, $targetStage, $relationship) $targetTable = $versioned->stageTable($joinTable, $targetStage); $disowned = new SQLUpdate("\"{$targetTable}\""); if ($polymorphic) { + $where = [ + "\"{$targetTable}\".\"{$joinField}ID\"" => $owner->ID, + "\"{$targetTable}\".\"{$joinField}Class\"" => get_class($owner), + ]; + + if ($hasManyDetails['needsRelation']) { + $disowned->assign("\"{$joinField}Relation\"", null); + $where["\"{$targetTable}\".\"{$joinField}Relation\""] = $relationship; + } + $disowned ->assign("\"{$joinField}ID\"", 0) ->assign("\"{$joinField}Class\"", null) - ->addWhere([ - "\"{$targetTable}\".\"{$joinField}ID\"" => $owner->ID, - "\"{$targetTable}\".\"{$joinField}Class\"" => get_class($owner), - ]); + ->addWhere($where); } else { $disowned ->assign("\"{$joinField}\"", 0)