mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
ba2c5b48f7
BUG Remove assignment of IDs to singletons API relation methods can take an optional $id parameter to get relations from specific parents API Added UnsavedRelationList::relation() method
89 lines
2.4 KiB
PHP
89 lines
2.4 KiB
PHP
<?php
|
|
|
|
namespace SilverStripe\ORM;
|
|
|
|
use Exception;
|
|
|
|
/**
|
|
* A DataList that represents a relation.
|
|
*
|
|
* Adds the notion of a foreign ID that can be optionally set.
|
|
*/
|
|
abstract class RelationList extends DataList implements Relation
|
|
{
|
|
|
|
/**
|
|
* Any number of foreign keys to apply to this list
|
|
*
|
|
* @return string|array|null
|
|
*/
|
|
public function getForeignID()
|
|
{
|
|
return $this->dataQuery->getQueryParam('Foreign.ID');
|
|
}
|
|
|
|
public function getQueryParams()
|
|
{
|
|
$params = parent::getQueryParams();
|
|
|
|
// Remove `Foreign.` query parameters for created objects,
|
|
// as this would interfere with relations on those objects.
|
|
foreach (array_keys($params) as $key) {
|
|
if (stripos($key, 'Foreign.') === 0) {
|
|
unset($params[$key]);
|
|
}
|
|
}
|
|
|
|
return $params;
|
|
}
|
|
|
|
/**
|
|
* Returns a copy of this list with the ManyMany relationship linked to
|
|
* the given foreign ID.
|
|
*
|
|
* @param int|array $id An ID or an array of IDs.
|
|
*
|
|
* @return static
|
|
*/
|
|
public function forForeignID($id)
|
|
{
|
|
// Turn a 1-element array into a simple value
|
|
if (is_array($id) && sizeof($id) == 1) {
|
|
$id = reset($id);
|
|
}
|
|
|
|
// Calculate the new filter
|
|
$filter = $this->foreignIDFilter($id);
|
|
|
|
$list = $this->alterDataQuery(function (DataQuery $query) use ($id, $filter) {
|
|
// Check if there is an existing filter, remove if there is
|
|
$currentFilter = $query->getQueryParam('Foreign.Filter');
|
|
if ($currentFilter) {
|
|
try {
|
|
$query->removeFilterOn($currentFilter);
|
|
} catch (Exception $e) {
|
|
/* NOP */
|
|
}
|
|
}
|
|
|
|
// Add the new filter
|
|
$query->setQueryParam('Foreign.ID', $id);
|
|
$query->setQueryParam('Foreign.Filter', $filter);
|
|
$query->where($filter);
|
|
});
|
|
|
|
return $list;
|
|
}
|
|
|
|
/**
|
|
* Returns a where clause that filters the members of this relationship to
|
|
* just the related items.
|
|
*
|
|
*
|
|
* @param array|integer $id (optional) An ID or an array of IDs - if not provided, will use the current ids as
|
|
* per getForeignID
|
|
* @return array Condition In array(SQL => parameters format)
|
|
*/
|
|
abstract protected function foreignIDFilter($id = null);
|
|
}
|