Merge pull request #10525 from creative-commoners/pulls/4/deprecated

API Update deprecations
This commit is contained in:
Guy Sartorelli 2022-10-13 15:25:47 +13:00 committed by GitHub
commit d6b3f4d515
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
62 changed files with 317 additions and 241 deletions

View File

@ -533,15 +533,11 @@ class Controller extends RequestHandler implements TemplateGlobalProvider
* called before Controller::init(). That is, you must call it in your controller's init method * called before Controller::init(). That is, you must call it in your controller's init method
* before it calls parent::init(). * before it calls parent::init().
* *
* @deprecated 4.1.0:5.0.0 Add this controller's url to * @deprecated 4.1.0 Add this controller's url to SilverStripe\Security\BasicAuthMiddleware.URLPatterns injected property instead
* SilverStripe\Security\BasicAuthMiddleware.URLPatterns injected property instead of setting false
*/ */
public function disableBasicAuth() public function disableBasicAuth()
{ {
Deprecation::notice( Deprecation::notice('4.1.0', 'Add this controller\'s url to SilverStripe\Security\BasicAuthMiddleware.URLPatterns injected property instead');
'5.0',
'Add this controller\'s url to ' . BasicAuthMiddleware::class . '.URLPatterns injected property instead'
);
$this->basicAuthEnabled = false; $this->basicAuthEnabled = false;
} }

View File

@ -2,6 +2,7 @@
namespace SilverStripe\Control; namespace SilverStripe\Control;
use SilverStripe\Dev\Deprecation;
use SilverStripe\ORM\FieldType\DBDatetime; use SilverStripe\ORM\FieldType\DBDatetime;
use LogicException; use LogicException;
@ -200,10 +201,11 @@ class CookieJar implements Cookie_Backend
/** /**
* Get the correct samesite value - Session cookies use a different configuration variable. * Get the correct samesite value - Session cookies use a different configuration variable.
* *
* @deprecated 5.0 The relevant methods will include a `$sameSite` parameter instead. * @deprecated 4.12.0 The relevant methods will include a `$sameSite` parameter instead.
*/ */
private function getSameSite(string $name): string private function getSameSite(string $name): string
{ {
Deprecation::notice('4.12.0', 'The relevant methods will include a `$sameSite` parameter instead.');
if ($name === session_name()) { if ($name === session_name()) {
return Session::config()->get('cookie_samesite'); return Session::config()->get('cookie_samesite');
} }

View File

@ -386,10 +386,11 @@ class Director implements TemplateGlobalProvider
* *
* @return bool * @return bool
* *
* @deprecated 5.0 Kernel::isFlushed to be used instead * @deprecated 4.12.0 Use Kernel::isFlushed instead
*/ */
public static function isManifestFlushed() public static function isManifestFlushed()
{ {
Deprecation::notice('4.12.0', 'Use Kernel::isFlushed instead');
$kernel = Injector::inst()->get(Kernel::class); $kernel = Injector::inst()->get(Kernel::class);
// Only CoreKernel implements this method at the moment // Only CoreKernel implements this method at the moment

View File

@ -737,7 +737,7 @@ class Email extends ViewableData
} }
/** /**
* @deprecated Will be removed without equivalent functionality to replace it * @deprecated 4.12.0 Will be removed without equivalent functionality to replace it
* *
* Debugging help * Debugging help
* *

View File

@ -2,6 +2,7 @@
namespace SilverStripe\Control\Email; namespace SilverStripe\Control\Email;
use SilverStripe\Dev\Deprecation;
use SilverStripe\Core\Config\Configurable; use SilverStripe\Core\Config\Configurable;
use SilverStripe\Core\Injector\Injectable; use SilverStripe\Core\Injector\Injectable;
use SilverStripe\Core\Injector\Injector; use SilverStripe\Core\Injector\Injector;
@ -37,6 +38,11 @@ class SwiftMailer implements Mailer
* @param Email $message * @param Email $message
* @return bool Whether the sending was "successful" or not * @return bool Whether the sending was "successful" or not
*/ */
public function __construct()
{
Deprecation::notice('4.12.0', 'Will be replaced with symfony/mailer', Deprecation::SCOPE_CLASS);
}
public function send($message) public function send($message)
{ {
$swiftMessage = $message->getSwiftMessage(); $swiftMessage = $message->getSwiftMessage();

View File

@ -2,11 +2,18 @@
namespace SilverStripe\Control\Email; namespace SilverStripe\Control\Email;
use SilverStripe\Dev\Deprecation;
/** /**
* @deprecated 4.12.0 Will be replaced with symfony/mailer * @deprecated 4.12.0 Will be replaced with symfony/mailer
*/ */
class SwiftPlugin implements \Swift_Events_SendListener class SwiftPlugin implements \Swift_Events_SendListener
{ {
public function __construct()
{
Deprecation::notice('4.12.0', 'Will be replaced with symfony/mailer', Deprecation::SCOPE_CLASS);
}
/** /**
* Before sending a message make sure all our overrides are taken into account * Before sending a message make sure all our overrides are taken into account
* *

View File

@ -372,43 +372,43 @@ class HTTP
/** /**
* Set the maximum age of this page in web caches, in seconds. * Set the maximum age of this page in web caches, in seconds.
* *
* @deprecated 4.2.0:5.0.0 Use HTTPCacheControlMiddleware::singleton()->setMaxAge($age) instead * @deprecated 4.2.0 Use HTTPCacheControlMiddleware::singleton()->setMaxAge($age) instead
* @param int $age * @param int $age
*/ */
public static function set_cache_age($age) public static function set_cache_age($age)
{ {
Deprecation::notice('5.0', 'Use HTTPCacheControlMiddleware::singleton()->setMaxAge($age) instead'); Deprecation::notice('4.2.0', 'Use HTTPCacheControlMiddleware::singleton()->setMaxAge($age) instead');
self::$cache_age = $age; self::$cache_age = $age;
HTTPCacheControlMiddleware::singleton()->setMaxAge($age); HTTPCacheControlMiddleware::singleton()->setMaxAge($age);
} }
/** /**
* @param string $dateString * @param string $dateString
* @deprecated 4.2.0:5.0.0 Use HTTPCacheControlMiddleware::registerModificationDate() instead * @deprecated 4.2.0 Use HTTPCacheControlMiddleware::registerModificationDate() instead
*/ */
public static function register_modification_date($dateString) public static function register_modification_date($dateString)
{ {
Deprecation::notice('5.0', 'Use HTTPCacheControlMiddleware::registerModificationDate() instead'); Deprecation::notice('4.2.0', 'Use HTTPCacheControlMiddleware::registerModificationDate() instead');
HTTPCacheControlMiddleware::singleton()->registerModificationDate($dateString); HTTPCacheControlMiddleware::singleton()->registerModificationDate($dateString);
} }
/** /**
* @param int $timestamp * @param int $timestamp
* @deprecated 4.2.0:5.0.0 Use HTTPCacheControlMiddleware::registerModificationDate() instead * @deprecated 4.2.0 Use HTTPCacheControlMiddleware::registerModificationDate() instead
*/ */
public static function register_modification_timestamp($timestamp) public static function register_modification_timestamp($timestamp)
{ {
Deprecation::notice('5.0', 'Use HTTPCacheControlMiddleware::registerModificationDate() instead'); Deprecation::notice('4.2.0', 'Use HTTPCacheControlMiddleware::registerModificationDate() instead');
HTTPCacheControlMiddleware::singleton()->registerModificationDate($timestamp); HTTPCacheControlMiddleware::singleton()->registerModificationDate($timestamp);
} }
/** /**
* @deprecated 4.2.0:5.0.0 Use ChangeDetectionMiddleware instead * @deprecated 4.2.0 Use ChangeDetectionMiddleware instead
* @param string $etag * @param string $etag
*/ */
public static function register_etag($etag) public static function register_etag($etag)
{ {
Deprecation::notice('5.0', 'Use ChangeDetectionMiddleware instead'); Deprecation::notice('4.2.0', 'Use ChangeDetectionMiddleware instead');
if (strpos($etag ?? '', '"') !== 0) { if (strpos($etag ?? '', '"') !== 0) {
$etag = "\"{$etag}\""; $etag = "\"{$etag}\"";
} }
@ -426,11 +426,11 @@ class HTTP
* output directly. * output directly.
* *
* @param HTTPResponse $response * @param HTTPResponse $response
* @deprecated 4.2.0:5.0.0 Headers are added automatically by HTTPCacheControlMiddleware instead. * @deprecated 4.2.0 Headers are added automatically by HTTPCacheControlMiddleware instead.
*/ */
public static function add_cache_headers($response = null) public static function add_cache_headers($response = null)
{ {
Deprecation::notice('5.0', 'Headers are added automatically by HTTPCacheControlMiddleware instead.'); Deprecation::notice('4.2.0', 'Headers are added automatically by HTTPCacheControlMiddleware instead.');
// Skip if deprecated API is disabled // Skip if deprecated API is disabled
if (Config::inst()->get(HTTP::class, 'ignoreDeprecatedCaching')) { if (Config::inst()->get(HTTP::class, 'ignoreDeprecatedCaching')) {
@ -473,13 +473,14 @@ class HTTP
/** /**
* Ensure that all deprecated HTTP cache settings are respected * Ensure that all deprecated HTTP cache settings are respected
* *
* @deprecated 4.2.0:5.0.0 Use HTTPCacheControlMiddleware instead * @deprecated 4.2.0 Use HTTPCacheControlMiddleware instead
* @throws \LogicException * @throws \LogicException
* @param HTTPRequest $request * @param HTTPRequest $request
* @param HTTPResponse $response * @param HTTPResponse $response
*/ */
public static function augmentState(HTTPRequest $request, HTTPResponse $response) public static function augmentState(HTTPRequest $request, HTTPResponse $response)
{ {
Deprecation::notice('4.2.0', 'Use HTTPCacheControlMiddleware instead');
// Skip if deprecated API is disabled // Skip if deprecated API is disabled
$config = Config::forClass(HTTP::class); $config = Config::forClass(HTTP::class);
if ($config->get('ignoreDeprecatedCaching')) { if ($config->get('ignoreDeprecatedCaching')) {
@ -560,11 +561,12 @@ class HTTP
* is always in GMT: the number of seconds since January 1 1970 00:00:00 GMT) * is always in GMT: the number of seconds since January 1 1970 00:00:00 GMT)
* *
* @param int $timestamp * @param int $timestamp
* @deprecated 4.2.0:5.0.0 Inline if you need this * @deprecated 4.2.0 Use native php function gmdate() instead
* @return string * @return string
*/ */
public static function gmt_date($timestamp) public static function gmt_date($timestamp)
{ {
Deprecation::notice('4.2.0', 'Use native php function gmdate() instead');
return gmdate('D, d M Y H:i:s', $timestamp) . ' GMT'; return gmdate('D, d M Y H:i:s', $timestamp) . ' GMT';
} }

View File

@ -2,6 +2,7 @@
namespace SilverStripe\Control; namespace SilverStripe\Control;
use SilverStripe\Dev\Deprecation;
use ArrayAccess; use ArrayAccess;
use BadMethodCallException; use BadMethodCallException;
use InvalidArgumentException; use InvalidArgumentException;
@ -910,10 +911,11 @@ class HTTPRequest implements ArrayAccess
* @param string $origMethod Original HTTP method from the browser request * @param string $origMethod Original HTTP method from the browser request
* @param array $postVars * @param array $postVars
* @return string HTTP method (all uppercase) * @return string HTTP method (all uppercase)
* @deprecated 4.4.7 * @deprecated 4.4.7 Will be removed without equivalent functionality
*/ */
public static function detect_method($origMethod, $postVars) public static function detect_method($origMethod, $postVars)
{ {
Deprecation::notice('4.4.7', 'Will be removed without equivalent functionality');
if (isset($postVars['_method'])) { if (isset($postVars['_method'])) {
if (!self::isValidHttpMethod($postVars['_method'])) { if (!self::isValidHttpMethod($postVars['_method'])) {
throw new InvalidArgumentException('HTTPRequest::detect_method(): Invalid "_method" parameter'); throw new InvalidArgumentException('HTTPRequest::detect_method(): Invalid "_method" parameter');

View File

@ -9,7 +9,7 @@ use SilverStripe\Dev\Deprecation;
/** /**
* Middleware that provides back-support for the deprecated RequestFilter API. * Middleware that provides back-support for the deprecated RequestFilter API.
* *
* @deprecated 4.0.0:5.0.0 Use HTTPMiddleware directly instead. * @deprecated 4.0.1 Use HTTPMiddleware directly instead.
*/ */
class RequestProcessor implements HTTPMiddleware class RequestProcessor implements HTTPMiddleware
{ {
@ -29,6 +29,7 @@ class RequestProcessor implements HTTPMiddleware
*/ */
public function __construct($filters = []) public function __construct($filters = [])
{ {
Deprecation::notice('4.0.1', 'Use HTTPMiddleware directly instead.', Deprecation::SCOPE_CLASS);
$this->filters = $filters; $this->filters = $filters;
} }

View File

@ -586,13 +586,13 @@ class Session
* Recursively apply the changes represented in $data to $dest. * Recursively apply the changes represented in $data to $dest.
* Used to update $_SESSION * Used to update $_SESSION
* *
* @deprecated 4.1.0:5.0.0 Use recursivelyApplyChanges() instead * @deprecated 4.1.0 Use recursivelyApplyChanges() instead
* @param array $data * @param array $data
* @param array $dest * @param array $dest
*/ */
protected function recursivelyApply($data, &$dest) protected function recursivelyApply($data, &$dest)
{ {
Deprecation::notice('5.0', 'Use recursivelyApplyChanges() instead'); Deprecation::notice('4.1.0', 'Use recursivelyApplyChanges() instead');
foreach ($data as $k => $v) { foreach ($data as $k => $v) {
if (is_array($v)) { if (is_array($v)) {
if (!isset($dest[$k]) || !is_array($dest[$k])) { if (!isset($dest[$k]) || !is_array($dest[$k])) {

View File

@ -2,6 +2,7 @@
namespace SilverStripe\Control; namespace SilverStripe\Control;
use SilverStripe\Dev\Deprecation;
use InvalidArgumentException; use InvalidArgumentException;
use SilverStripe\Core\Config\Config; use SilverStripe\Core\Config\Config;
use SilverStripe\Core\Convert; use SilverStripe\Core\Convert;
@ -159,12 +160,13 @@ class SimpleResourceURLGenerator implements ResourceURLGenerator
/** /**
* Resolve resource in the absence of a public/ folder * Resolve resource in the absence of a public/ folder
* *
* @deprecated 4.1.0:5.0.0 Will be removed in 5.0 when public/ folder becomes mandatory * @deprecated 4.1.0 Will be removed without equivalent functionality when public/ folder becomes mandatory
* @param string $relativePath * @param string $relativePath
* @return array List of [$exists, $absolutePath, $relativePath] * @return array List of [$exists, $absolutePath, $relativePath]
*/ */
protected function resolveUnsecuredResource($relativePath) protected function resolveUnsecuredResource($relativePath)
{ {
Deprecation::notice('4.1.0', 'Will be removed without equivalent functionality when public/ folder becomes mandatory');
// Check if the path requested is public-only, but we have no public folder // Check if the path requested is public-only, but we have no public folder
$publicOnly = $this->inferPublicResourceRequired($relativePath); $publicOnly = $this->inferPublicResourceRequired($relativePath);
if ($publicOnly) { if ($publicOnly) {

View File

@ -260,10 +260,11 @@ abstract class BaseKernel implements Kernel
* *
* @return string * @return string
* *
* @deprecated 5.0 use Director::get_environment_type() instead. Since 5.0 it should return only if kernel overrides. No checking SESSION or Environment. * @deprecated 4.12.0 Use Director::get_environment_type() instead
*/ */
public function getEnvironment() public function getEnvironment()
{ {
Deprecation::notice('4.12.0', 'Use Director::get_environment_type() instead');
// Check set // Check set
if ($this->enviroment) { if ($this->enviroment) {
return $this->enviroment; return $this->enviroment;
@ -288,10 +289,11 @@ abstract class BaseKernel implements Kernel
* *
* @return null|string * @return null|string
* *
* @deprecated 5.0 Use Director::get_session_environment_type() instead * @deprecated 4.12.0 Use Director::get_session_environment_type() instead
*/ */
protected function sessionEnvironment() protected function sessionEnvironment()
{ {
Deprecation::notice('4.12.0', 'Use Director::get_session_environment_type() instead');
if (!$this->booted) { if (!$this->booted) {
// session is not initialyzed yet, neither is manifest // session is not initialyzed yet, neither is manifest
return null; return null;
@ -378,11 +380,11 @@ abstract class BaseKernel implements Kernel
* The purpose of this method is to avoid loading PHPUnit test files with incompatible definitions. * The purpose of this method is to avoid loading PHPUnit test files with incompatible definitions.
* *
* @return string[] List of CI types to ignore as defined by `Module`. * @return string[] List of CI types to ignore as defined by `Module`.
* @deprecated 5.0.0 * @deprecated 4.12.0 Will be removed without equivalent functionality
*/ */
protected function getIgnoredCIConfigs(): array protected function getIgnoredCIConfigs(): array
{ {
Deprecation::notice('5.0.0', 'This method will be removed in CMS 5'); Deprecation::notice('4.12.0', 'Will be removed without equivalent functionality');
return []; return [];
} }

View File

@ -156,13 +156,13 @@ class ClassInfo
} }
/** /**
* @deprecated 4.0.0:5.0.0 * @deprecated 4.0.1 Use DataObject::getSchema()->baseDataClass()
* @param string $class * @param string $class
* @return string * @return string
*/ */
public static function baseDataClass($class) public static function baseDataClass($class)
{ {
Deprecation::notice('5.0', 'Use DataObject::getSchema()->baseDataClass()'); Deprecation::notice('4.0.1', 'Use DataObject::getSchema()->baseDataClass()');
return DataObject::getSchema()->baseDataClass($class); return DataObject::getSchema()->baseDataClass($class);
} }
@ -371,11 +371,11 @@ class ClassInfo
} }
/** /**
* @deprecated 4.0.0:5.0.0 * @deprecated 4.0.1 Use DataObject::getSchema()->tableForField()
*/ */
public static function table_for_object_field($candidateClass, $fieldName) public static function table_for_object_field($candidateClass, $fieldName)
{ {
Deprecation::notice('5.0', 'Use DataObject::getSchema()->tableForField()'); Deprecation::notice('4.0.1', 'Use DataObject::getSchema()->tableForField()');
return DataObject::getSchema()->tableForField($candidateClass, $fieldName); return DataObject::getSchema()->tableForField($candidateClass, $fieldName);
} }

View File

@ -43,10 +43,11 @@ class Config_ForClass
* @param string $name * @param string $name
* @param mixed $value * @param mixed $value
* @return $this * @return $this
* @deprecated 4.12.0 Use merge() instead
*/ */
public function update($name, $value) public function update($name, $value)
{ {
Deprecation::notice('5.0', 'Use merge() instead'); Deprecation::notice('4.12.0', 'Use merge() instead');
return $this->merge($name, $value); return $this->merge($name, $value);
} }

View File

@ -161,14 +161,14 @@ class Convert
* Encode a value as a JSON encoded string. You can optionally pass a bitmask of * Encode a value as a JSON encoded string. You can optionally pass a bitmask of
* JSON constants as options through to the encode function. * JSON constants as options through to the encode function.
* *
* @deprecated 4.4.0:5.0.0 Use json_encode() instead * @deprecated 4.4.0 Use json_encode() instead
* @param mixed $val Value to be encoded * @param mixed $val Value to be encoded
* @param int $options Optional bitmask of JSON constants * @param int $options Optional bitmask of JSON constants
* @return string JSON encoded string * @return string JSON encoded string
*/ */
public static function raw2json($val, $options = 0) public static function raw2json($val, $options = 0)
{ {
Deprecation::notice('4.4', 'Please use json_encode() instead.'); Deprecation::notice('4.4.0', 'Use json_encode() instead');
return json_encode($val, $options ?? 0); return json_encode($val, $options ?? 0);
} }
@ -176,14 +176,14 @@ class Convert
/** /**
* Encode an array as a JSON encoded string. * Encode an array as a JSON encoded string.
* *
* @deprecated 4.4.0:5.0.0 Use json_encode() instead * @deprecated 4.4.0 Use json_encode() instead
* @param array $val Array to convert * @param array $val Array to convert
* @param int $options Optional bitmask of JSON constants * @param int $options Optional bitmask of JSON constants
* @return string JSON encoded string * @return string JSON encoded string
*/ */
public static function array2json($val, $options = 0) public static function array2json($val, $options = 0)
{ {
Deprecation::notice('4.4', 'Please use json_encode() instead.'); Deprecation::notice('4.4.0', 'Use json_encode() instead');
return json_encode($val, $options ?? 0); return json_encode($val, $options ?? 0);
} }
@ -261,13 +261,13 @@ class Convert
/** /**
* Convert a JSON encoded string into an object. * Convert a JSON encoded string into an object.
* *
* @deprecated 4.4.0:5.0.0 Use json_decode() instead * @deprecated 4.4.0 Use json_decode() instead
* @param string $val * @param string $val
* @return object|boolean * @return object|boolean
*/ */
public static function json2obj($val) public static function json2obj($val)
{ {
Deprecation::notice('4.4', 'Please use json_decode() instead.'); Deprecation::notice('4.4.0', 'Use json_decode() instead');
return json_decode($val ?? ''); return json_decode($val ?? '');
} }
@ -275,13 +275,13 @@ class Convert
/** /**
* Convert a JSON string into an array. * Convert a JSON string into an array.
* *
* @deprecated 4.4.0:5.0.0 Use json_decode() instead * @deprecated 4.4.0 Use json_decode() instead
* @param string $val JSON string to convert * @param string $val JSON string to convert
* @return array|boolean * @return array|boolean
*/ */
public static function json2array($val) public static function json2array($val)
{ {
Deprecation::notice('4.4', 'Please use json_decode() instead.'); Deprecation::notice('4.4.0', 'Use json_decode() instead');
return json_decode($val ?? '', true); return json_decode($val ?? '', true);
} }
@ -295,13 +295,13 @@ class Convert
* @param boolean $disableDoctypes Disables the use of DOCTYPE, and will trigger an error if encountered. * @param boolean $disableDoctypes Disables the use of DOCTYPE, and will trigger an error if encountered.
* false by default. * false by default.
* @param boolean $disableExternals Does nothing because xml entities are removed * @param boolean $disableExternals Does nothing because xml entities are removed
* @deprecated 4.11.0:5.0.0 * @deprecated 4.11.0 Use a dedicated XML library instead
* @return array * @return array
* @throws Exception * @throws Exception
*/ */
public static function xml2array($val, $disableDoctypes = false, $disableExternals = false) public static function xml2array($val, $disableDoctypes = false, $disableExternals = false)
{ {
Deprecation::notice('4.10', 'Use a dedicated XML library instead'); Deprecation::notice('4.11.0', 'Use a dedicated XML library instead');
// Check doctype // Check doctype
if ($disableDoctypes && strpos($val ?? '', '<!DOCTYPE') !== false) { if ($disableDoctypes && strpos($val ?? '', '<!DOCTYPE') !== false) {

View File

@ -854,13 +854,13 @@ class Injector implements ContainerInterface
} }
/** /**
* @deprecated 4.0.0:5.0.0 Use Injector::has() instead * @deprecated 4.0.1 Use Injector::has() instead
* @param $name * @param $name
* @return string * @return string
*/ */
public function hasService($name) public function hasService($name)
{ {
Deprecation::notice('5.0', 'Use Injector::has() instead'); Deprecation::notice('4.0.1', 'Use Injector::has() instead');
return $this->has($name); return $this->has($name);
} }

View File

@ -142,10 +142,11 @@ class ClassLoader
* *
* @param string $class * @param string $class
* @return bool * @return bool
* @deprecated 4.0.1 Use ClassInfo::exists() instead
*/ */
public function classExists($class) public function classExists($class)
{ {
Deprecation::notice('4.0', 'Use ClassInfo::exists.'); Deprecation::notice('4.0.1', 'Use ClassInfo::exists() instead');
return ClassInfo::exists($class); return ClassInfo::exists($class);
} }
} }

View File

@ -206,10 +206,11 @@ class Module implements Serializable
* The __serialize() magic method will be automatically used instead of this * The __serialize() magic method will be automatically used instead of this
* *
* @return string * @return string
* @deprecated will be removed in 5.0 * @deprecated 4.12.0 Use __serialize() instead
*/ */
public function serialize() public function serialize()
{ {
Deprecation::notice('4.12.0', 'Use __serialize() instead');
return json_encode([$this->path, $this->basePath, $this->composerData]); return json_encode([$this->path, $this->basePath, $this->composerData]);
} }
@ -219,10 +220,11 @@ class Module implements Serializable
* and the PHP version used in less than PHP 9.0 * and the PHP version used in less than PHP 9.0
* *
* @param string $serialized * @param string $serialized
* @deprecated will be removed in 5.0 * @deprecated 4.12.0 Use __unserialize() instead
*/ */
public function unserialize($serialized) public function unserialize($serialized)
{ {
Deprecation::notice('4.12.0', 'Use __unserialize() instead');
list($this->path, $this->basePath, $this->composerData) = json_decode($serialized ?? '', true); list($this->path, $this->basePath, $this->composerData) = json_decode($serialized ?? '', true);
$this->resources = []; $this->resources = [];
} }
@ -275,52 +277,52 @@ class Module implements Serializable
} }
/** /**
* @deprecated 4.0.0:5.0.0 Use getResource($path)->getRelativePath() instead * @deprecated 4.0.1 Use getResource($path)->getRelativePath() instead
* @param string $path * @param string $path
* @return string * @return string
*/ */
public function getRelativeResourcePath($path) public function getRelativeResourcePath($path)
{ {
Deprecation::notice('5.0', 'Use getResource($path)->getRelativePath() instead'); Deprecation::notice('4.0.1', 'Use getResource($path)->getRelativePath() instead');
return $this return $this
->getResource($path) ->getResource($path)
->getRelativePath(); ->getRelativePath();
} }
/** /**
* @deprecated 4.0.0:5.0.0 Use ->getResource($path)->getPath() instead * @deprecated 4.0.1 Use getResource($path)->getPath() instead
* @param string $path * @param string $path
* @return string * @return string
*/ */
public function getResourcePath($path) public function getResourcePath($path)
{ {
Deprecation::notice('5.0', 'Use getResource($path)->getPath() instead'); Deprecation::notice('4.0.1', 'Use getResource($path)->getPath() instead');
return $this return $this
->getResource($path) ->getResource($path)
->getPath(); ->getPath();
} }
/** /**
* @deprecated 4.0.0:5.0.0 Use ->getResource($path)->getURL() instead * @deprecated 4.0.1 Use getResource($path)->getURL() instead
* @param string $path * @param string $path
* @return string * @return string
*/ */
public function getResourceURL($path) public function getResourceURL($path)
{ {
Deprecation::notice('5.0', 'Use getResource($path)->getURL() instead'); Deprecation::notice('4.0.1', 'Use getResource($path)->getURL() instead');
return $this return $this
->getResource($path) ->getResource($path)
->getURL(); ->getURL();
} }
/** /**
* @deprecated 4.0.0:5.0.0 Use ->getResource($path)->exists() instead * @deprecated 4.0.1 Use getResource($path)->exists() instead
* @param string $path * @param string $path
* @return string * @return string
*/ */
public function hasResource($path) public function hasResource($path)
{ {
Deprecation::notice('5.0', 'Use getResource($path)->exists() instead'); Deprecation::notice('4.0.1', 'Use getResource($path)->exists() instead');
return $this return $this
->getResource($path) ->getResource($path)
->exists(); ->exists();
@ -331,11 +333,11 @@ class Module implements Serializable
* that is observed is `PHP` * that is observed is `PHP`
* @return array List of configuration aspects e.g.: `['PHP' => 'CI_PHPUNIT_NINE']` * @return array List of configuration aspects e.g.: `['PHP' => 'CI_PHPUNIT_NINE']`
* @internal * @internal
* @deprecated 5.0.0 * @deprecated 4.12.0 Will be removed without equivalent functionality
*/ */
public function getCIConfig(): array public function getCIConfig(): array
{ {
Deprecation::notice('5.0.0', 'This method will be removed in CMS 5'); Deprecation::notice('4.12.0', 'Will be removed without equivalent functionality');
return [ return [
'PHP' => $this->getPhpCiConfig() 'PHP' => $this->getPhpCiConfig()
]; ];

View File

@ -2,6 +2,7 @@
namespace SilverStripe\Core\Startup; namespace SilverStripe\Core\Startup;
use SilverStripe\Dev\Deprecation;
use SilverStripe\Control\Controller; use SilverStripe\Control\Controller;
use SilverStripe\Control\Director; use SilverStripe\Control\Director;
use SilverStripe\Control\HTTPRequest; use SilverStripe\Control\HTTPRequest;
@ -15,7 +16,7 @@ use SilverStripe\Security\RandomGenerator;
* *
* @internal This class is designed specifically for use pre-startup and may change without warning * @internal This class is designed specifically for use pre-startup and may change without warning
* *
* @deprecated 5.0 To be removed in SilverStripe 5.0 * @deprecated 4.12.0 Will be removed without equivalent functionality
*/ */
abstract class AbstractConfirmationToken abstract class AbstractConfirmationToken
{ {
@ -39,6 +40,11 @@ abstract class AbstractConfirmationToken
* @param HTTPRequest $request * @param HTTPRequest $request
* @return static The token container for the unvalidated $key given with the highest priority * @return static The token container for the unvalidated $key given with the highest priority
*/ */
public function __construct()
{
Deprecation::notice('4.12.0', 'Will be removed without equivalent functionality', Deprecation::SCOPE_CLASS);
}
public static function prepare_tokens($keys, HTTPRequest $request) public static function prepare_tokens($keys, HTTPRequest $request)
{ {
$target = null; $target = null;

View File

@ -2,6 +2,7 @@
namespace SilverStripe\Core\Startup; namespace SilverStripe\Core\Startup;
use SilverStripe\Dev\Deprecation;
use SilverStripe\Control\Controller; use SilverStripe\Control\Controller;
use SilverStripe\Control\Director; use SilverStripe\Control\Director;
use SilverStripe\Control\HTTPResponse; use SilverStripe\Control\HTTPResponse;
@ -13,7 +14,7 @@ use SilverStripe\Core\Convert;
* *
* @internal This class is designed specifically for use pre-startup and may change without warning * @internal This class is designed specifically for use pre-startup and may change without warning
* *
* @deprecated 5.0 To be removed in SilverStripe 5.0 * @deprecated 4.12.0 Will be removed without equivalent functionality
*/ */
class ConfirmationTokenChain class ConfirmationTokenChain
{ {
@ -25,6 +26,11 @@ class ConfirmationTokenChain
/** /**
* @param AbstractConfirmationToken $token * @param AbstractConfirmationToken $token
*/ */
public function __construct()
{
Deprecation::notice('4.12.0', 'Will be removed without equivalent functionality', Deprecation::SCOPE_CLASS);
}
public function pushToken(AbstractConfirmationToken $token) public function pushToken(AbstractConfirmationToken $token)
{ {
$this->tokens[] = $token; $this->tokens[] = $token;

View File

@ -2,6 +2,7 @@
namespace SilverStripe\Core\Startup; namespace SilverStripe\Core\Startup;
use SilverStripe\Dev\Deprecation;
use Exception; use Exception;
/** /**
@ -17,7 +18,7 @@ use Exception;
* *
* @internal This class is designed specifically for use pre-startup and may change without warning * @internal This class is designed specifically for use pre-startup and may change without warning
* *
* @deprecated 5.0 To be removed in SilverStripe 5.0 * @deprecated 4.12.0 Will be removed without equivalent functionality
*/ */
class ErrorControlChain class ErrorControlChain
{ {
@ -62,6 +63,11 @@ class ErrorControlChain
* *
* @return bool * @return bool
*/ */
public function __construct()
{
Deprecation::notice('4.12.0', 'Will be removed without equivalent functionality', Deprecation::SCOPE_CLASS);
}
public function hasErrored() public function hasErrored()
{ {
return $this->error; return $this->error;

View File

@ -16,7 +16,7 @@ use SilverStripe\Security\Security;
* *
* @internal This class is designed specifically for use pre-startup and may change without warning * @internal This class is designed specifically for use pre-startup and may change without warning
* *
* @deprecated 5.0 To be removed in SilverStripe 5.0 * @deprecated 4.12.0 Will be removed without equivalent functionality
*/ */
class ErrorControlChainMiddleware implements HTTPMiddleware class ErrorControlChainMiddleware implements HTTPMiddleware
{ {
@ -40,9 +40,9 @@ class ErrorControlChainMiddleware implements HTTPMiddleware
*/ */
public function __construct(Application $application, $legacy = false) public function __construct(Application $application, $legacy = false)
{ {
Deprecation::notice('4.12.0', 'Will be removed without equivalent functionality', Deprecation::SCOPE_CLASS);
$this->application = $application; $this->application = $application;
$this->legacy = $legacy; $this->legacy = $legacy;
Deprecation::notice('5.0', 'ErrorControlChainMiddleware is deprecated and will be removed completely');
} }
/** /**

View File

@ -2,6 +2,7 @@
namespace SilverStripe\Core\Startup; namespace SilverStripe\Core\Startup;
use SilverStripe\Dev\Deprecation;
use SilverStripe\Control\Director; use SilverStripe\Control\Director;
use SilverStripe\Control\HTTPRequest; use SilverStripe\Control\HTTPRequest;
use SilverStripe\Control\HTTPResponse; use SilverStripe\Control\HTTPResponse;
@ -15,7 +16,7 @@ use SilverStripe\Security\Security;
* *
* @internal This class is experimental API and may change without warning * @internal This class is experimental API and may change without warning
* *
* @deprecated 5.0 To be removed in SilverStripe 5.0 * @deprecated 4.12.0 Will be removed without equivalent functionality
*/ */
class ErrorDirector extends Director class ErrorDirector extends Director
{ {
@ -27,6 +28,11 @@ class ErrorDirector extends Director
* @param Kernel $kernel * @param Kernel $kernel
* @return null|HTTPResponse Redirection response, or null if not able to redirect * @return null|HTTPResponse Redirection response, or null if not able to redirect
*/ */
public function __construct()
{
Deprecation::notice('4.12.0', 'Will be removed without equivalent functionality', Deprecation::SCOPE_CLASS);
}
public function handleRequestWithTokenChain( public function handleRequestWithTokenChain(
HTTPRequest $request, HTTPRequest $request,
ConfirmationTokenChain $confirmationTokenChain, ConfirmationTokenChain $confirmationTokenChain,

View File

@ -2,6 +2,7 @@
namespace SilverStripe\Core\Startup; namespace SilverStripe\Core\Startup;
use SilverStripe\Dev\Deprecation;
use SilverStripe\Control\Controller; use SilverStripe\Control\Controller;
use SilverStripe\Control\Director; use SilverStripe\Control\Director;
use SilverStripe\Control\HTTPRequest; use SilverStripe\Control\HTTPRequest;
@ -16,7 +17,7 @@ use SilverStripe\Security\RandomGenerator;
* *
* @internal This class is designed specifically for use pre-startup and may change without warning * @internal This class is designed specifically for use pre-startup and may change without warning
* *
* @deprecated 5.0 To be removed in SilverStripe 5.0 * @deprecated 4.12.0 Will be removed without equivalent functionality
*/ */
class ParameterConfirmationToken extends AbstractConfirmationToken class ParameterConfirmationToken extends AbstractConfirmationToken
{ {
@ -47,6 +48,7 @@ class ParameterConfirmationToken extends AbstractConfirmationToken
*/ */
public function __construct($parameterName, HTTPRequest $request) public function __construct($parameterName, HTTPRequest $request)
{ {
Deprecation::notice('4.12.0', 'Will be removed without equivalent functionality', Deprecation::SCOPE_CLASS);
// Store the parameter name // Store the parameter name
$this->parameterName = $parameterName; $this->parameterName = $parameterName;
$this->request = $request; $this->request = $request;

View File

@ -2,6 +2,7 @@
namespace SilverStripe\Core\Startup; namespace SilverStripe\Core\Startup;
use SilverStripe\Dev\Deprecation;
use SilverStripe\Control\Controller; use SilverStripe\Control\Controller;
use SilverStripe\Control\Director; use SilverStripe\Control\Director;
use SilverStripe\Control\HTTPRequest; use SilverStripe\Control\HTTPRequest;
@ -12,7 +13,7 @@ use SilverStripe\Control\HTTPRequest;
* *
* @internal This class is designed specifically for use pre-startup and may change without warning * @internal This class is designed specifically for use pre-startup and may change without warning
* *
* @deprecated 5.0 To be removed in SilverStripe 5.0 * @deprecated 4.12.0 Will be removed without equivalent functionality
*/ */
class URLConfirmationToken extends AbstractConfirmationToken class URLConfirmationToken extends AbstractConfirmationToken
{ {
@ -42,6 +43,7 @@ class URLConfirmationToken extends AbstractConfirmationToken
*/ */
public function __construct($urlToCheck, HTTPRequest $request) public function __construct($urlToCheck, HTTPRequest $request)
{ {
Deprecation::notice('4.12.0', 'Will be removed without equivalent functionality', Deprecation::SCOPE_CLASS);
$this->urlToCheck = $urlToCheck; $this->urlToCheck = $urlToCheck;
$this->request = $request; $this->request = $request;
$this->currentURL = $request->getURL(false); $this->currentURL = $request->getURL(false);

View File

@ -173,10 +173,11 @@ class CsvBulkLoader extends BulkLoader
* @param int $lines Number of lines per file * @param int $lines Number of lines per file
* *
* @return array List of file paths * @return array List of file paths
* @deprecated 4.12.0 Process files using a stream instead
*/ */
protected function splitFile($path, $lines = null) protected function splitFile($path, $lines = null)
{ {
Deprecation::notice('5.0', 'splitFile is deprecated, please process files using a stream'); Deprecation::notice('4.12.0', 'Process files using a stream instead');
if (!is_int($lines)) { if (!is_int($lines)) {
$lines = $this->config()->get("lines"); $lines = $this->config()->get("lines");
@ -229,10 +230,11 @@ class CsvBulkLoader extends BulkLoader
/** /**
* @return string * @return string
* @deprecated 4.12.0 Name files yourself instead
*/ */
protected function getNewSplitFileName() protected function getNewSplitFileName()
{ {
Deprecation::notice('5.0', 'getNewSplitFileName is deprecated, please name your files yourself'); Deprecation::notice('4.12.0', 'Name files yourself instead');
return TEMP_PATH . DIRECTORY_SEPARATOR . uniqid(str_replace('\\', '_', static::class) ?? '', true) . '.csv'; return TEMP_PATH . DIRECTORY_SEPARATOR . uniqid(str_replace('\\', '_', static::class) ?? '', true) . '.csv';
} }
@ -241,10 +243,11 @@ class CsvBulkLoader extends BulkLoader
* @param boolean $preview * @param boolean $preview
* *
* @return BulkLoader_Result * @return BulkLoader_Result
* @deprecated 4.12.0 Process rows individually instead
*/ */
protected function processChunk($filepath, $preview = false) protected function processChunk($filepath, $preview = false)
{ {
Deprecation::notice('5.0', 'processChunk is deprecated, please process rows individually'); Deprecation::notice('4.12.0', 'Process rows individually instead');
$results = BulkLoader_Result::create(); $results = BulkLoader_Result::create();
$csv = new CSVParser( $csv = new CSVParser(

View File

@ -143,65 +143,65 @@ class DebugView
} }
/** /**
* @deprecated 4.0.0:5.0.0 Use renderHeader() instead * @deprecated 4.0.1 Use renderHeader() instead
*/ */
public function writeHeader() public function writeHeader()
{ {
Deprecation::notice('4.0', 'Use renderHeader() instead'); Deprecation::notice('4.0.1', 'Use renderHeader() instead');
echo $this->renderHeader(); echo $this->renderHeader();
} }
/** /**
* @deprecated 4.0.0:5.0.0 Use renderInfo() instead * @deprecated 4.0.1 Use renderInfo() instead
*/ */
public function writeInfo($title, $subtitle, $description = false) public function writeInfo($title, $subtitle, $description = false)
{ {
Deprecation::notice('4.0', 'Use renderInfo() instead'); Deprecation::notice('4.0.1', 'Use renderInfo() instead');
echo $this->renderInfo($title, $subtitle, $description); echo $this->renderInfo($title, $subtitle, $description);
} }
/** /**
* @deprecated 4.0.0:5.0.0 Use renderFooter() instead * @deprecated 4.0.1 Use renderFooter() instead
*/ */
public function writeFooter() public function writeFooter()
{ {
Deprecation::notice('4.0', 'Use renderFooter() instead'); Deprecation::notice('4.0.1', 'Use renderFooter() instead');
echo $this->renderFooter(); echo $this->renderFooter();
} }
/** /**
* @deprecated 4.0.0:5.0.0 Use renderError() instead * @deprecated 4.0.1 Use renderError() instead
*/ */
public function writeError($httpRequest, $errno, $errstr, $errfile, $errline) public function writeError($httpRequest, $errno, $errstr, $errfile, $errline)
{ {
Deprecation::notice('4.0', 'Use renderError() instead'); Deprecation::notice('4.0.1', 'Use renderError() instead');
echo $this->renderError($httpRequest, $errno, $errstr, $errfile, $errline); echo $this->renderError($httpRequest, $errno, $errstr, $errfile, $errline);
} }
/** /**
* @deprecated 4.0.0:5.0.0 Use renderSourceFragment() instead * @deprecated 4.0.1 Use renderSourceFragment() instead
*/ */
public function writeSourceFragment($lines, $errline) public function writeSourceFragment($lines, $errline)
{ {
Deprecation::notice('4.0', 'Use renderSourceFragment() instead'); Deprecation::notice('4.0.1', 'Use renderSourceFragment() instead');
echo $this->renderSourceFragment($lines, $errline); echo $this->renderSourceFragment($lines, $errline);
} }
/** /**
* @deprecated 4.0.0:5.0.0 Use renderTrace() instead * @deprecated 4.0.1 Use renderTrace() instead
*/ */
public function writeTrace($trace) public function writeTrace($trace)
{ {
Deprecation::notice('4.0', 'Use renderTrace() instead'); Deprecation::notice('4.0.1', 'Use renderTrace() instead');
echo $this->renderTrace($trace); echo $this->renderTrace($trace);
} }
/** /**
* @deprecated 4.0.0:5.0.0 Use renderVariable() instead * @deprecated 4.0.1 Use renderVariable() instead
*/ */
public function writeVariable($val, $caller) public function writeVariable($val, $caller)
{ {
Deprecation::notice('4.0', 'Use renderVariable() instead'); Deprecation::notice('4.0.1', 'Use renderVariable() instead');
echo $this->renderVariable($val, $caller); echo $this->renderVariable($val, $caller);
} }

View File

@ -66,7 +66,7 @@ if (class_exists(IsEqualCanonicalizing::class)) {
/** /**
* Set this to true on your sub-class to use the draft site by default for every test in this class. * Set this to true on your sub-class to use the draft site by default for every test in this class.
* *
* @deprecated 4.2.0:5.0.0 Use ?stage=Stage in your ->get() querystring requests instead * @deprecated 4.2.0 Use ?stage=Stage in your request's querystring instead
* @var bool * @var bool
*/ */
protected static $use_draft_site = false; protected static $use_draft_site = false;
@ -425,12 +425,12 @@ if (class_exists(IsEqualCanonicalizing::class)) {
* This is helpful if you're not testing publication functionality and don't want "stage management" cluttering * This is helpful if you're not testing publication functionality and don't want "stage management" cluttering
* your test. * your test.
* *
* @deprecated 4.2.0:5.0.0 Use ?stage=Stage querystring arguments instead of useDraftSite * @deprecated 4.2.0 Use ?stage=Stage in your request's querystring instead
* @param bool $enabled toggle the use of the draft site * @param bool $enabled toggle the use of the draft site
*/ */
public function useDraftSite($enabled = true) public function useDraftSite($enabled = true)
{ {
Deprecation::notice('5.0', 'Use ?stage=Stage querystring arguments instead of useDraftSite'); Deprecation::notice('4.2.0', 'Use ?stage=Stage in your request\'s querystring instead');
if ($enabled) { if ($enabled) {
$this->session()->set('readingMode', 'Stage.Stage'); $this->session()->set('readingMode', 'Stage.Stage');
$this->session()->set('unsecuredDraftSite', true); $this->session()->set('unsecuredDraftSite', true);
@ -449,11 +449,12 @@ if (class_exists(IsEqualCanonicalizing::class)) {
} }
/** /**
* @deprecated 4.2.0:5.0.0 Use ?stage=Stage in your querystring arguments instead * @deprecated 4.2.0 Use ?stage=Stage in your request's querystring instead
* @return bool * @return bool
*/ */
public static function get_use_draft_site() public static function get_use_draft_site()
{ {
Deprecation::notice('4.2.0', 'Use ?stage=Stage in your request\'s querystring instead');
return static::$use_draft_site; return static::$use_draft_site;
} }
} }
@ -508,7 +509,7 @@ class FunctionalTest extends SapphireTest implements TestOnly
/** /**
* Set this to true on your sub-class to use the draft site by default for every test in this class. * Set this to true on your sub-class to use the draft site by default for every test in this class.
* *
* @deprecated 4.2.0:5.0.0 Use ?stage=Stage in your ->get() querystring requests instead * @deprecated 4.2.0 Use ?stage=Stage in your request's querystring instead
* @var bool * @var bool
*/ */
protected static $use_draft_site = false; protected static $use_draft_site = false;
@ -869,12 +870,12 @@ class FunctionalTest extends SapphireTest implements TestOnly
* This is helpful if you're not testing publication functionality and don't want "stage management" cluttering * This is helpful if you're not testing publication functionality and don't want "stage management" cluttering
* your test. * your test.
* *
* @deprecated 4.2.0:5.0.0 Use ?stage=Stage querystring arguments instead of useDraftSite * @deprecated 4.2.0 Use ?stage=Stage in your request's querystring instead
* @param bool $enabled toggle the use of the draft site * @param bool $enabled toggle the use of the draft site
*/ */
public function useDraftSite($enabled = true) public function useDraftSite($enabled = true)
{ {
Deprecation::notice('5.0', 'Use ?stage=Stage querystring arguments instead of useDraftSite'); Deprecation::notice('4.2.0', 'Use ?stage=Stage in your request\'s querystring instead');
if ($enabled) { if ($enabled) {
$this->session()->set('readingMode', 'Stage.Stage'); $this->session()->set('readingMode', 'Stage.Stage');
$this->session()->set('unsecuredDraftSite', true); $this->session()->set('unsecuredDraftSite', true);
@ -893,11 +894,12 @@ class FunctionalTest extends SapphireTest implements TestOnly
} }
/** /**
* @deprecated 4.2.0:5.0.0 Use ?stage=Stage in your querystring arguments instead * @deprecated 4.2.0 Use ?stage=Stage in your request's querystring instead
* @return bool * @return bool
*/ */
public static function get_use_draft_site() public static function get_use_draft_site()
{ {
Deprecation::notice('4.2.0', 'Use ?stage=Stage in your request\'s querystring instead');
return static::$use_draft_site; return static::$use_draft_site;
} }
} }

View File

@ -2,11 +2,12 @@
namespace SilverStripe\Dev; namespace SilverStripe\Dev;
use SilverStripe\Dev\Deprecation;
use SilverStripe\Control\Controller; use SilverStripe\Control\Controller;
/** /**
* Simple controller that the installer uses to test that URL rewriting is working. * Simple controller that the installer uses to test that URL rewriting is working.
* @deprecated 4.4.7 This class will be removed in Silverstripe Framework 5. * @deprecated 4.4.7 Will be removed without equivalent functionality
*/ */
class InstallerTest extends Controller class InstallerTest extends Controller
{ {
@ -15,6 +16,11 @@ class InstallerTest extends Controller
'testrewrite' 'testrewrite'
]; ];
public function __construct()
{
Deprecation::notice('4.4.7', 'Will be removed without equivalent functionality', Deprecation::SCOPE_CLASS);
}
public function testrewrite() public function testrewrite()
{ {
echo "OK"; echo "OK";

View File

@ -2,6 +2,7 @@
namespace SilverStripe\Dev; namespace SilverStripe\Dev;
use SilverStripe\Dev\Deprecation;
use SilverStripe\Control\Controller; use SilverStripe\Control\Controller;
use SilverStripe\Control\Director; use SilverStripe\Control\Director;
use SilverStripe\Security\Permission; use SilverStripe\Security\Permission;
@ -9,7 +10,7 @@ use SilverStripe\Security\Security;
/** /**
* Returns information about the current site instance. * Returns information about the current site instance.
* @deprecated 4.4.7 This class will be removed in Silverstripe Framework 5. * @deprecated 4.4.7 Will be removed without equivalent functionality
*/ */
class SapphireInfo extends Controller class SapphireInfo extends Controller
{ {
@ -19,6 +20,11 @@ class SapphireInfo extends Controller
'environmenttype', 'environmenttype',
]; ];
public function __construct()
{
Deprecation::notice('4.4.7', 'Will be removed without equivalent functionality', Deprecation::SCOPE_CLASS);
}
protected function init() protected function init()
{ {
parent::init(); parent::init();

View File

@ -98,7 +98,7 @@ if (class_exists(IsEqualCanonicalizing::class)) {
protected static $fixture_file = null; protected static $fixture_file = null;
/** /**
* @deprecated 4.0..5.0 Use FixtureTestState instead * @deprecated 4.0.1 Use FixtureTestState instead
* @var FixtureFactory * @var FixtureFactory
*/ */
protected $fixtureFactory; protected $fixtureFactory;
@ -472,11 +472,11 @@ if (class_exists(IsEqualCanonicalizing::class)) {
/** /**
* @return FixtureFactory|false * @return FixtureFactory|false
* @deprecated 4.0.0:5.0.0 * @deprecated 4.0.1 Use FixtureTestState instead
*/ */
public function getFixtureFactory() public function getFixtureFactory()
{ {
Deprecation::notice('5.0', __FUNCTION__ . ' is deprecated, use ' . FixtureTestState::class . ' instead'); Deprecation::notice('4.0.1', 'Use FixtureTestState instead');
/** @var FixtureTestState $state */ /** @var FixtureTestState $state */
$state = static::$state->getStateByName('fixtures'); $state = static::$state->getStateByName('fixtures');
return $state->getFixtureFactory(static::class); return $state->getFixtureFactory(static::class);
@ -486,11 +486,11 @@ if (class_exists(IsEqualCanonicalizing::class)) {
* Sets a new fixture factory * Sets a new fixture factory
* @param FixtureFactory $factory * @param FixtureFactory $factory
* @return $this * @return $this
* @deprecated 4.0.0:5.0.0 * @deprecated 4.0.1 Use FixtureTestState instead
*/ */
public function setFixtureFactory(FixtureFactory $factory) public function setFixtureFactory(FixtureFactory $factory)
{ {
Deprecation::notice('5.0', __FUNCTION__ . ' is deprecated, use ' . FixtureTestState::class . ' instead'); Deprecation::notice('4.0.1', 'Use FixtureTestState instead');
/** @var FixtureTestState $state */ /** @var FixtureTestState $state */
$state = static::$state->getStateByName('fixtures'); $state = static::$state->getStateByName('fixtures');
$state->setFixtureFactory($factory, static::class); $state->setFixtureFactory($factory, static::class);
@ -566,12 +566,11 @@ if (class_exists(IsEqualCanonicalizing::class)) {
* Once loaded, you can use idFromFixture() and objFromFixture() to get items from the fixture. * Once loaded, you can use idFromFixture() and objFromFixture() to get items from the fixture.
* Doesn't clear existing fixtures. * Doesn't clear existing fixtures.
* @param string $fixtureFile The location of the .yml fixture file, relative to the site base dir * @param string $fixtureFile The location of the .yml fixture file, relative to the site base dir
* @deprecated 4.0.0:5.0.0 * @deprecated 4.0.1 Use FixtureTestState instead
*
*/ */
public function loadFixture($fixtureFile) public function loadFixture($fixtureFile)
{ {
Deprecation::notice('5.0', __FUNCTION__ . ' is deprecated, use ' . FixtureTestState::class . ' instead'); Deprecation::notice('4.0.1', 'Use FixtureTestState instead');
$fixture = Injector::inst()->create(YamlFixture::class, $fixtureFile); $fixture = Injector::inst()->create(YamlFixture::class, $fixtureFile);
$fixture->writeInto($this->getFixtureFactory()); $fixture->writeInto($this->getFixtureFactory());
} }
@ -762,12 +761,12 @@ if (class_exists(IsEqualCanonicalizing::class)) {
/** /**
* @param $matches * @param $matches
* @param $dataObjectSet * @param $dataObjectSet
* @deprecated 4.0.0:5.0.0 Use assertListContains() instead * @deprecated 4.0.1 Use assertListContains() instead
* *
*/ */
public function assertDOSContains($matches, $dataObjectSet) public function assertDOSContains($matches, $dataObjectSet)
{ {
Deprecation::notice('5.0', 'Use assertListContains() instead'); Deprecation::notice('4.0.1', 'Use assertListContains() instead');
static::assertListContains($matches, $dataObjectSet); static::assertListContains($matches, $dataObjectSet);
} }
@ -816,12 +815,12 @@ if (class_exists(IsEqualCanonicalizing::class)) {
/** /**
* @param $matches * @param $matches
* @param $dataObjectSet * @param $dataObjectSet
* @deprecated 4.0.0:5.0.0 Use assertListNotContains() instead * @deprecated 4.0.1 Use assertListNotContains() instead
* *
*/ */
public static function assertNotDOSContains($matches, $dataObjectSet) public static function assertNotDOSContains($matches, $dataObjectSet)
{ {
Deprecation::notice('5.0', 'Use assertListNotContains() instead'); Deprecation::notice('4.0.1', 'Use assertListNotContains() instead');
static::assertListNotContains($matches, $dataObjectSet); static::assertListNotContains($matches, $dataObjectSet);
} }
@ -864,12 +863,12 @@ if (class_exists(IsEqualCanonicalizing::class)) {
/** /**
* @param $matches * @param $matches
* @param SS_List $dataObjectSet * @param SS_List $dataObjectSet
* @deprecated 4.0.0:5.0.0 Use assertListEquals() instead * @deprecated 4.0.1 Use assertListEquals() instead
* *
*/ */
public function assertDOSEquals($matches, $dataObjectSet) public function assertDOSEquals($matches, $dataObjectSet)
{ {
Deprecation::notice('5.0', 'Use assertListEquals() instead'); Deprecation::notice('4.0.1', 'Use assertListEquals() instead');
static::assertListEquals($matches, $dataObjectSet); static::assertListEquals($matches, $dataObjectSet);
} }
@ -908,12 +907,12 @@ if (class_exists(IsEqualCanonicalizing::class)) {
/** /**
* @param $match * @param $match
* @param SS_List $dataObjectSet * @param SS_List $dataObjectSet
* @deprecated 4.0.0:5.0.0 Use assertListAllMatch() instead * @deprecated 4.0.1 Use assertListAllMatch() instead
* *
*/ */
public function assertDOSAllMatch($match, SS_List $dataObjectSet) public function assertDOSAllMatch($match, SS_List $dataObjectSet)
{ {
Deprecation::notice('5.0', 'Use assertListAllMatch() instead'); Deprecation::notice('4.0.1', 'Use assertListAllMatch() instead');
static::assertListAllMatch($match, $dataObjectSet); static::assertListAllMatch($match, $dataObjectSet);
} }
@ -1416,7 +1415,7 @@ class SapphireTest extends PHPUnit_Framework_TestCase implements TestOnly
protected static $fixture_file = null; protected static $fixture_file = null;
/** /**
* @deprecated 4.0..5.0 Use FixtureTestState instead * @deprecated 4.0.1 Use FixtureTestState instead
* @var FixtureFactory * @var FixtureFactory
*/ */
protected $fixtureFactory; protected $fixtureFactory;
@ -1793,11 +1792,11 @@ class SapphireTest extends PHPUnit_Framework_TestCase implements TestOnly
/** /**
* @return FixtureFactory|false * @return FixtureFactory|false
* @deprecated 4.0.0:5.0.0 * @deprecated 4.0.1 Use FixtureTestState instead
*/ */
public function getFixtureFactory() public function getFixtureFactory()
{ {
Deprecation::notice('5.0', __FUNCTION__ . ' is deprecated, use ' . FixtureTestState::class . ' instead'); Deprecation::notice('4.0.1', 'Use FixtureTestState instead');
/** @var FixtureTestState $state */ /** @var FixtureTestState $state */
$state = static::$state->getStateByName('fixtures'); $state = static::$state->getStateByName('fixtures');
return $state->getFixtureFactory(static::class); return $state->getFixtureFactory(static::class);
@ -1807,11 +1806,11 @@ class SapphireTest extends PHPUnit_Framework_TestCase implements TestOnly
* Sets a new fixture factory * Sets a new fixture factory
* @param FixtureFactory $factory * @param FixtureFactory $factory
* @return $this * @return $this
* @deprecated 4.0.0:5.0.0 * @deprecated 4.0.1 Use FixtureTestState instead
*/ */
public function setFixtureFactory(FixtureFactory $factory) public function setFixtureFactory(FixtureFactory $factory)
{ {
Deprecation::notice('5.0', __FUNCTION__ . ' is deprecated, use ' . FixtureTestState::class . ' instead'); Deprecation::notice('4.0.1', 'Use FixtureTestState instead');
/** @var FixtureTestState $state */ /** @var FixtureTestState $state */
$state = static::$state->getStateByName('fixtures'); $state = static::$state->getStateByName('fixtures');
$state->setFixtureFactory($factory, static::class); $state->setFixtureFactory($factory, static::class);
@ -1887,12 +1886,12 @@ class SapphireTest extends PHPUnit_Framework_TestCase implements TestOnly
* Once loaded, you can use idFromFixture() and objFromFixture() to get items from the fixture. * Once loaded, you can use idFromFixture() and objFromFixture() to get items from the fixture.
* Doesn't clear existing fixtures. * Doesn't clear existing fixtures.
* @param string $fixtureFile The location of the .yml fixture file, relative to the site base dir * @param string $fixtureFile The location of the .yml fixture file, relative to the site base dir
* @deprecated 4.0.0:5.0.0 * @deprecated 4.0.1 Use FixtureTestState instead
* *
*/ */
public function loadFixture($fixtureFile) public function loadFixture($fixtureFile)
{ {
Deprecation::notice('5.0', __FUNCTION__ . ' is deprecated, use ' . FixtureTestState::class . ' instead'); Deprecation::notice('4.0.1', 'Use FixtureTestState instead');
$fixture = Injector::inst()->create(YamlFixture::class, $fixtureFile); $fixture = Injector::inst()->create(YamlFixture::class, $fixtureFile);
$fixture->writeInto($this->getFixtureFactory()); $fixture->writeInto($this->getFixtureFactory());
} }
@ -2110,12 +2109,12 @@ class SapphireTest extends PHPUnit_Framework_TestCase implements TestOnly
/** /**
* @param $matches * @param $matches
* @param $dataObjectSet * @param $dataObjectSet
* @deprecated 4.0.0:5.0.0 Use assertListContains() instead * @deprecated 4.0.1 Use assertListContains() instead
* *
*/ */
public function assertDOSContains($matches, $dataObjectSet) public function assertDOSContains($matches, $dataObjectSet)
{ {
Deprecation::notice('5.0', 'Use assertListContains() instead'); Deprecation::notice('4.0.1', 'Use assertListContains() instead');
return static::assertListContains($matches, $dataObjectSet); return static::assertListContains($matches, $dataObjectSet);
} }
@ -2164,12 +2163,12 @@ class SapphireTest extends PHPUnit_Framework_TestCase implements TestOnly
/** /**
* @param $matches * @param $matches
* @param $dataObjectSet * @param $dataObjectSet
* @deprecated 4.0.0:5.0.0 Use assertListNotContains() instead * @deprecated 4.0.1 Use assertListNotContains() instead
* *
*/ */
public static function assertNotDOSContains($matches, $dataObjectSet) public static function assertNotDOSContains($matches, $dataObjectSet)
{ {
Deprecation::notice('5.0', 'Use assertListNotContains() instead'); Deprecation::notice('4.0.1', 'Use assertListNotContains() instead');
return static::assertListNotContains($matches, $dataObjectSet); return static::assertListNotContains($matches, $dataObjectSet);
} }
@ -2212,12 +2211,12 @@ class SapphireTest extends PHPUnit_Framework_TestCase implements TestOnly
/** /**
* @param $matches * @param $matches
* @param SS_List $dataObjectSet * @param SS_List $dataObjectSet
* @deprecated 4.0.0:5.0.0 Use assertListEquals() instead * @deprecated 4.0.1 Use assertListEquals() instead
* *
*/ */
public function assertDOSEquals($matches, $dataObjectSet) public function assertDOSEquals($matches, $dataObjectSet)
{ {
Deprecation::notice('5.0', 'Use assertListEquals() instead'); Deprecation::notice('4.0.1', 'Use assertListEquals() instead');
return static::assertListEquals($matches, $dataObjectSet); return static::assertListEquals($matches, $dataObjectSet);
} }
@ -2255,12 +2254,12 @@ class SapphireTest extends PHPUnit_Framework_TestCase implements TestOnly
/** /**
* @param $match * @param $match
* @param SS_List $dataObjectSet * @param SS_List $dataObjectSet
* @deprecated 4.0.0:5.0.0 Use assertListAllMatch() instead * @deprecated 4.0.1 Use assertListAllMatch() instead
* *
*/ */
public function assertDOSAllMatch($match, SS_List $dataObjectSet) public function assertDOSAllMatch($match, SS_List $dataObjectSet)
{ {
Deprecation::notice('5.0', 'Use assertListAllMatch() instead'); Deprecation::notice('4.0.1', 'Use assertListAllMatch() instead');
return static::assertListAllMatch($match, $dataObjectSet); return static::assertListAllMatch($match, $dataObjectSet);
} }

View File

@ -50,18 +50,22 @@ class TestKernel extends CoreKernel
/** /**
* Set a list of CI configurations that should cause a module's test not to be added to a manifest * Set a list of CI configurations that should cause a module's test not to be added to a manifest
* @param string[] $ciConfigs * @param string[] $ciConfigs
* @deprecated 4.12.0 Will be removed without equivalent functionality
*/ */
public function setIgnoredCIConfigs(array $ciConfigs): self public function setIgnoredCIConfigs(array $ciConfigs): self
{ {
Deprecation::notice('5.0.0', 'This method will be removed in CMS 5'); Deprecation::notice('4.12.0', 'Will be removed without equivalent functionality');
$this->ciConfigs = $ciConfigs; $this->ciConfigs = $ciConfigs;
return $this; return $this;
} }
/**
* @deprecated 4.12.0 Will be removed without equivalent functionality
*/
protected function getIgnoredCIConfigs(): array protected function getIgnoredCIConfigs(): array
{ {
Deprecation::notice('5.0.0', 'This method will be removed in CMS 5'); Deprecation::notice('4.12.0', 'Will be removed without equivalent functionality');
return $this->ciConfigs; return $this->ciConfigs;
} }

View File

@ -180,13 +180,13 @@ class FieldList extends ArrayList
} }
/** /**
* @deprecated 4.1.0:5.0.0 Please use dataFields or saveableFields * @deprecated 4.1.0 Please use dataFields or saveableFields instead
* @param $list * @param $list
* @param bool $saveableOnly * @param bool $saveableOnly
*/ */
protected function collateDataFields(&$list, $saveableOnly = false) protected function collateDataFields(&$list, $saveableOnly = false)
{ {
Deprecation::notice('5.0', 'Please use dataFields or SaveableFields'); Deprecation::notice('4.1.0', 'Please use dataFields or saveableFields instead');
if (!isset($list)) { if (!isset($list)) {
$list = []; $list = [];
} }

View File

@ -1587,12 +1587,12 @@ class Form extends ViewableData implements HasRequestHandler
* and _form_enctype. These are the attributes of the form. These fields * and _form_enctype. These are the attributes of the form. These fields
* can be used to send the form to Ajax. * can be used to send the form to Ajax.
* *
* @deprecated 5.0 * @deprecated 4.12.0 Will be removed without equivalent functionality
* @return string * @return string
*/ */
public function formHtmlContent() public function formHtmlContent()
{ {
Deprecation::notice('5.0'); Deprecation::notice('4.12.0', 'Will be removed without equivalent functionality');
$this->IncludeFormTag = false; $this->IncludeFormTag = false;
$content = $this->forTemplate(); $content = $this->forTemplate();
$this->IncludeFormTag = true; $this->IncludeFormTag = true;

View File

@ -435,13 +435,13 @@ class GridFieldFilterHeader extends AbstractGridFieldComponent implements GridFi
/** /**
* Generate fields for the legacy filter header row * Generate fields for the legacy filter header row
* *
* @deprecated 5.0 * @deprecated 4.12.0 Use search field instead
* @param GridField $gridfield * @param GridField $gridfield
* @return ArrayList|null * @return ArrayList|null
*/ */
public function getLegacyFilterHeader(GridField $gridField) public function getLegacyFilterHeader(GridField $gridField)
{ {
Deprecation::notice('5.0', 'Table row based filter header will be removed in favor of search field in 5.0'); Deprecation::notice('4.12.0', 'Use search field instead');
$list = $gridField->getList(); $list = $gridField->getList();
if (!$this->checkDataType($list)) { if (!$this->checkDataType($list)) {

View File

@ -11,13 +11,13 @@ if (!class_exists(VersionedGridFieldState::class)) {
/** /**
* @deprecated 4.1.0:5.0.0 * @deprecated 4.1.0 Use VersionedGridFieldState instead
*/ */
class GridFieldVersionedState extends VersionedGridFieldState class GridFieldVersionedState extends VersionedGridFieldState
{ {
public function __construct(array $versionedLabelFields = ['Name', 'Title']) public function __construct(array $versionedLabelFields = ['Name', 'Title'])
{ {
Deprecation::notice('4.1.0', 'Use VersionedGridFieldState instead', Deprecation::SCOPE_CLASS);
parent::__construct($versionedLabelFields); parent::__construct($versionedLabelFields);
Deprecation::notice('5.0', 'Use ' . VersionedGridFieldState::class . ' instead');
} }
} }

View File

@ -875,21 +875,21 @@ class TinyMCEConfig extends HTMLEditorConfig implements i18nEntityProvider
} }
/** /**
* @deprecated 4.0.0:5.0.0 * @deprecated 4.0.1 Use getTinyMCEResourcePath() instead
*/ */
public function getTinyMCEPath() public function getTinyMCEPath()
{ {
Deprecation::notice('5.0', 'use getTinyMCEResourcePath instead'); Deprecation::notice('4.0.1', 'Use getTinyMCEResourcePath() instead');
return $this->getTinyMCEResourcePath(); return $this->getTinyMCEResourcePath();
} }
/** /**
* @return Module * @return Module
* @deprecated 4.0.0:5.0.0 * @deprecated 4.0.1 Set base_dir or editor_css config instead
*/ */
protected function getAdminModule() protected function getAdminModule()
{ {
Deprecation::notice('5.0', 'Set base_dir or editor_css config instead'); Deprecation::notice('4.0.1', 'Set base_dir or editor_css config instead');
return ModuleLoader::getModule('silverstripe/admin'); return ModuleLoader::getModule('silverstripe/admin');
} }

View File

@ -11,7 +11,7 @@ use TinyMCE_Compressor;
/** /**
* Uses the default tiny_mc_gzip.php handler * Uses the default tiny_mc_gzip.php handler
* *
* @deprecated 4.0.0:5.0.0 * @deprecated 4.0.1 Will be removed without equivalent functionality
*/ */
class TinyMCEGZIPGenerator implements TinyMCEScriptGenerator class TinyMCEGZIPGenerator implements TinyMCEScriptGenerator
{ {
@ -19,7 +19,7 @@ class TinyMCEGZIPGenerator implements TinyMCEScriptGenerator
public function __construct() public function __construct()
{ {
Deprecation::notice('5.0', 'Legacy tiny_mce_gzip compressor is deprecated'); Deprecation::notice('4.0.1', 'Will be removed without equivalent functionality', Deprecation::SCOPE_CLASS);
} }
/** /**

View File

@ -121,10 +121,11 @@ class TextField extends FormField implements TippableFieldInterface
/** /**
* @return string * @return string
* @deprecated 4.0.1 Use setValue() instead
*/ */
public function InternallyLabelledField() public function InternallyLabelledField()
{ {
Deprecation::notice('4.0', 'Please use ->setValue() instead'); Deprecation::notice('4.0.1', 'Use setValue() instead');
if (!$this->value) { if (!$this->value) {
$this->value = $this->Title(); $this->value = $this->Title();

View File

@ -2,6 +2,7 @@
namespace SilverStripe\Forms; namespace SilverStripe\Forms;
use SilverStripe\Dev\Deprecation;
use Exception; use Exception;
use InvalidArgumentException; use InvalidArgumentException;
use SilverStripe\Assets\Folder; use SilverStripe\Assets\Folder;
@ -621,12 +622,13 @@ class TreeDropdownField extends FormField
/** /**
* HTML-encoded label for this node, including css classes and other markup. * HTML-encoded label for this node, including css classes and other markup.
* *
* @deprecated 4.0.0:5.0.0 Use setTitleField() * @deprecated 4.0.1 Use setTitleField() instead
* @param string $field * @param string $field
* @return $this * @return $this
*/ */
public function setLabelField($field) public function setLabelField($field)
{ {
Deprecation::notice('4.0.1', 'Use setTitleField() instead');
$this->labelField = $field; $this->labelField = $field;
return $this; return $this;
} }
@ -634,11 +636,12 @@ class TreeDropdownField extends FormField
/** /**
* HTML-encoded label for this node, including css classes and other markup. * HTML-encoded label for this node, including css classes and other markup.
* *
* @deprecated 4.0.0:5.0.0 Use getTitleField() * @deprecated 4.0.1 Use getTitleField() instead
* @return string * @return string
*/ */
public function getLabelField() public function getLabelField()
{ {
Deprecation::notice('4.0.1', 'Use getTitleField() instead');
return $this->labelField; return $this->labelField;
} }

View File

@ -18,13 +18,13 @@ class MonologErrorHandler implements ErrorHandler
* Set the PSR-3 logger to send errors & exceptions to. Will overwrite any previously configured * Set the PSR-3 logger to send errors & exceptions to. Will overwrite any previously configured
* loggers * loggers
* *
* @deprecated 4.4.0:5.0.0 Use pushLogger() instead * @deprecated 4.4.0 Use pushLogger() instead
* @param LoggerInterface $logger * @param LoggerInterface $logger
* @return $this * @return $this
*/ */
public function setLogger(LoggerInterface $logger) public function setLogger(LoggerInterface $logger)
{ {
Deprecation::notice('4.4.0', 'Please use pushLogger() instead'); Deprecation::notice('4.4.0', 'Use pushLogger() instead');
$this->loggers = [$logger]; $this->loggers = [$logger];
return $this; return $this;
@ -33,12 +33,12 @@ class MonologErrorHandler implements ErrorHandler
/** /**
* Get the first registered PSR-3 logger to send errors & exceptions to * Get the first registered PSR-3 logger to send errors & exceptions to
* *
* @deprecated 4.4.0:5.0.0 Use getLoggers() instead * @deprecated 4.4.0 Use getLoggers() instead
* @return LoggerInterface * @return LoggerInterface
*/ */
public function getLogger() public function getLogger()
{ {
Deprecation::notice('4.4.0', 'Please use getLoggers() instead'); Deprecation::notice('4.4.0', 'Use getLoggers() instead');
return reset($this->loggers); return reset($this->loggers);
} }

View File

@ -2,6 +2,7 @@
namespace SilverStripe\ORM\Connect; namespace SilverStripe\ORM\Connect;
use SilverStripe\Dev\Deprecation;
use Exception; use Exception;
use SilverStripe\Control\Director; use SilverStripe\Control\Director;
use SilverStripe\Core\Config\Config; use SilverStripe\Core\Config\Config;
@ -60,10 +61,11 @@ abstract class DBSchemaManager
* @param string $table * @param string $table
* @param string $class * @param string $class
* *
* @deprecated 4.0.0:5.0.0 * @deprecated 4.0.1 Will be removed without equivalent functionality
*/ */
public static function showTableNameWarning($table, $class) public static function showTableNameWarning($table, $class)
{ {
Deprecation::notice('4.0.1', 'Will be removed without equivalent functionality');
static::$table_name_warnings[$table] = $class; static::$table_name_warnings[$table] = $class;
} }

View File

@ -140,10 +140,12 @@ class PDOConnector extends DBConnector implements TransactionManager
return self::config()->get('emulate_prepare'); return self::config()->get('emulate_prepare');
} }
/**
* @deprecated 4.5.0 Use native database drivers instead
*/
public function connect($parameters, $selectDB = false) public function connect($parameters, $selectDB = false)
{ {
Deprecation::notice('4.5', 'Use native database drivers in favour of PDO. ' Deprecation::notice('4.5.0', 'Use native database drivers instead');
. 'https://github.com/silverstripe/silverstripe-framework/issues/8598');
$this->flushStatements(); $this->flushStatements();

View File

@ -112,12 +112,12 @@ class DB
} }
/** /**
* @deprecated since version 4.0 Use DB::get_conn instead * @deprecated 4.0.1 Use DB::get_conn() instead
* @todo PSR-2 standardisation will probably un-deprecate this * @todo PSR-2 standardisation will probably un-deprecate this
*/ */
public static function getConn($name = 'default') public static function getConn($name = 'default')
{ {
Deprecation::notice('4.0', 'Use DB::get_conn instead'); Deprecation::notice('4.0.1', 'Use DB::get_conn() instead');
return self::get_conn($name); return self::get_conn($name);
} }

View File

@ -2,6 +2,7 @@
namespace SilverStripe\ORM; namespace SilverStripe\ORM;
use SilverStripe\Dev\Deprecation;
use SilverStripe\Core\Config\Config; use SilverStripe\Core\Config\Config;
use SilverStripe\Core\Extension; use SilverStripe\Core\Extension;
use SilverStripe\Forms\FieldList; use SilverStripe\Forms\FieldList;
@ -19,10 +20,11 @@ abstract class DataExtension extends Extension
{ {
/** /**
* @deprecated 4.7.0 No longer used by internal code * @deprecated 4.7.0 Will be removed without equivalent functionality
*/ */
public static function unload_extra_statics($class, $extension) public static function unload_extra_statics($class, $extension)
{ {
Deprecation::notice('4.7.0', 'Will be removed without equivalent functionality');
throw new Exception('unload_extra_statics gone'); throw new Exception('unload_extra_statics gone');
} }

View File

@ -600,14 +600,14 @@ class DataObject extends ViewableData implements DataObjectInterface, i18nEntity
/** /**
* Copies the many_many and belongs_many_many relations from one object to another instance of the name of object. * Copies the many_many and belongs_many_many relations from one object to another instance of the name of object.
* *
* @deprecated 4.1.0:5.0.0 Use duplicateRelations() instead * @deprecated 4.1.0 Use duplicateRelations() instead
* @param DataObject $sourceObject the source object to duplicate from * @param DataObject $sourceObject the source object to duplicate from
* @param DataObject $destinationObject the destination object to populate with the duplicated relations * @param DataObject $destinationObject the destination object to populate with the duplicated relations
* @param bool|string $filter * @param bool|string $filter
*/ */
protected function duplicateManyManyRelations($sourceObject, $destinationObject, $filter) protected function duplicateManyManyRelations($sourceObject, $destinationObject, $filter)
{ {
Deprecation::notice('5.0', 'Use duplicateRelations() instead'); Deprecation::notice('4.1.0', 'Use duplicateRelations() instead');
// Get list of relations to duplicate // Get list of relations to duplicate
if ($filter === 'many_many' || $filter === 'belongs_many_many') { if ($filter === 'many_many' || $filter === 'belongs_many_many') {
@ -1266,10 +1266,11 @@ class DataObject extends ViewableData implements DataObjectInterface, i18nEntity
* Public accessor for {@see DataObject::validate()} * Public accessor for {@see DataObject::validate()}
* *
* @return ValidationResult * @return ValidationResult
* @deprecated 4.12.0 Use validate() instead
*/ */
public function doValidate() public function doValidate()
{ {
Deprecation::notice('5.0', 'Use validate'); Deprecation::notice('4.12.0', 'Use validate() instead');
return $this->validate(); return $this->validate();
} }

View File

@ -376,11 +376,11 @@ class DatabaseAdmin extends Controller
* @param string $fieldName The field name to look in for obsolete class names * @param string $fieldName The field name to look in for obsolete class names
* @param string $oldClassName The old class name * @param string $oldClassName The old class name
* @param string $newClassName The new class name * @param string $newClassName The new class name
* @deprecated 5.0 use updateLegacyClassNameField instead * @deprecated 4.12.0 Use updateLegacyClassNameField() instead
*/ */
protected function updateLegacyClassNames($dataClass, $fieldName, $oldClassName, $newClassName) protected function updateLegacyClassNames($dataClass, $fieldName, $oldClassName, $newClassName)
{ {
Deprecation::notice('5.0', 'use updateLegacyClassNameField instead'); Deprecation::notice('4.12.0', 'Use updateLegacyClassNameField() instead');
$this->updateLegacyClassNameField($dataClass, $fieldName, [$oldClassName => $newClassName]); $this->updateLegacyClassNameField($dataClass, $fieldName, [$oldClassName => $newClassName]);
} }

View File

@ -35,10 +35,11 @@ class DBClassName extends DBEnum
/** /**
* Clear all cached classname specs. It's necessary to clear all cached subclassed names * Clear all cached classname specs. It's necessary to clear all cached subclassed names
* for any classes if a new class manifest is generated. * for any classes if a new class manifest is generated.
* @deprecated 4.3.0 Use DBEnum::flushCache() instead
*/ */
public static function clear_classname_cache() public static function clear_classname_cache()
{ {
Deprecation::notice('4.3', 'Call DBEnum::flushCache() instead'); Deprecation::notice('4.3.0', 'Use DBEnum::flushCache() instead');
DBEnum::flushCache(); DBEnum::flushCache();
} }

View File

@ -232,10 +232,11 @@ class ValidationResult implements Serializable
* The __serialize() magic method will be automatically used instead of this * The __serialize() magic method will be automatically used instead of this
* *
* @return string * @return string
* @deprecated will be removed in 5.0 * @deprecated 4.12.0 Use __serialize() instead
*/ */
public function serialize() public function serialize()
{ {
Deprecation::notice('4.12.0', 'Use __serialize() instead');
return json_encode([$this->messages, $this->isValid]); return json_encode([$this->messages, $this->isValid]);
} }
@ -245,10 +246,11 @@ class ValidationResult implements Serializable
* and the PHP version used in less than PHP 9.0 * and the PHP version used in less than PHP 9.0
* *
* @param string $serialized * @param string $serialized
* @deprecated will be removed in 5.0 * @deprecated 4.12.0 Use __unserialize() instead
*/ */
public function unserialize($serialized) public function unserialize($serialized)
{ {
Deprecation::notice('4.12.0', 'Use __unserialize() instead');
list($this->messages, $this->isValid) = json_decode($serialized ?? '', true); list($this->messages, $this->isValid) = json_decode($serialized ?? '', true);
} }
} }

View File

@ -720,8 +720,6 @@ class Group extends DataObject
/** /**
* Code needs to be unique as it is used to identify a specific group. Ensure no duplicate * Code needs to be unique as it is used to identify a specific group. Ensure no duplicate
* codes are created. * codes are created.
*
* @deprecated 5.0 Remove deduping in favour of throwing a validation error for duplicates.
*/ */
private function dedupeCode(): void private function dedupeCode(): void
{ {

View File

@ -282,26 +282,26 @@ class Member extends DataObject
/** /**
* Get the default admin record if it exists, or creates it otherwise if enabled * Get the default admin record if it exists, or creates it otherwise if enabled
* *
* @deprecated 4.0.0:5.0.0 Use DefaultAdminService::findOrCreateDefaultAdmin() instead * @deprecated 4.0.1 Use DefaultAdminService::findOrCreateDefaultAdmin() instead
* @return Member * @return Member
*/ */
public static function default_admin() public static function default_admin()
{ {
Deprecation::notice('5.0', 'Use DefaultAdminService::findOrCreateDefaultAdmin() instead'); Deprecation::notice('4.0.1', 'Use DefaultAdminService::findOrCreateDefaultAdmin() instead');
return DefaultAdminService::singleton()->findOrCreateDefaultAdmin(); return DefaultAdminService::singleton()->findOrCreateDefaultAdmin();
} }
/** /**
* Check if the passed password matches the stored one (if the member is not locked out). * Check if the passed password matches the stored one (if the member is not locked out).
* *
* @deprecated 4.0.0:5.0.0 Use Authenticator::checkPassword() instead * @deprecated 4.0.1 Use Authenticator::checkPassword() instead
* *
* @param string $password * @param string $password
* @return ValidationResult * @return ValidationResult
*/ */
public function checkPassword($password) public function checkPassword($password)
{ {
Deprecation::notice('5.0', 'Use Authenticator::checkPassword() instead'); Deprecation::notice('4.0.1', 'Use Authenticator::checkPassword() instead');
// With a valid user and password, check the password is correct // With a valid user and password, check the password is correct
$result = ValidationResult::create(); $result = ValidationResult::create();
@ -448,15 +448,12 @@ class Member extends DataObject
} }
/** /**
* @deprecated 5.0.0 Use Security::setCurrentUser() or IdentityStore::logIn() * @deprecated 4.12.0 Use Security::setCurrentUser() or IdentityStore::logIn() instead
* *
*/ */
public function logIn() public function logIn()
{ {
Deprecation::notice( Deprecation::notice('4.12.0', 'Use Security::setCurrentUser() or IdentityStore::logIn() instead');
'5.0.0',
'This method is deprecated and only logs in for the current request. Please use Security::setCurrentUser($user) or an IdentityStore'
);
Security::setCurrentUser($this); Security::setCurrentUser($this);
} }
@ -509,16 +506,13 @@ class Member extends DataObject
* has a database record of the same ID. If there is * has a database record of the same ID. If there is
* no logged in user, FALSE is returned anyway. * no logged in user, FALSE is returned anyway.
* *
* @deprecated Not needed anymore, as it returns Security::getCurrentUser(); * @deprecated 4.12.0 Use Security::getCurrentUser() instead
* *
* @return boolean TRUE record found FALSE no record found * @return boolean TRUE record found FALSE no record found
*/ */
public static function logged_in_session_exists() public static function logged_in_session_exists()
{ {
Deprecation::notice( Deprecation::notice('4.12.0', 'Use Security::getCurrentUser() instead');
'5.0.0',
'This method is deprecated and now does not add value. Please use Security::getCurrentUser()'
);
$member = Security::getCurrentUser(); $member = Security::getCurrentUser();
if ($member && $member->exists()) { if ($member && $member->exists()) {
@ -529,15 +523,13 @@ class Member extends DataObject
} }
/** /**
* @deprecated Use Security::setCurrentUser(null) or an IdentityStore
* Logs this member out. * Logs this member out.
*
* @deprecated 4.12.0 Use Security::setCurrentUser(null) or an IdentityStore instead
*/ */
public function logOut() public function logOut()
{ {
Deprecation::notice( Deprecation::notice('4.12.0', 'Use Security::setCurrentUser(null) or an IdentityStore instead');
'5.0.0',
'This method is deprecated and now does not persist. Please use Security::setCurrentUser(null) or an IdentityStore'
);
Injector::inst()->get(IdentityStore::class)->logOut(Controller::curr()->getRequest()); Injector::inst()->get(IdentityStore::class)->logOut(Controller::curr()->getRequest());
} }
@ -769,16 +761,13 @@ class Member extends DataObject
/** /**
* Returns the current logged in user * Returns the current logged in user
* *
* @deprecated 5.0.0 use Security::getCurrentUser() * @deprecated 4.12.0 Use Security::getCurrentUser() instead
* *
* @return Member * @return Member
*/ */
public static function currentUser() public static function currentUser()
{ {
Deprecation::notice( Deprecation::notice('4.12.0', 'Use Security::getCurrentUser() instead');
'5.0.0',
'This method is deprecated. Please use Security::getCurrentUser() or an IdentityStore'
);
return Security::getCurrentUser(); return Security::getCurrentUser();
} }
@ -819,16 +808,13 @@ class Member extends DataObject
/** /**
* Get the ID of the current logged in user * Get the ID of the current logged in user
* *
* @deprecated 5.0.0 use Security::getCurrentUser() * @deprecated 4.12.0 Use Security::getCurrentUser() instead
* *
* @return int Returns the ID of the current logged in user or 0. * @return int Returns the ID of the current logged in user or 0.
*/ */
public static function currentUserID() public static function currentUserID()
{ {
Deprecation::notice( Deprecation::notice('4.12.0', 'Use Security::getCurrentUser() instead');
'5.0.0',
'This method is deprecated. Please use Security::getCurrentUser() or an IdentityStore'
);
$member = Security::getCurrentUser(); $member = Security::getCurrentUser();
if ($member) { if ($member) {
@ -1117,10 +1103,11 @@ class Member extends DataObject
/** /**
* @param array $columns Column names on the Member record to show in {@link getTitle()}. * @param array $columns Column names on the Member record to show in {@link getTitle()}.
* @param string $sep Separator * @param string $sep Separator
* @deprecated 4.12.0 Use Member.title_format config instead
*/ */
public static function set_title_columns($columns, $sep = ' ') public static function set_title_columns($columns, $sep = ' ')
{ {
Deprecation::notice('5.0', 'Use Member.title_format config instead'); Deprecation::notice('4.12.0', 'Use Member.title_format config instead');
if (!is_array($columns)) { if (!is_array($columns)) {
$columns = [$columns]; $columns = [$columns];
} }

View File

@ -76,20 +76,19 @@ class PasswordValidator
protected $historicalPasswordCount = null; protected $historicalPasswordCount = null;
/** /**
* @deprecated 4.5.0
* Minimum password length * Minimum password length
* *
* @param int $minLength * @param int $minLength
* @return $this * @return $this
* @deprecated 4.5.0 Use setMinLength() instead
*/ */
public function minLength($minLength) public function minLength($minLength)
{ {
Deprecation::notice('4.5.0', 'Use ->setMinLength($value) instead.'); Deprecation::notice('4.5.0', 'Use setMinLength() instead');
return $this->setMinLength($minLength); return $this->setMinLength($minLength);
} }
/** /**
* @deprecated 4.5.0
* Check the character strength of the password. * Check the character strength of the password.
* *
* Eg: $this->characterStrength(3, array("lowercase", "uppercase", "digits", "punctuation")) * Eg: $this->characterStrength(3, array("lowercase", "uppercase", "digits", "punctuation"))
@ -97,13 +96,11 @@ class PasswordValidator
* @param int $minScore The minimum number of character tests that must pass * @param int $minScore The minimum number of character tests that must pass
* @param string[] $testNames The names of the tests to perform * @param string[] $testNames The names of the tests to perform
* @return $this * @return $this
* @deprecated 4.5.0 Use setMinTestScore($score) and setTestNames($names) instead
*/ */
public function characterStrength($minScore, $testNames = null) public function characterStrength($minScore, $testNames = null)
{ {
Deprecation::notice( Deprecation::notice('4.5.0', 'Use setMinTestScore($score) and setTestNames($names) instead');
'4.5.0',
'Use ->setMinTestScore($score) and ->setTestNames($names) instead.'
);
$this->setMinTestScore($minScore); $this->setMinTestScore($minScore);
if ($testNames) { if ($testNames) {
$this->setTestNames($testNames); $this->setTestNames($testNames);
@ -112,15 +109,15 @@ class PasswordValidator
} }
/** /**
* @deprecated 4.5.0
* Check a number of previous passwords that the user has used, and don't let them change to that. * Check a number of previous passwords that the user has used, and don't let them change to that.
* *
* @param int $count * @param int $count
* @return $this * @return $this
* @deprecated 4.5.0 Use setHistoricCount($value) instead
*/ */
public function checkHistoricalPasswords($count) public function checkHistoricalPasswords($count)
{ {
Deprecation::notice('4.5.0', 'Use ->setHistoricCount($value) instead.'); Deprecation::notice('4.5.0', 'Use setHistoricCount($value) instead');
return $this->setHistoricCount($count); return $this->setHistoricCount($count);
} }

View File

@ -2,6 +2,7 @@
namespace SilverStripe\Security; namespace SilverStripe\Security;
use SilverStripe\Dev\Deprecation;
use SilverStripe\Core\ClassInfo; use SilverStripe\Core\ClassInfo;
use SilverStripe\Core\Resettable; use SilverStripe\Core\Resettable;
use SilverStripe\Dev\TestOnly; use SilverStripe\Dev\TestOnly;
@ -660,10 +661,11 @@ class Permission extends DataObject implements TemplateGlobalProvider, Resettabl
* Get a linear list of the permissions in the system. * Get a linear list of the permissions in the system.
* *
* @return array Linear list of declared permissions in the system. * @return array Linear list of declared permissions in the system.
* @deprecated 4.4.0 * @deprecated 4.4.0 Will be removed without equivalent functionality
*/ */
public static function get_declared_permissions_list() public static function get_declared_permissions_list()
{ {
Deprecation::notice('4.4.0', 'Will be removed without equivalent functionality');
if (!self::$declared_permissions) { if (!self::$declared_permissions) {
return null; return null;
} }
@ -684,10 +686,11 @@ class Permission extends DataObject implements TemplateGlobalProvider, Resettabl
* *
* @param string $perm Permission code * @param string $perm Permission code
* @return string Label for the given permission, or the permission itself if the label doesn't exist * @return string Label for the given permission, or the permission itself if the label doesn't exist
* @deprecated 4.4.0 * @deprecated 4.4.0 Will be removed without equivalent functionality
*/ */
public static function get_label_for_permission($perm) public static function get_label_for_permission($perm)
{ {
Deprecation::notice('4.4.0', 'Will be removed without equivalent functionality');
$list = self::get_declared_permissions_list(); $list = self::get_declared_permissions_list();
if (array_key_exists($perm, $list ?? [])) { if (array_key_exists($perm, $list ?? [])) {
return $list[$perm]; return $list[$perm];
@ -702,10 +705,11 @@ class Permission extends DataObject implements TemplateGlobalProvider, Resettabl
* @param array $declared Nested structure of permissions. * @param array $declared Nested structure of permissions.
* @param array $list List of permissions in the structure. The result will be * @param array $list List of permissions in the structure. The result will be
* written to this array. * written to this array.
* @deprecated 4.4.0 * @deprecated 4.4.0 Will be removed without equivalent functionality
*/ */
protected static function traverse_declared_permissions($declared, &$list) protected static function traverse_declared_permissions($declared, &$list)
{ {
Deprecation::notice('4.4.0', 'Will be removed without equivalent functionality');
if (!is_array($declared)) { if (!is_array($declared)) {
return; return;
} }

View File

@ -14,11 +14,11 @@ class RandomGenerator
/** /**
* @return string A 128-character, randomly generated ASCII string * @return string A 128-character, randomly generated ASCII string
* @throws Exception If no suitable CSPRNG is installed * @throws Exception If no suitable CSPRNG is installed
* @deprecated 4.4.0:5.0.0 * @deprecated 4.4.0 Use native php function random_bytes() instead
*/ */
public function generateEntropy() public function generateEntropy()
{ {
Deprecation::notice('4.4', __METHOD__ . ' has been deprecated. Use random_bytes instead'); Deprecation::notice('4.4.0', 'Use native php function random_bytes() instead');
try { try {
return bin2hex(random_bytes(64)); return bin2hex(random_bytes(64));

View File

@ -464,7 +464,7 @@ class Security extends Controller implements TemplateGlobalProvider
/** /**
* Get the login forms for all available authentication methods * Get the login forms for all available authentication methods
* *
* @deprecated 5.0.0 Now handled by {@link static::delegateToMultipleHandlers} * @deprecated 4.12.0 Use delegateToMultipleHandlers() instead
* *
* @return array Returns an array of available login forms (array of Form * @return array Returns an array of available login forms (array of Form
* objects). * objects).
@ -472,7 +472,7 @@ class Security extends Controller implements TemplateGlobalProvider
*/ */
public function getLoginForms() public function getLoginForms()
{ {
Deprecation::notice('5.0.0', 'Now handled by delegateToMultipleHandlers'); Deprecation::notice('4.12.0', 'Use delegateToMultipleHandlers() instead');
return array_map( return array_map(
function (Authenticator $authenticator) { function (Authenticator $authenticator) {
@ -1073,11 +1073,11 @@ class Security extends Controller implements TemplateGlobalProvider
* *
* @return Member * @return Member
* *
* @deprecated 4.0.0:5.0.0 Please use DefaultAdminService::findOrCreateDefaultAdmin() * @deprecated 4.0.1 Use DefaultAdminService::findOrCreateDefaultAdmin()
*/ */
public static function findAnAdministrator() public static function findAnAdministrator()
{ {
Deprecation::notice('5.0.0', 'Please use DefaultAdminService::findOrCreateDefaultAdmin()'); Deprecation::notice('4.0.1', 'Use DefaultAdminService::findOrCreateDefaultAdmin()');
$service = DefaultAdminService::singleton(); $service = DefaultAdminService::singleton();
return $service->findOrCreateDefaultAdmin(); return $service->findOrCreateDefaultAdmin();
@ -1086,11 +1086,11 @@ class Security extends Controller implements TemplateGlobalProvider
/** /**
* Flush the default admin credentials * Flush the default admin credentials
* *
* @deprecated 4.0.0:5.0.0 Please use DefaultAdminService::clearDefaultAdmin() * @deprecated 4.0.1 Use DefaultAdminService::clearDefaultAdmin()
*/ */
public static function clear_default_admin() public static function clear_default_admin()
{ {
Deprecation::notice('5.0.0', 'Please use DefaultAdminService::clearDefaultAdmin()'); Deprecation::notice('4.0.1', 'Use DefaultAdminService::clearDefaultAdmin()');
DefaultAdminService::clearDefaultAdmin(); DefaultAdminService::clearDefaultAdmin();
} }
@ -1107,11 +1107,11 @@ class Security extends Controller implements TemplateGlobalProvider
* @param string $password The password (in cleartext) * @param string $password The password (in cleartext)
* @return bool True if successfully set * @return bool True if successfully set
* *
* @deprecated 4.0.0:5.0.0 Please use DefaultAdminService::setDefaultAdmin($username, $password) * @deprecated 4.0.1 Use DefaultAdminService::setDefaultAdmin($username, $password)
*/ */
public static function setDefaultAdmin($username, $password) public static function setDefaultAdmin($username, $password)
{ {
Deprecation::notice('5.0.0', 'Please use DefaultAdminService::setDefaultAdmin($username, $password)'); Deprecation::notice('4.0.1', 'Use DefaultAdminService::setDefaultAdmin($username, $password)');
DefaultAdminService::setDefaultAdmin($username, $password); DefaultAdminService::setDefaultAdmin($username, $password);
return true; return true;
@ -1125,11 +1125,11 @@ class Security extends Controller implements TemplateGlobalProvider
* @param string $password * @param string $password
* @return bool * @return bool
* *
* @deprecated 4.0.0:5.0.0 Use DefaultAdminService::isDefaultAdminCredentials() instead * @deprecated 4.0.1 Use DefaultAdminService::isDefaultAdminCredentials() instead
*/ */
public static function check_default_admin($username, $password) public static function check_default_admin($username, $password)
{ {
Deprecation::notice('5.0.0', 'Please use DefaultAdminService::isDefaultAdminCredentials($username, $password)'); Deprecation::notice('4.0.1', 'Use DefaultAdminService::isDefaultAdminCredentials() instead');
/** @var DefaultAdminService $service */ /** @var DefaultAdminService $service */
return DefaultAdminService::isDefaultAdminCredentials($username, $password); return DefaultAdminService::isDefaultAdminCredentials($username, $password);
@ -1138,11 +1138,11 @@ class Security extends Controller implements TemplateGlobalProvider
/** /**
* Check that the default admin account has been set. * Check that the default admin account has been set.
* *
* @deprecated 4.0.0:5.0.0 Use DefaultAdminService::hasDefaultAdmin() instead * @deprecated 4.0.1 Use DefaultAdminService::hasDefaultAdmin() instead
*/ */
public static function has_default_admin() public static function has_default_admin()
{ {
Deprecation::notice('5.0.0', 'Please use DefaultAdminService::hasDefaultAdmin()'); Deprecation::notice('4.0.1', 'Use DefaultAdminService::hasDefaultAdmin() instead');
return DefaultAdminService::hasDefaultAdmin(); return DefaultAdminService::hasDefaultAdmin();
} }
@ -1150,12 +1150,12 @@ class Security extends Controller implements TemplateGlobalProvider
/** /**
* Get default admin username * Get default admin username
* *
* @deprecated 4.0.0:5.0.0 Use DefaultAdminService::getDefaultAdminUsername() * @deprecated 4.0.1 Use DefaultAdminService::getDefaultAdminUsername() instead
* @return string * @return string
*/ */
public static function default_admin_username() public static function default_admin_username()
{ {
Deprecation::notice('5.0.0', 'Please use DefaultAdminService::getDefaultAdminUsername()'); Deprecation::notice('4.0.1', 'Use DefaultAdminService::getDefaultAdminUsername() instead');
return DefaultAdminService::getDefaultAdminUsername(); return DefaultAdminService::getDefaultAdminUsername();
} }
@ -1163,12 +1163,12 @@ class Security extends Controller implements TemplateGlobalProvider
/** /**
* Get default admin password * Get default admin password
* *
* @deprecated 4.0.0:5.0.0 Use DefaultAdminService::getDefaultAdminPassword() * @deprecated 4.0.1 Use DefaultAdminService::getDefaultAdminPassword() instead
* @return string * @return string
*/ */
public static function default_admin_password() public static function default_admin_password()
{ {
Deprecation::notice('5.0.0', 'Please use DefaultAdminService::getDefaultAdminPassword()'); Deprecation::notice('4.0.1', 'Use DefaultAdminService::getDefaultAdminPassword() instead');
return DefaultAdminService::getDefaultAdminPassword(); return DefaultAdminService::getDefaultAdminPassword();
} }

View File

@ -15,7 +15,7 @@ use SilverStripe\Dev\Deprecation;
* Encapsulation of an embed tag, linking to an external media source. * Encapsulation of an embed tag, linking to an external media source.
* *
* @see Embed * @see Embed
* @deprecated 4.11..5.0 Use EmbedContainer instead * @deprecated 4.11.0 Use EmbedContainer instead
*/ */
class EmbedResource implements Embeddable class EmbedResource implements Embeddable
{ {
@ -46,7 +46,7 @@ class EmbedResource implements Embeddable
*/ */
public function __construct($url) public function __construct($url)
{ {
Deprecation::notice('4.11', 'Use EmbedContainer instead'); Deprecation::notice('4.11.0', 'Use EmbedContainer instead', Deprecation::SCOPE_CLASS);
$this->url = $url; $this->url = $url;
} }

View File

@ -238,11 +238,12 @@ class Requirements_Backend
/** /**
* Gets the minification service for this backend * Gets the minification service for this backend
* *
* @deprecated 4.0.0:5.0.0
* @return Requirements_Minifier * @return Requirements_Minifier
* @deprecated 4.0.1 Will be removed without equivalent functionality
*/ */
public function getMinifier() public function getMinifier()
{ {
Deprecation::notice('4.0.1', 'Will be removed without equivalent functionality');
return $this->minifier; return $this->minifier;
} }

View File

@ -296,12 +296,12 @@ class SSViewer implements Flushable
} }
/** /**
* @deprecated 4.0.0:5.0.0 Use the "SSViewer#set_themes" instead
* @param string $theme The "base theme" name (without underscores). * @param string $theme The "base theme" name (without underscores).
* @deprecated 4.0.1 Use SSViewer::set_themes() instead
*/ */
public static function set_theme($theme) public static function set_theme($theme)
{ {
Deprecation::notice('4.0', 'Use the "SSViewer#set_themes" instead'); Deprecation::notice('4.0.1', 'Use SSViewer::set_themes() instead');
self::set_themes([$theme, self::DEFAULT_THEME]); self::set_themes([$theme, self::DEFAULT_THEME]);
} }

View File

@ -67,12 +67,12 @@ class SSViewer_BasicIteratorSupport implements TemplateIteratorProvider
} }
/** /**
* @deprecated 5.0.0 Use IsFirst() to avoid clashes with SS_Lists * @deprecated 4.12.0 Use IsFirst() instead
* @return bool * @return bool
*/ */
public function First() public function First()
{ {
Deprecation::notice('5.0.0', 'Use IsFirst() to avoid clashes with SS_Lists'); Deprecation::notice('4.12.0', 'Use IsFirst() instead');
return $this->IsFirst(); return $this->IsFirst();
} }
@ -87,12 +87,12 @@ class SSViewer_BasicIteratorSupport implements TemplateIteratorProvider
} }
/** /**
* @deprecated 5.0.0 Use IsLast() to avoid clashes with SS_Lists * @deprecated 4.12.0 Use IsLast() instead
* @return bool * @return bool
*/ */
public function Last() public function Last()
{ {
Deprecation::notice('5.0.0', 'Use IsLast() to avoid clashes with SS_Lists'); Deprecation::notice('4.12.0', 'Use IsLast() instead');
return $this->IsLast(); return $this->IsLast();
} }

View File

@ -160,11 +160,11 @@ class EmbedShortcodeProvider implements ShortcodeHandler
* @param Adapter $embed * @param Adapter $embed
* @param array $arguments Additional shortcode params * @param array $arguments Additional shortcode params
* @return string * @return string
* @deprecated 4.11..5.0 Use embeddableToHtml instead * @deprecated 4.11.0 Use embeddableToHtml() instead
*/ */
public static function embedForTemplate($embed, $arguments) public static function embedForTemplate($embed, $arguments)
{ {
Deprecation::notice('4.11', 'Use embeddableToHtml() instead'); Deprecation::notice('4.11.0', 'Use embeddableToHtml() instead');
switch ($embed->getType()) { switch ($embed->getType()) {
case 'video': case 'video':
case 'rich': case 'rich':
@ -257,7 +257,6 @@ class EmbedShortcodeProvider implements ShortcodeHandler
/** /**
* Build a list of HTML attributes from embed arguments - used to preserve backward compatibility * Build a list of HTML attributes from embed arguments - used to preserve backward compatibility
* *
* @deprecated 4.5.0 Use {$Arguments.name} directly in shortcode templates to access argument values
* @param array $arguments List of embed arguments * @param array $arguments List of embed arguments
* @param array $exclude List of attribute names to exclude from the resulting list * @param array $exclude List of attribute names to exclude from the resulting list
* @return ArrayList * @return ArrayList

View File

@ -619,11 +619,11 @@ class ViewableData implements IteratorAggregate
* project directory. * project directory.
* *
* @return string URL to the current theme * @return string URL to the current theme
* @deprecated 4.0.0:5.0.0 Use $resourcePath or $resourceURL template helpers instead * @deprecated 4.0.1 Use ModuleResourceLoader::resourcePath() or ModuleResourceLoader::resourceURL() instead
*/ */
public function ThemeDir() public function ThemeDir()
{ {
Deprecation::notice('5.0', 'Use $resourcePath or $resourceURL template helpers instead'); Deprecation::notice('4.0.1', 'Use ModuleResourceLoader::resourcePath() or ModuleResourceLoader::resourceURL() instead');
$themes = SSViewer::get_themes(); $themes = SSViewer::get_themes();
foreach ($themes as $theme) { foreach ($themes as $theme) {
// Skip theme sets // Skip theme sets

View File

@ -2,6 +2,7 @@
namespace SilverStripe\i18n\Messages\Symfony; namespace SilverStripe\i18n\Messages\Symfony;
use SilverStripe\Dev\Deprecation;
use SilverStripe\Core\Flushable; use SilverStripe\Core\Flushable;
use Symfony\Component\Config\Resource\DirectoryResource; use Symfony\Component\Config\Resource\DirectoryResource;
use Symfony\Component\Config\Resource\SelfCheckingResourceInterface; use Symfony\Component\Config\Resource\SelfCheckingResourceInterface;
@ -54,10 +55,11 @@ class FlushInvalidatedResource implements SelfCheckingResourceInterface, \Serial
* The __serialize() magic method will be automatically used instead of this * The __serialize() magic method will be automatically used instead of this
* *
* @return string * @return string
* @deprecated will be removed in 5.0 * @deprecated 4.12.0 Use __serialize() instead
*/ */
public function serialize() public function serialize()
{ {
Deprecation::notice('4.12.0', 'Use __serialize() instead');
return ''; return '';
} }
@ -67,10 +69,11 @@ class FlushInvalidatedResource implements SelfCheckingResourceInterface, \Serial
* and the PHP version used in less than PHP 9.0 * and the PHP version used in less than PHP 9.0
* *
* @param string $serialized * @param string $serialized
* @deprecated will be removed in 5.0 * @deprecated 4.12.0 Use __unserialize() instead
*/ */
public function unserialize($serialized) public function unserialize($serialized)
{ {
Deprecation::notice('4.12.0', 'Use __unserialize() instead');
// no-op // no-op
} }