Merge branch '4.3' into 4

This commit is contained in:
Dan Hensby 2019-03-06 11:04:50 +00:00
commit 765d1568ab
No known key found for this signature in database
GPG Key ID: 3906B235643EF10B
4 changed files with 45 additions and 7 deletions

View File

@ -196,7 +196,7 @@ class RequestHandler extends ViewableData
if (!$this->hasAction($action)) { if (!$this->hasAction($action)) {
return $this->httpError(404, "Action '$action' isn't available $classMessage."); return $this->httpError(404, "Action '$action' isn't available $classMessage.");
} }
if (!$this->checkAccessAction($action) || in_array(strtolower($action), ['run', 'doInit'])) { if (!$this->checkAccessAction($action) || in_array(strtolower($action), ['run', 'doinit'])) {
return $this->httpError(403, "Action '$action' isn't allowed $classMessage."); return $this->httpError(403, "Action '$action' isn't allowed $classMessage.");
} }
$result = $this->handleAction($request, $action); $result = $this->handleAction($request, $action);
@ -414,7 +414,7 @@ class RequestHandler extends ViewableData
$actionsWithoutExtra = $this->config()->get('allowed_actions', true); $actionsWithoutExtra = $this->config()->get('allowed_actions', true);
if (!is_array($actions) || !$actionsWithoutExtra) { if (!is_array($actions) || !$actionsWithoutExtra) {
if ($action != 'doInit' && $action != 'run' && method_exists($this, $action)) { if (!in_array(strtolower($action), ['run', 'doinit']) && method_exists($this, $action)) {
return true; return true;
} }
} }

View File

@ -1421,8 +1421,10 @@ class DataObject extends ViewableData implements DataObjectInterface, i18nEntity
// Inserts done one the base table are performed in another step, so the manipulation should instead // Inserts done one the base table are performed in another step, so the manipulation should instead
// attempt an update, as though it were a normal update. // attempt an update, as though it were a normal update.
$manipulation[$table]['command'] = $isNewRecord ? 'insert' : 'update'; $manipulation[$table]['command'] = $isNewRecord ? 'insert' : 'update';
$manipulation[$table]['id'] = $this->record['ID'];
$manipulation[$table]['class'] = $class; $manipulation[$table]['class'] = $class;
if ($this->isInDB()) {
$manipulation[$table]['id'] = $this->record['ID'];
}
} }
/** /**
@ -1441,10 +1443,10 @@ class DataObject extends ViewableData implements DataObjectInterface, i18nEntity
} }
// Perform an insert on the base table // Perform an insert on the base table
$insert = new SQLInsert('"' . $baseTable . '"'); $manipulation = [];
$insert $this->prepareManipulationTable($baseTable, $now, true, $manipulation, $this->baseClass());
->assign('"Created"', $now) DB::manipulate($manipulation);
->execute();
$this->changed['ID'] = self::CHANGE_VALUE; $this->changed['ID'] = self::CHANGE_VALUE;
$this->record['ID'] = DB::get_generated_id($baseTable); $this->record['ID'] = DB::get_generated_id($baseTable);
} }

View File

@ -343,4 +343,35 @@ class DataObjectSchemaTest extends SapphireTest
'columns' => ['IndexedMoneyCurrency', 'IndexedMoneyAmount'] 'columns' => ['IndexedMoneyCurrency', 'IndexedMoneyAmount']
], $indexes['IndexedMoney']); ], $indexes['IndexedMoney']);
} }
/**
* Ensure that records with unique indexes can be written
*/
public function testWriteUniqueIndexes()
{
// Create default object
$zeroObject = new AllIndexes();
$zeroObject->Number = 0;
$zeroObject->write();
$this->assertListEquals(
[
['Number' => 0],
],
AllIndexes::get()
);
// Test a new record can be created without clashing with default value
$validObject = new AllIndexes();
$validObject->Number = 1;
$validObject->write();
$this->assertListEquals(
[
['Number' => 0],
['Number' => 1],
],
AllIndexes::get()
);
}
} }

View File

@ -5,6 +5,11 @@ use SilverStripe\Dev\TestOnly;
use SilverStripe\ORM\DataObject; use SilverStripe\ORM\DataObject;
use SilverStripe\ORM\FieldType\DBIndexable; use SilverStripe\ORM\FieldType\DBIndexable;
/**
* @property int $Number
* @property string $Content
* @property string $Title
*/
class AllIndexes extends DataObject implements TestOnly class AllIndexes extends DataObject implements TestOnly
{ {
private static $table_name = 'DataObjectSchemaTest_AllIndexes'; private static $table_name = 'DataObjectSchemaTest_AllIndexes';