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:
Sam Minnee 2008-08-12 02:51:33 +00:00
parent b5001bc906
commit 0bd9bc4ff8
34 changed files with 188 additions and 67 deletions

View File

@ -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();
} }

View File

@ -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
View 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 {
}
?>

View File

@ -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) {

View File

@ -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);
} }

View File

@ -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

View File

@ -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 = "";
} }
} }

View File

@ -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) {

View File

@ -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'];
} }

View File

@ -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);
} }

View File

@ -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;
}
//-------------------------------------------------------------------------------------------// //-------------------------------------------------------------------------------------------//

View File

@ -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;

View File

@ -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.

View File

@ -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();

View File

@ -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);

View File

@ -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) {

View File

@ -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;
} }

View File

@ -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

View File

@ -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 );

View File

@ -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];

View File

@ -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 {

View File

@ -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);
} }
} }

View File

@ -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();

View File

@ -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.

View File

@ -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() ;

View File

@ -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) {

View File

@ -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';

View File

@ -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()));

View File

@ -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 -----------------------------------//

View File

@ -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>