From c931eb10fbce36df91bc1573de3b0e9101b1e51f Mon Sep 17 00:00:00 2001 From: Sam Minnee Date: Wed, 25 Feb 2009 01:53:16 +0000 Subject: [PATCH] BUGFIX: Prevent infinite redirection when the homepage isn't available, when using modules such as subsites. git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/branches/2.3@72200 467b73ca-7a2a-4603-9d3b-597d59a354a9 --- core/control/ModelAsController.php | 37 +++++++++++++++++++++--------- 1 file changed, 26 insertions(+), 11 deletions(-) diff --git a/core/control/ModelAsController.php b/core/control/ModelAsController.php index afc1e20f4..6f8352abe 100644 --- a/core/control/ModelAsController.php +++ b/core/control/ModelAsController.php @@ -39,11 +39,11 @@ class ModelAsController extends Controller implements NestedController { $url = Controller::join_links( Director::baseURL(), $child->URLSegment, - $this->urlParams['Action'], - $this->urlParams['ID'], - $this->urlParams['OtherID'] + isset($this->urlParams['Action']) ? $this->urlParams['Action'] : null, + isset($this->urlParams['ID']) ? $this->urlParams['ID'] : null, + isset($this->urlParams['OtherID']) ? $this->urlParams['OtherID'] : null ); - + $response = new HTTPResponse(); $response->redirect($url, 301); return $response; @@ -78,17 +78,32 @@ class ModelAsController extends Controller implements NestedController { } protected function findOldPage($urlSegment) { - $versionedQuery = new SQLQuery ( - 'RecordID', 'SiteTree_versions', - "`WasPublished` = 1 AND `URLSegment` = '$urlSegment'", - '`LastEdited` DESC, `WasPublished`', - null, null, 1 - ); + // Build the query by replacing `SiteTree` with `SiteTree_versions` in a regular query. + // Note that this should *really* be handled by a more full-featured data mapper; as it stands + // this is a bit of a hack. + $origStage = Versioned::current_stage(); + Versioned::reading_stage('Stage'); + $versionedQuery = singleton('SiteTree')->extendedSQL(''); + Versioned::reading_stage($origStage); + foreach($versionedQuery->from as $k => $v) { + $versionedQuery->renameTable($k, $k . '_versions'); + } + $versionedQuery->select = array("`SiteTree_versions`.RecordID"); + $versionedQuery->where[] = "`SiteTree_versions`.`WasPublished` = 1 AND `URLSegment` = '$urlSegment'"; + $versionedQuery->orderby = '`LastEdited` DESC, `SiteTree_versions`.`WasPublished`'; + $versionedQuery->limit = 1; + $result = $versionedQuery->execute(); if($result->numRecords() == 1 && $redirectPage = $result->nextRecord()) { - if($redirectObj = DataObject::get_by_id('SiteTree', $redirectPage['RecordID'])) return $redirectObj; + $redirectObj = DataObject::get_by_id('SiteTree', $redirectPage['RecordID']); + if($redirectObj) { + // Double-check by querying this page in the same way that getNestedController() does. This + // will prevent query muck-ups from modules such as subsites + $doubleCheck = SiteTree::get_by_url($redirectObj->URLSegment); + if($doubleCheck) return $redirectObj; + } } return false;