mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
Merged changes from 2.2.2-assets - everything except the asset refactoring
git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/trunk@60468 467b73ca-7a2a-4603-9d3b-597d59a354a9
This commit is contained in:
parent
b5001bc906
commit
0bd9bc4ff8
@ -92,11 +92,9 @@ if(isset($_FILE_TO_URL_MAPPING)) {
|
|||||||
}
|
}
|
||||||
$testPath = dirname($testPath);
|
$testPath = dirname($testPath);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if(ManifestBuilder::staleManifest()){
|
if(ManifestBuilder::staleManifest()){
|
||||||
ManifestBuilder::compileManifest();
|
ManifestBuilder::compileManifest();
|
||||||
}
|
}
|
||||||
|
@ -11,6 +11,9 @@ abstract class CliController extends Controller {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function index() {
|
function index() {
|
||||||
|
// Always re-compile the manifest (?flush=1)
|
||||||
|
ManifestBuilder::compileManifest();
|
||||||
|
|
||||||
foreach( ClassInfo::subclassesFor( $this->class ) as $subclass ) {
|
foreach( ClassInfo::subclassesFor( $this->class ) as $subclass ) {
|
||||||
echo $subclass;
|
echo $subclass;
|
||||||
|
|
||||||
|
16
cli/HourlyTask.php
Normal file
16
cli/HourlyTask.php
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @package sapphire
|
||||||
|
* @subpackage cron
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Classes that must be run hourly extend this class
|
||||||
|
* @package sapphire
|
||||||
|
* @subpackage cron
|
||||||
|
*/
|
||||||
|
class HourlyTask extends ScheduledTask {
|
||||||
|
|
||||||
|
}
|
||||||
|
?>
|
@ -128,7 +128,9 @@ class ClassInfo {
|
|||||||
static function ancestry($class, $onlyWithTables = false) {
|
static function ancestry($class, $onlyWithTables = false) {
|
||||||
global $_ALL_CLASSES;
|
global $_ALL_CLASSES;
|
||||||
|
|
||||||
if(!is_string($class)) $class = $class->class;
|
if(is_object($class)) $class = $class->class;
|
||||||
|
else if(!is_string($class)) user_error("Bad class value " . var_export($class, true) . " passed to ClassInfo::ancestry()", E_USER_WARNING);
|
||||||
|
|
||||||
$items = $_ALL_CLASSES['parents'][$class];
|
$items = $_ALL_CLASSES['parents'][$class];
|
||||||
$items[$class] = $class;
|
$items[$class] = $class;
|
||||||
if($onlyWithTables) foreach($items as $item) {
|
if($onlyWithTables) foreach($items as $item) {
|
||||||
|
@ -87,8 +87,8 @@ function getClassFile($className) {
|
|||||||
function singleton($className) {
|
function singleton($className) {
|
||||||
static $_SINGLETONS;
|
static $_SINGLETONS;
|
||||||
if(!isset($className)) user_error("singleton() Called without a class", E_USER_ERROR);
|
if(!isset($className)) user_error("singleton() Called without a class", E_USER_ERROR);
|
||||||
if(!class_exists($className)) user_error("Bad class to singleton() - $className", E_USER_ERROR);
|
|
||||||
if(!isset($_SINGLETONS[$className])) {
|
if(!isset($_SINGLETONS[$className])) {
|
||||||
|
if(!class_exists($className)) user_error("Bad class to singleton() - $className", E_USER_ERROR);
|
||||||
$_SINGLETONS[$className] = Object::strong_create($className,null, true);
|
$_SINGLETONS[$className] = Object::strong_create($className,null, true);
|
||||||
if(!$_SINGLETONS[$className]) user_error("singleton() Unknown class '$className'", E_USER_ERROR);
|
if(!$_SINGLETONS[$className]) user_error("singleton() Unknown class '$className'", E_USER_ERROR);
|
||||||
}
|
}
|
||||||
|
@ -146,11 +146,15 @@ class Object {
|
|||||||
* Returns true if the given method exists.
|
* Returns true if the given method exists.
|
||||||
*/
|
*/
|
||||||
public function hasMethod($methodName) {
|
public function hasMethod($methodName) {
|
||||||
|
if(method_exists($this, $methodName)) return true;
|
||||||
|
|
||||||
$methodName = strtolower($methodName);
|
$methodName = strtolower($methodName);
|
||||||
if(!isset($this->class)) $this->class = get_class($this);
|
if(!isset($this->class)) $this->class = get_class($this);
|
||||||
|
/*
|
||||||
if(!isset(Object::$builtInMethods['_set'][$this->class])) $this->buildMethodList();
|
if(!isset(Object::$builtInMethods['_set'][$this->class])) $this->buildMethodList();
|
||||||
|
|
||||||
if(isset(Object::$builtInMethods[$this->class][$methodName])) return true;
|
if(isset(Object::$builtInMethods[$this->class][$methodName])) return true;
|
||||||
|
*/
|
||||||
if(isset(Object::$extraMethods[$this->class][$methodName])) return true;
|
if(isset(Object::$extraMethods[$this->class][$methodName])) return true;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -257,7 +261,7 @@ class Object {
|
|||||||
$methodNames[strtolower($name)] = $name;
|
$methodNames[strtolower($name)] = $name;
|
||||||
}
|
}
|
||||||
Object::$builtInMethods[$this->class] = $methodNames;
|
Object::$builtInMethods[$this->class] = $methodNames;
|
||||||
Object::$builtInMethods['_set'][$this->class] = true ;
|
Object::$builtInMethods['_set'][$this->class] = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -442,8 +446,10 @@ class Object {
|
|||||||
* @return DataObjectDecorator The instance of the extension
|
* @return DataObjectDecorator The instance of the extension
|
||||||
*/
|
*/
|
||||||
public function extInstance($name) {
|
public function extInstance($name) {
|
||||||
|
if(isset($this->extension_instances[$name])) {
|
||||||
return $this->extension_instances[$name];
|
return $this->extension_instances[$name];
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns true if the given extension class is attached to this object
|
* Returns true if the given extension class is attached to this object
|
||||||
|
@ -220,6 +220,7 @@ class Requirements {
|
|||||||
Requirements::$css = array();
|
Requirements::$css = array();
|
||||||
Requirements::$customScript = array();
|
Requirements::$customScript = array();
|
||||||
Requirements::$customCSS = array();
|
Requirements::$customCSS = array();
|
||||||
|
Requirements::$customHeadTags = "";
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -206,8 +206,7 @@ class ViewableData extends Object implements IteratorAggregate {
|
|||||||
* @param array
|
* @param array
|
||||||
*/
|
*/
|
||||||
public function buildCastingHelperCache(&$cache) {
|
public function buildCastingHelperCache(&$cache) {
|
||||||
$class = $this->class;
|
$class = $this->class ? $this->class : get_class($this);
|
||||||
|
|
||||||
$classes = ClassInfo::ancestry($class);
|
$classes = ClassInfo::ancestry($class);
|
||||||
|
|
||||||
foreach($classes as $componentClass) {
|
foreach($classes as $componentClass) {
|
||||||
|
@ -293,6 +293,11 @@ class Director {
|
|||||||
}
|
}
|
||||||
|
|
||||||
$s = (isset($_SERVER['SSL']) || isset($_SERVER['HTTPS'])) ? 's' : '';
|
$s = (isset($_SERVER['SSL']) || isset($_SERVER['HTTPS'])) ? 's' : '';
|
||||||
|
|
||||||
|
if(!isset($_SERVER['HTTP_HOST'])) {
|
||||||
|
user_error("Director::protocolAndHost() lacks sufficient information - HTTP_HOST not set.", E_USER_WARNING);
|
||||||
|
}
|
||||||
|
|
||||||
return "http$s://" . $_SERVER['HTTP_HOST'];
|
return "http$s://" . $_SERVER['HTTP_HOST'];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -72,6 +72,16 @@ class DB {
|
|||||||
*/
|
*/
|
||||||
static function query($sql, $errorLevel = E_USER_ERROR) {
|
static function query($sql, $errorLevel = E_USER_ERROR) {
|
||||||
DB::$lastQuery = $sql;
|
DB::$lastQuery = $sql;
|
||||||
|
/* debug helper for query efficiency
|
||||||
|
if(substr(strtolower($sql),0,6) == 'select') {
|
||||||
|
$product = 1;
|
||||||
|
foreach(DB::$globalConn->query("explain " . $sql, $errorLevel) as $explainRow) {
|
||||||
|
if($explainRow['rows']) $product *= $explainRow['rows'];
|
||||||
|
}
|
||||||
|
if($product > 100)
|
||||||
|
Debug::message("Cartesian product $product for SQL: $sql");
|
||||||
|
} */
|
||||||
|
|
||||||
return DB::$globalConn->query($sql, $errorLevel);
|
return DB::$globalConn->query($sql, $errorLevel);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -679,13 +679,13 @@ class DataObject extends ViewableData implements DataObjectInterface {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
$this->extend('augmentWrite', $manipulation);
|
$this->extend('augmentWrite', $manipulation);
|
||||||
// New records have their insert into the base data table done first, so that they can pass the
|
// New records have their insert into the base data table done first, so that they can pass the
|
||||||
// generated ID on to the rest of the manipulation
|
// generated ID on to the rest of the manipulation
|
||||||
if(isset($isNewRecord) && $isNewRecord && isset($manipulation[$baseTable])) {
|
if(isset($isNewRecord) && $isNewRecord && isset($manipulation[$baseTable])) {
|
||||||
$manipulation[$baseTable]['command'] = 'update';
|
$manipulation[$baseTable]['command'] = 'update';
|
||||||
}
|
}
|
||||||
|
|
||||||
DB::manipulate($manipulation);
|
DB::manipulate($manipulation);
|
||||||
|
|
||||||
if(isset($isNewRecord) && $isNewRecord) {
|
if(isset($isNewRecord) && $isNewRecord) {
|
||||||
@ -1901,7 +1901,7 @@ class DataObject extends ViewableData implements DataObjectInterface {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Join all the tables
|
// Join all the tables
|
||||||
if($tableClasses) {
|
if($tableClasses && self::$subclass_access) {
|
||||||
foreach($tableClasses as $tableClass) {
|
foreach($tableClasses as $tableClass) {
|
||||||
$query->from[$tableClass] = "LEFT JOIN `$tableClass` ON `$tableClass`.ID = `$baseClass`.ID";
|
$query->from[$tableClass] = "LEFT JOIN `$tableClass` ON `$tableClass`.ID = `$baseClass`.ID";
|
||||||
$query->select[] = "`$tableClass`.*";
|
$query->select[] = "`$tableClass`.*";
|
||||||
@ -2519,6 +2519,20 @@ class DataObject extends ViewableData implements DataObjectInterface {
|
|||||||
*/
|
*/
|
||||||
protected static $context_obj = null;
|
protected static $context_obj = null;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @ignore
|
||||||
|
*/
|
||||||
|
private static $subclass_access = true;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Temporarily disable subclass access in data object qeur
|
||||||
|
*/
|
||||||
|
static function disable_subclass_access() {
|
||||||
|
self::$subclass_access = false;
|
||||||
|
}
|
||||||
|
static function enable_subclass_access() {
|
||||||
|
self::$subclass_access = true;
|
||||||
|
}
|
||||||
|
|
||||||
//-------------------------------------------------------------------------------------------//
|
//-------------------------------------------------------------------------------------------//
|
||||||
|
|
||||||
|
@ -33,6 +33,9 @@ abstract class DataObjectDecorator extends Extension {
|
|||||||
* @todo Rename to "loadExtraStaticFields", as it decorates more than database related fields.
|
* @todo Rename to "loadExtraStaticFields", as it decorates more than database related fields.
|
||||||
*/
|
*/
|
||||||
function loadExtraDBFields() {
|
function loadExtraDBFields() {
|
||||||
|
// Don't apply DB fields if the parent object has this extension too
|
||||||
|
if(singleton(get_parent_class($this->owner))->extInstance($this->class)) return;
|
||||||
|
|
||||||
$fields = $this->extraDBFields();
|
$fields = $this->extraDBFields();
|
||||||
$className = $this->owner->class;
|
$className = $this->owner->class;
|
||||||
|
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class represents a set of {@link ViewableData} subclasses (mostly {@link DataObject} or {@link ArrayData}.
|
* This class represents a set of {@link ViewableData} subclasses (mostly {@link DataObject} or {@link ArrayData}).
|
||||||
* It is used by the ORM-layer of Silverstripe to return query-results from {@link SQLQuery}.
|
* It is used by the ORM-layer of Silverstripe to return query-results from {@link SQLQuery}.
|
||||||
* @package sapphire
|
* @package sapphire
|
||||||
* @subpackage model
|
* @subpackage model
|
||||||
@ -436,10 +436,12 @@ class DataObjectSet extends ViewableData implements IteratorAggregate {
|
|||||||
* @param DataObjectSet $anotherSet Set to mege onto this set.
|
* @param DataObjectSet $anotherSet Set to mege onto this set.
|
||||||
*/
|
*/
|
||||||
public function merge($anotherSet){
|
public function merge($anotherSet){
|
||||||
|
if($anotherSet) {
|
||||||
foreach($anotherSet->items as $item){
|
foreach($anotherSet->items as $item){
|
||||||
$this->push($item);
|
$this->push($item);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets a specific slice of an existing set.
|
* Gets a specific slice of an existing set.
|
||||||
@ -573,6 +575,7 @@ class DataObjectSet extends ViewableData implements IteratorAggregate {
|
|||||||
* @return array
|
* @return array
|
||||||
*/
|
*/
|
||||||
public function map($key = "ID", $value = "Title", $includeBlank=null) {
|
public function map($key = "ID", $value = "Title", $includeBlank=null) {
|
||||||
|
$map = array();
|
||||||
|
|
||||||
/* Don't do this, add this locally.
|
/* Don't do this, add this locally.
|
||||||
* Reasons: 1: In some case this blank value don't/mustn't present.
|
* Reasons: 1: In some case this blank value don't/mustn't present.
|
||||||
|
@ -161,7 +161,7 @@ class DatabaseAdmin extends Controller {
|
|||||||
array_shift($dataClasses);
|
array_shift($dataClasses);
|
||||||
|
|
||||||
if(!$quiet) {
|
if(!$quiet) {
|
||||||
echo '<p><b>Creating database tables</b></p>';
|
echo '\n<p><b>Creating database tables</b></p>\n\n';
|
||||||
}
|
}
|
||||||
|
|
||||||
$conn->beginSchemaUpdate();
|
$conn->beginSchemaUpdate();
|
||||||
@ -169,7 +169,7 @@ class DatabaseAdmin extends Controller {
|
|||||||
$SNG = singleton($dataClass);
|
$SNG = singleton($dataClass);
|
||||||
if($testMode || !($SNG instanceof TestOnly)) {
|
if($testMode || !($SNG instanceof TestOnly)) {
|
||||||
if(!$quiet) {
|
if(!$quiet) {
|
||||||
echo "<li>$dataClass</li>";
|
echo "<li>$dataClass</li>\n";
|
||||||
}
|
}
|
||||||
$SNG->requireTable();
|
$SNG->requireTable();
|
||||||
}
|
}
|
||||||
@ -180,7 +180,7 @@ class DatabaseAdmin extends Controller {
|
|||||||
|
|
||||||
if($populate) {
|
if($populate) {
|
||||||
if(!$quiet) {
|
if(!$quiet) {
|
||||||
echo '<p><b>Creating database records</b></p>';
|
echo '\n<p><b>Creating database records</b></p>\n\n';
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach($dataClasses as $dataClass) {
|
foreach($dataClasses as $dataClass) {
|
||||||
@ -188,7 +188,7 @@ class DatabaseAdmin extends Controller {
|
|||||||
|
|
||||||
if(strpos($dataClass,'Test_') === false) {
|
if(strpos($dataClass,'Test_') === false) {
|
||||||
if(!$quiet) {
|
if(!$quiet) {
|
||||||
echo "<li>$dataClass</li>";
|
echo "<li>$dataClass</li>\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
singleton($dataClass)->requireDefaultRecords();
|
singleton($dataClass)->requireDefaultRecords();
|
||||||
|
@ -85,9 +85,6 @@ class ErrorPage extends Page {
|
|||||||
* @param boolean $createNewVersion Set this to true to create a new version number. By default, the existing version number will be copied over.
|
* @param boolean $createNewVersion Set this to true to create a new version number. By default, the existing version number will be copied over.
|
||||||
*/
|
*/
|
||||||
function publish($fromStage, $toStage, $createNewVersion = false) {
|
function publish($fromStage, $toStage, $createNewVersion = false) {
|
||||||
// Temporarily log out when producing this page
|
|
||||||
$loggedInMember = Member::currentUser();
|
|
||||||
Session::clear("loggedInAs");
|
|
||||||
$alc_enc = isset($_COOKIE['alc_enc']) ? $_COOKIE['alc_enc'] : null;
|
$alc_enc = isset($_COOKIE['alc_enc']) ? $_COOKIE['alc_enc'] : null;
|
||||||
Cookie::set('alc_enc', null);
|
Cookie::set('alc_enc', null);
|
||||||
|
|
||||||
@ -111,7 +108,6 @@ class ErrorPage extends Page {
|
|||||||
Versioned::reading_stage($oldStage);
|
Versioned::reading_stage($oldStage);
|
||||||
|
|
||||||
// Log back in
|
// Log back in
|
||||||
if($loggedInMember) Session::set("loggedInAs", $loggedInMember->ID);
|
|
||||||
if(isset($alc_enc)) Cookie::set('alc_enc', $alc_enc);
|
if(isset($alc_enc)) Cookie::set('alc_enc', $alc_enc);
|
||||||
|
|
||||||
return $this->extension_instances['Versioned']->publish($fromStage, $toStage, $createNewVersion);
|
return $this->extension_instances['Versioned']->publish($fromStage, $toStage, $createNewVersion);
|
||||||
|
@ -408,6 +408,7 @@ class Hierarchy extends DataObjectDecorator {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
DataObject::disable_subclass_access();
|
||||||
if(isset($idxStageChildren)) {
|
if(isset($idxStageChildren)) {
|
||||||
$foundInLive = Versioned::get_by_stage( $baseClass, 'Live', "`{$baseClass}`.`ID` IN (" . implode(",", array_keys($idxStageChildren)) . ")", "" );
|
$foundInLive = Versioned::get_by_stage( $baseClass, 'Live', "`{$baseClass}`.`ID` IN (" . implode(",", array_keys($idxStageChildren)) . ")", "" );
|
||||||
}
|
}
|
||||||
@ -415,6 +416,7 @@ class Hierarchy extends DataObjectDecorator {
|
|||||||
if(isset($idxLiveChildren)) {
|
if(isset($idxLiveChildren)) {
|
||||||
$foundInStage = Versioned::get_by_stage( $baseClass, 'Stage', "`{$baseClass}`.`ID` IN (" . implode(",", array_keys($idxLiveChildren)) . ")", "" );
|
$foundInStage = Versioned::get_by_stage( $baseClass, 'Stage', "`{$baseClass}`.`ID` IN (" . implode(",", array_keys($idxLiveChildren)) . ")", "" );
|
||||||
}
|
}
|
||||||
|
DataObject::enable_subclass_access();
|
||||||
|
|
||||||
if(isset($foundInLive)) {
|
if(isset($foundInLive)) {
|
||||||
foreach($foundInLive as $child) {
|
foreach($foundInLive as $child) {
|
||||||
|
@ -65,6 +65,8 @@ class SQLQuery extends Object {
|
|||||||
*/
|
*/
|
||||||
public $delete = false;
|
public $delete = false;
|
||||||
|
|
||||||
|
private $replacements = array();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The logical connective used to join WHERE clauses. Defaults to AND.
|
* The logical connective used to join WHERE clauses. Defaults to AND.
|
||||||
* @var string
|
* @var string
|
||||||
@ -352,6 +354,8 @@ class SQLQuery extends Object {
|
|||||||
* @param string $new The new text.
|
* @param string $new The new text.
|
||||||
*/
|
*/
|
||||||
function replaceText($old, $new) {
|
function replaceText($old, $new) {
|
||||||
|
$this->replacements[] = array($old, $new);
|
||||||
|
/*
|
||||||
if($this->select) foreach($this->select as $i => $item)
|
if($this->select) foreach($this->select as $i => $item)
|
||||||
$this->select[$i] = str_replace($old, $new, $item);
|
$this->select[$i] = str_replace($old, $new, $item);
|
||||||
|
|
||||||
@ -374,6 +378,7 @@ class SQLQuery extends Object {
|
|||||||
foreach($this->having as $i => $item)
|
foreach($this->having as $i => $item)
|
||||||
$this->having[$i] = str_replace($old, $new, $item);
|
$this->having[$i] = str_replace($old, $new, $item);
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -406,6 +411,10 @@ class SQLQuery extends Object {
|
|||||||
if($this->orderby) $text .= " ORDER BY " . $this->orderby;
|
if($this->orderby) $text .= " ORDER BY " . $this->orderby;
|
||||||
if($this->limit) $text .= " LIMIT " . $this->limit;
|
if($this->limit) $text .= " LIMIT " . $this->limit;
|
||||||
|
|
||||||
|
foreach($this->replacements as $replacement) {
|
||||||
|
$text = str_replace($replacement[0], $replacement[1], $text);
|
||||||
|
}
|
||||||
|
|
||||||
return $text;
|
return $text;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -91,7 +91,8 @@ class SiteTree extends DataObject {
|
|||||||
|
|
||||||
static $indexes = array(
|
static $indexes = array(
|
||||||
"SearchFields" => "fulltext (Title, MenuTitle, Content, MetaTitle, MetaDescription, MetaKeywords)",
|
"SearchFields" => "fulltext (Title, MenuTitle, Content, MetaTitle, MetaDescription, MetaKeywords)",
|
||||||
"TitleSearchFields" => "fulltext (Title)"
|
"TitleSearchFields" => "fulltext (Title)",
|
||||||
|
"URLSegment" => true,
|
||||||
);
|
);
|
||||||
|
|
||||||
static $has_many = array(
|
static $has_many = array(
|
||||||
@ -361,7 +362,12 @@ class SiteTree extends DataObject {
|
|||||||
*
|
*
|
||||||
* @var int
|
* @var int
|
||||||
*/
|
*/
|
||||||
protected static $currentPageID;
|
private static $currentPageID;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Records the URL segment that was used to set the current page ID
|
||||||
|
*/
|
||||||
|
private static $currentPageIDSetFromURLSegment;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -369,8 +375,10 @@ class SiteTree extends DataObject {
|
|||||||
* the cached answers.
|
* the cached answers.
|
||||||
*/
|
*/
|
||||||
protected function prepareCurrentAndSection() {
|
protected function prepareCurrentAndSection() {
|
||||||
if(!self::$currentPageID) {
|
if(!self::$currentPageID || Director::urlParam('URLSegment') != self::$currentPageIDSetFromURLSegment) {
|
||||||
self::$currentPageID = Director::currentPage() ? Director::currentPage()->ID : null;
|
self::$currentPageID = Director::currentPage() ? Director::currentPage()->ID : null;
|
||||||
|
self::$currentPageIDSetFromURLSegment = Director::urlParam('URLSegment');
|
||||||
|
|
||||||
if(!isset(self::$currentPageID)) {
|
if(!isset(self::$currentPageID)) {
|
||||||
self::$currentPageID = -1;
|
self::$currentPageID = -1;
|
||||||
$nextID = (Director::currentPage() && isset(Director::currentPage()->Parent->ID))
|
$nextID = (Director::currentPage() && isset(Director::currentPage()->Parent->ID))
|
||||||
@ -1220,6 +1228,7 @@ class SiteTree extends DataObject {
|
|||||||
return $fields;
|
return $fields;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the actions available in the CMS for this page - eg Save, Publish.
|
* Get the actions available in the CMS for this page - eg Save, Publish.
|
||||||
@ -1252,6 +1261,34 @@ class SiteTree extends DataObject {
|
|||||||
return new DataObjectSet($actions);
|
return new DataObjectSet($actions);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Publish this page
|
||||||
|
*/
|
||||||
|
function doPublish() {
|
||||||
|
$original = Versioned::get_one_by_stage("SiteTree", "Live", "`SiteTree`.`ID` = $this->ID");
|
||||||
|
|
||||||
|
// Handle activities undertaken by decorators
|
||||||
|
$this->extend('onBeforePublish', $original);
|
||||||
|
|
||||||
|
$this->AssignedToID = 0;
|
||||||
|
$this->RequestedByID = 0;
|
||||||
|
$this->Status = "Published";
|
||||||
|
//$this->PublishedByID = Member::currentUser()->ID;
|
||||||
|
$this->write();
|
||||||
|
$this->publish("Stage", "Live");
|
||||||
|
|
||||||
|
GoogleSitemap::ping();
|
||||||
|
|
||||||
|
// Fix the sort order for this page's siblings
|
||||||
|
DB::query("UPDATE SiteTree_Live
|
||||||
|
INNER JOIN SiteTree ON SiteTree_Live.ID = SiteTree.ID
|
||||||
|
SET SiteTree_Live.Sort = SiteTree.Sort
|
||||||
|
WHERE SiteTree_Live.ParentID = " . sprintf('%d', $this->ParentID));
|
||||||
|
|
||||||
|
// Handle activities undertaken by decorators
|
||||||
|
$this->extend('onAfterPublish', $original);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Check if this page is new - that is, if it has yet to have been written
|
* Check if this page is new - that is, if it has yet to have been written
|
||||||
|
@ -159,7 +159,7 @@ class Text extends DBField {
|
|||||||
* Caution: Not XML/HTML-safe - does not respect closing tags.
|
* Caution: Not XML/HTML-safe - does not respect closing tags.
|
||||||
*/
|
*/
|
||||||
function BigSummary($maxWords = 50, $plain = 1) {
|
function BigSummary($maxWords = 50, $plain = 1) {
|
||||||
|
$result = "";
|
||||||
// get first sentence?
|
// get first sentence?
|
||||||
// this needs to be more robust
|
// this needs to be more robust
|
||||||
if($plain) $data = Convert::xml2raw( $this->value, true );
|
if($plain) $data = Convert::xml2raw( $this->value, true );
|
||||||
|
@ -27,7 +27,7 @@ class Time extends DBField {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
function _12Hour( $parts ) {
|
function 12Hour( $parts ) {
|
||||||
$hour = $parts[1];
|
$hour = $parts[1];
|
||||||
$min = $parts[2];
|
$min = $parts[2];
|
||||||
$half = $parts[3];
|
$half = $parts[3];
|
||||||
|
@ -11,6 +11,8 @@
|
|||||||
width: 20px;
|
width: 20px;
|
||||||
float : left;
|
float : left;
|
||||||
|
|
||||||
|
height:100px;
|
||||||
|
overflow-y:scroll;
|
||||||
}
|
}
|
||||||
|
|
||||||
.SelectionGroup li div.field {
|
.SelectionGroup li div.field {
|
||||||
|
@ -22,8 +22,10 @@ class Filesystem extends Object {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Remove a directory and all subdirectories and files
|
* Remove a directory and all subdirectories and files
|
||||||
|
* @param $contentsOnly If this is true then the contents of the folder will be removed but not the folder itself
|
||||||
*/
|
*/
|
||||||
static function removeFolder($folder) {
|
static function removeFolder( $folder, $contentsOnly = false ) {
|
||||||
|
|
||||||
// remove a file encountered by a recursive call.
|
// remove a file encountered by a recursive call.
|
||||||
if( !is_dir( $folder ) || is_link($folder) )
|
if( !is_dir( $folder ) || is_link($folder) )
|
||||||
unlink( $folder );
|
unlink( $folder );
|
||||||
@ -36,7 +38,8 @@ class Filesystem extends Object {
|
|||||||
self::removeFolder( $folder.'/'.$file );
|
self::removeFolder( $folder.'/'.$file );
|
||||||
|
|
||||||
closedir($dir);
|
closedir($dir);
|
||||||
rmdir($folder);
|
|
||||||
|
if(!$contentsOnly) rmdir($folder);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -39,7 +39,7 @@ class Folder extends File {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function userCanUse() {
|
function userCanUse() {
|
||||||
if( Member::currentUser()->_isAdmin() )
|
if( Member::currentUser()->isAdmin() )
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
$useGroups = $this->CanUse();
|
$useGroups = $this->CanUse();
|
||||||
@ -55,7 +55,7 @@ class Folder extends File {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function userCanEdit() {
|
function userCanEdit() {
|
||||||
if( Member::currentUser()->_isAdmin() )
|
if( Member::currentUser()->isAdmin() )
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
$useGroups = $this->CanEdit();
|
$useGroups = $this->CanEdit();
|
||||||
|
@ -81,7 +81,6 @@ class Form extends RequestHandlingData {
|
|||||||
* @param actions All of the action buttons in the form - a {@link FieldSet} of {@link FormAction} objects
|
* @param actions All of the action buttons in the form - a {@link FieldSet} of {@link FormAction} objects
|
||||||
*/
|
*/
|
||||||
function __construct($controller, $name, FieldSet $fields, FieldSet $actions, $validator = null) {
|
function __construct($controller, $name, FieldSet $fields, FieldSet $actions, $validator = null) {
|
||||||
|
|
||||||
parent::__construct();
|
parent::__construct();
|
||||||
|
|
||||||
foreach($fields as $field) $field->setForm($this);
|
foreach($fields as $field) $field->setForm($this);
|
||||||
@ -92,6 +91,8 @@ class Form extends RequestHandlingData {
|
|||||||
$this->controller = $controller;
|
$this->controller = $controller;
|
||||||
$this->name = $name;
|
$this->name = $name;
|
||||||
|
|
||||||
|
if(!$this->controller) user_error("$this->class form created without a controller", E_USER_ERROR);
|
||||||
|
|
||||||
// Form validation
|
// Form validation
|
||||||
if($validator) {
|
if($validator) {
|
||||||
$this->validator = $validator;
|
$this->validator = $validator;
|
||||||
@ -122,6 +123,8 @@ class Form extends RequestHandlingData {
|
|||||||
if(isset($errorInfo['message']) && isset($errorInfo['type'])) {
|
if(isset($errorInfo['message']) && isset($errorInfo['type'])) {
|
||||||
$this->setMessage($errorInfo['message'],$errorInfo['type']);
|
$this->setMessage($errorInfo['message'],$errorInfo['type']);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$this->security = self::$default_security;
|
||||||
}
|
}
|
||||||
|
|
||||||
static $url_handlers = array(
|
static $url_handlers = array(
|
||||||
@ -910,6 +913,16 @@ class Form extends RequestHandlingData {
|
|||||||
$this->security = false;
|
$this->security = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private static $default_security = true;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Disable security tokens for every form on this site.
|
||||||
|
*/
|
||||||
|
static function disable_all_security_tokens() {
|
||||||
|
self::$default_security = false;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns true if security is enabled - that is if the SecurityID
|
* Returns true if security is enabled - that is if the SecurityID
|
||||||
* should be included and checked on this form.
|
* should be included and checked on this form.
|
||||||
|
@ -233,7 +233,7 @@ function HtmlEditorField_dataValue_processImage($parts) {
|
|||||||
$image = Image::find(urldecode($src));
|
$image = Image::find(urldecode($src));
|
||||||
|
|
||||||
// If we have an image, insert the resampled one into the src attribute; otherwise, leave the img src alone.
|
// If we have an image, insert the resampled one into the src attribute; otherwise, leave the img src alone.
|
||||||
if($image) {
|
if($image && $image->getWidth() != $width && $image->getHeight != $height) {
|
||||||
// If we have an image, generate the resized image.
|
// If we have an image, generate the resized image.
|
||||||
$resizedImage = $image->getFormattedImage("ResizedImage",$width, $height);
|
$resizedImage = $image->getFormattedImage("ResizedImage",$width, $height);
|
||||||
$parts[$partSource['src="']] = $resizedImage->getRelativePath() ;
|
$parts[$partSource['src="']] = $resizedImage->getRelativePath() ;
|
||||||
|
@ -167,7 +167,7 @@ class TableField extends TableListField {
|
|||||||
// Load the data in to a temporary form (for correct field types)
|
// Load the data in to a temporary form (for correct field types)
|
||||||
$fieldset = $this->FieldSetForRow();
|
$fieldset = $this->FieldSetForRow();
|
||||||
if($fieldset){
|
if($fieldset){
|
||||||
$form = new Form(null, null, $fieldset, new FieldSet());
|
$form = new Form($this, null, $fieldset, new FieldSet());
|
||||||
$form->loadDataFrom($item);
|
$form->loadDataFrom($item);
|
||||||
// Add the item to our new DataObjectSet, with a wrapper class.
|
// Add the item to our new DataObjectSet, with a wrapper class.
|
||||||
$output->push(new TableField_Item($item, $this, $form, $this->fieldTypes));
|
$output->push(new TableField_Item($item, $this, $form, $this->fieldTypes));
|
||||||
@ -351,7 +351,7 @@ class TableField extends TableListField {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$form = new Form(null, null, $fieldset, new FieldSet());
|
$form = new Form($this, null, $fieldset, new FieldSet());
|
||||||
|
|
||||||
if($dataObjects) {
|
if($dataObjects) {
|
||||||
foreach ($dataObjects as $objectid => $fieldValues) {
|
foreach ($dataObjects as $objectid => $fieldValues) {
|
||||||
|
@ -511,8 +511,8 @@ $lang['en_US']['Security']['ALREADYLOGGEDIN'] = 'You don\'t have access to this
|
|||||||
$lang['en_US']['Security']['LOGGEDOUT'] = 'You have been logged out. If you would like to log in again, enter your credentials below.';
|
$lang['en_US']['Security']['LOGGEDOUT'] = 'You have been logged out. If you would like to log in again, enter your credentials below.';
|
||||||
$lang['en_US']['Security']['LOGIN'] = 'Log in';
|
$lang['en_US']['Security']['LOGIN'] = 'Log in';
|
||||||
$lang['en_US']['Security']['LOSTPASSWORDHEADER'] = 'Lost Password';
|
$lang['en_US']['Security']['LOSTPASSWORDHEADER'] = 'Lost Password';
|
||||||
$lang['en_US']['Security']['NOTERESETPASSWORD'] = 'Enter your e-mail address and we will send you a link with which you can reset your password';
|
$lang['en_US']['Security']['NOTERESETPASSWORD'] = 'Enter your email address to be sent a password reset link.';
|
||||||
$lang['en_US']['Security']['BUTTONSEND'] = 'Send me the password reset link';
|
$lang['en_US']['Security']['BUTTONSEND'] = 'Send Password Reset Link';
|
||||||
$lang['en_US']['Security']['PASSWORDSENTHEADER'] = 'Password reset link sent to \'%s\'';
|
$lang['en_US']['Security']['PASSWORDSENTHEADER'] = 'Password reset link sent to \'%s\'';
|
||||||
$lang['en_US']['Security']['PASSWORDSENTTEXT'] = 'Thank you! The password reset link has been sent to \'%s\'.';
|
$lang['en_US']['Security']['PASSWORDSENTTEXT'] = 'Thank you! The password reset link has been sent to \'%s\'.';
|
||||||
$lang['en_US']['Security']['CHANGEPASSWORDHEADER'] = 'Change your password';
|
$lang['en_US']['Security']['CHANGEPASSWORDHEADER'] = 'Change your password';
|
||||||
|
@ -33,7 +33,9 @@ class SearchForm extends Form {
|
|||||||
// Hayden: Sorry if I've got it mixed up, but on the results or not found pages, the
|
// Hayden: Sorry if I've got it mixed up, but on the results or not found pages, the
|
||||||
// RelativeLink seems to be empty and it packs a sad
|
// RelativeLink seems to be empty and it packs a sad
|
||||||
$formController = isset($_GET['formController']) ? $_GET['formController'] : null;
|
$formController = isset($_GET['formController']) ? $_GET['formController'] : null;
|
||||||
if( !$formController ) $formController = $controller->RelativeLink();
|
if( !$formController ) {
|
||||||
|
$formController = $controller->RelativeLink();
|
||||||
|
}
|
||||||
|
|
||||||
$fields->push(new HiddenField("formController", null, $formController));
|
$fields->push(new HiddenField("formController", null, $formController));
|
||||||
// $fields->push(new HiddenField("formController", null, $controller->RelativeLink()));
|
// $fields->push(new HiddenField("formController", null, $controller->RelativeLink()));
|
||||||
|
@ -601,7 +601,7 @@ class Member extends DataObject {
|
|||||||
* only right name for this?
|
* only right name for this?
|
||||||
* @todo Is {@link Group}::CanCMSAdmin not deprecated?
|
* @todo Is {@link Group}::CanCMSAdmin not deprecated?
|
||||||
*/
|
*/
|
||||||
function _isAdmin() {
|
function isAdmin() {
|
||||||
if($groups = $this->Groups()) {
|
if($groups = $this->Groups()) {
|
||||||
foreach($groups as $group) {
|
foreach($groups as $group) {
|
||||||
if($group->CanCMSAdmin)
|
if($group->CanCMSAdmin)
|
||||||
@ -612,20 +612,12 @@ class Member extends DataObject {
|
|||||||
return Permission::check('ADMIN');
|
return Permission::check('ADMIN');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function _isAdmin() {
|
||||||
/**
|
user_error("Deprecated. Use isAdmin() instead", E_USER_NOTICE);
|
||||||
* Check if the user is an administrator
|
return $this->isAdmin();
|
||||||
*
|
|
||||||
* Alias for {@link _isAdmin()} because the method is used in both ways
|
|
||||||
* all over the framework.
|
|
||||||
*
|
|
||||||
* @return Returns TRUE if this user is an administrator.
|
|
||||||
* @see _isAdmin()
|
|
||||||
*/
|
|
||||||
public function isAdmin() {
|
|
||||||
return $this->_isAdmin();
|
|
||||||
}
|
}
|
||||||
function _isCMSUser() {
|
|
||||||
|
function isCMSUser() {
|
||||||
if($groups = $this->Groups()) {
|
if($groups = $this->Groups()) {
|
||||||
foreach($groups as $group) {
|
foreach($groups as $group) {
|
||||||
if($group->CanCMS)
|
if($group->CanCMS)
|
||||||
@ -634,6 +626,11 @@ class Member extends DataObject {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function _isCMSUser() {
|
||||||
|
user_error("Deprecated. Use isCMSUser() instead", E_USER_NOTICE);
|
||||||
|
return $this->isCMSUser();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
//------------------- HELPER METHODS -----------------------------------//
|
//------------------- HELPER METHODS -----------------------------------//
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<p><% _t('HELLO', 'Hi') %> $FirstName,</p>
|
<p><% _t('HELLO', 'Hi') %> $FirstName,</p>
|
||||||
|
|
||||||
<p><% _t('TEXT1', 'Here\'s is your') %> <a href="$PasswordResetLink"><% _t('TEXT2', 'password reset link') %></a> <% _t('TEXT3', 'for') %> $BaseHref</p>
|
<p><% _t('TEXT1', 'Here is your') %> <a href="$PasswordResetLink"><% _t('TEXT2', 'password reset link') %></a> <% _t('TEXT3', 'for') %> $BaseHref.</p>
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user