Merge pull request #1639 from open-sausages/pulls/4.0/many-many-through

API Update for DataObjectSchema changes
This commit is contained in:
Ingo Schommer 2016-10-07 09:44:42 +13:00 committed by GitHub
commit ae9e05c99d
3 changed files with 15 additions and 6 deletions

View File

@ -8,6 +8,7 @@ use SilverStripe\Core\ClassInfo;
use SilverStripe\Core\Object; use SilverStripe\Core\Object;
use SilverStripe\Forms\DateField; use SilverStripe\Forms\DateField;
use SilverStripe\ORM\DataList; use SilverStripe\ORM\DataList;
use SilverStripe\ORM\DataObject;
use SilverStripe\ORM\SS_List; use SilverStripe\ORM\SS_List;
use SilverStripe\ORM\Versioning\Versioned; use SilverStripe\ORM\Versioning\Versioned;
@ -212,8 +213,9 @@ abstract class CMSSiteTreeFilter extends Object implements LeftAndMain_SearchFil
break; break;
default: default:
if($sng->hasDatabaseField($name)) { $field = $sng->dbObject($name);
$filter = $sng->dbObject($name)->defaultSearchFilter(); if($field) {
$filter = $field->defaultSearchFilter();
$filter->setValue($val); $filter->setValue($val);
$query = $query->alterDataQuery(array($filter, 'apply')); $query = $query->alterDataQuery(array($filter, 'apply'));
} }

View File

@ -4,6 +4,7 @@ namespace SilverStripe\CMS\Model;
use SilverStripe\Core\Injector\Injector; use SilverStripe\Core\Injector\Injector;
use SilverStripe\ORM\DataExtension; use SilverStripe\ORM\DataExtension;
use SilverStripe\ORM\DataObject;
use SilverStripe\ORM\FieldType\DBHTMLText; use SilverStripe\ORM\FieldType\DBHTMLText;
use SilverStripe\ORM\ManyManyList; use SilverStripe\ORM\ManyManyList;
use SilverStripe\ORM\Versioning\Versioned; use SilverStripe\ORM\Versioning\Versioned;
@ -168,7 +169,10 @@ class SiteTreeLinkTracking extends DataExtension {
} }
// Update the "LinkTracking" many_many // Update the "LinkTracking" many_many
if($record->ID && $record->manyManyComponent('LinkTracking') && ($tracker = $record->LinkTracking())) { if($record->ID
&& $record->getSchema()->manyManyComponent(get_class($record), 'LinkTracking')
&& ($tracker = $record->LinkTracking())
) {
$tracker->removeByFilter(array( $tracker->removeByFilter(array(
sprintf('"FieldName" = ? AND "%s" = ?', $tracker->getForeignKey()) sprintf('"FieldName" = ? AND "%s" = ?', $tracker->getForeignKey())
=> array($fieldName, $record->ID) => array($fieldName, $record->ID)
@ -180,7 +184,10 @@ class SiteTreeLinkTracking extends DataExtension {
} }
// Update the "ImageTracking" many_many // Update the "ImageTracking" many_many
if($record->ID && $record->manyManyComponent('ImageTracking') && ($tracker = $record->ImageTracking())) { if($record->ID
&& $record->getSchema()->manyManyComponent(get_class($record), 'ImageTracking')
&& ($tracker = $record->ImageTracking())
) {
$tracker->removeByFilter(array( $tracker->removeByFilter(array(
sprintf('"FieldName" = ? AND "%s" = ?', $tracker->getForeignKey()) sprintf('"FieldName" = ? AND "%s" = ?', $tracker->getForeignKey())
=> array($fieldName, $record->ID) => array($fieldName, $record->ID)
@ -208,7 +215,7 @@ class SiteTreeLinkTracking extends DataExtension {
$this->owner->HasBrokenFile = false; $this->owner->HasBrokenFile = false;
// Build a list of HTMLText fields // Build a list of HTMLText fields
$allFields = $this->owner->db(); $allFields = DataObject::getSchema()->fieldSpecs($this->owner);
$htmlFields = array(); $htmlFields = array();
foreach($allFields as $field => $fieldSpec) { foreach($allFields as $field => $fieldSpec) {
$fieldObj = $this->owner->dbObject($field); $fieldObj = $this->owner->dbObject($field);

View File

@ -87,7 +87,7 @@ class VirtualPage extends Page {
} }
// Diff db with non-virtual fields // Diff db with non-virtual fields
$fields = array_keys($record->db()); $fields = array_keys(static::getSchema()->fieldSpecs($record));
$nonVirtualFields = $this->getNonVirtualisedFields(); $nonVirtualFields = $this->getNonVirtualisedFields();
return array_diff($fields, $nonVirtualFields); return array_diff($fields, $nonVirtualFields);
} }