From fa48b6e17770375b405188b2720394d122e6f00b Mon Sep 17 00:00:00 2001 From: Steve Boyd Date: Tue, 29 Oct 2024 18:55:04 +1300 Subject: [PATCH] DOC Split apart Versioned and Staged --- .../00_Model/10_Versioning.md | 90 +++++++++---------- .../11_Partial_Template_Caching.md | 2 +- .../06_Testing/00_Unit_Testing.md | 2 +- .../14_Files/03_File_Security.md | 2 +- .../14_Files/05_File_Manipulation.md | 4 +- .../04_Preview.md | 4 +- .../How_Tos/Customise_CMS_Tree.md | 2 +- en/08_Changelogs/5.0.0.md | 26 +++--- en/08_Changelogs/5.2.0.md | 4 +- en/08_Changelogs/alpha/5.0.0-alpha1.md | 16 ++-- en/08_Changelogs/beta/5.0.0-beta1.md | 24 ++--- en/08_Changelogs/beta/5.2.0-beta1.md | 2 +- en/08_Changelogs/rc/5.0.0-rc1.md | 24 ++--- en/08_Changelogs/rc/5.2.0-rc1.md | 4 +- 14 files changed, 103 insertions(+), 103 deletions(-) diff --git a/en/02_Developer_Guides/00_Model/10_Versioning.md b/en/02_Developer_Guides/00_Model/10_Versioning.md index f320f42f2..db70546bb 100644 --- a/en/02_Developer_Guides/00_Model/10_Versioning.md +++ b/en/02_Developer_Guides/00_Model/10_Versioning.md @@ -8,7 +8,7 @@ summary: Add versioning to your database content through the Versioned extension Database content in Silverstripe CMS can be "staged" before its publication, as well as track all changes through the lifetime of a database record. -Versioning in Silverstripe CMS is handled through the [`Versioned`](api:SilverStripe\Versioned\Versioned) extension class. As an [`Extension`](api:SilverStripe\Core\Extension) it is possible to be applied to any [`DataObject`](api:SilverStripe\ORM\DataObject) subclass. The extension class will automatically update read and write operations performed via the ORM because it implements the `augmentSQL` extension hooks defined in [`DataQuery::getFinalisedQuery()`](api:SilverStripe\ORM\DataQuery::getFinalisedQuery()). +Versioning in Silverstripe CMS is handled through the [`Versioned`](api:SilverStripe\Versioned\Mode\Versioned) extension class. As an [`Extension`](api:SilverStripe\Core\Extension) it is possible to be applied to any [`DataObject`](api:SilverStripe\ORM\DataObject) subclass. The extension class will automatically update read and write operations performed via the ORM because it implements the `augmentSQL` extension hooks defined in [`DataQuery::getFinalisedQuery()`](api:SilverStripe\ORM\DataQuery::getFinalisedQuery()). The `Versioned` extension is applied to pages in the CMS (the [`SiteTree`](api:SilverStripe\CMS\Model\SiteTree) class) - along with some other core `DataObject` models such as files - by default. Draft content edited in the CMS can be different from published content shown to your website visitors. @@ -125,13 +125,13 @@ This section explains how to take a regular `DataObject` and add versioning to i > Versioning only works if you are adding the extension to the base class. That is, the first subclass > of `DataObject`. Adding this extension to children of the base class will have unpredictable behaviour. -Adding versioning to a `DataObject` model is as easy as applying the [`Versioned`](api:SilverStripe\Versioned\Versioned) extension to it, either via PHP or YAML configuration. This will apply versioning *with stages*, meaning you can have a draft and a published version of your records. +Adding versioning to a `DataObject` model is as easy as applying the [`Versioned`](api:SilverStripe\Versioned\Mode\Versioned) extension to it, either via PHP or YAML configuration. This will apply versioning *with stages*, meaning you can have a draft and a published version of your records. ```php namespace App\Model; use SilverStripe\ORM\DataObject; -use SilverStripe\Versioned\Versioned; +use SilverStripe\Versioned\Mode\Versioned; class MyStagedModel extends DataObject { @@ -144,7 +144,7 @@ class MyStagedModel extends DataObject ```yml App\Model\MyStagedModel: extensions: - - SilverStripe\Versioned\Versioned + - SilverStripe\Versioned\Mode\Versioned ``` Alternatively, staging can be disabled, so that only versioned changes are tracked for your model. This @@ -155,7 +155,7 @@ staging. namespace App\Model; use SilverStripe\ORM\DataObject; -use SilverStripe\Versioned\Versioned; +use SilverStripe\Versioned\Mode\Versioned; class VersionedModel extends DataObject { @@ -168,7 +168,7 @@ class VersionedModel extends DataObject ```yml App\Model\MyStagedModel: extensions: - - SilverStripe\Versioned\Versioned.versioned + - SilverStripe\Versioned\Mode\Versioned.versioned ``` > [!WARNING] @@ -205,7 +205,7 @@ class Product extends DataObject namespace App\Model; use SilverStripe\ORM\DataObject; -use SilverStripe\Versioned\Versioned; +use SilverStripe\Versioned\Mode\Versioned; class ProductCategory extends DataObject { @@ -238,12 +238,12 @@ By default, `Versioned` will come out of the box with security extensions which Versioned DataObjects get additional permission check methods to verify what operation a `Member` is allowed to perform: -- [`canPublish()`](api:SilverStripe\Versioned\Versioned::canPublish()): Determines if a given `Member` is allowed to publish the record -- [`canUnpublish()`](api:SilverStripe\Versioned\Versioned::canUnpublish()) Determines if a given `Member` is allowed to unpublish the record -- [`canViewStage()`](api:SilverStripe\Versioned\Versioned::canViewStage()) Determines if a given `Member` can view the latest version of this record on a specific stage. Beware that this is *not* invoked when calling `canView()`. If you want to affect the result of regular `canView()` checks, implement `canViewVersioned()` instead. -- [`canViewVersioned()`](api:SilverStripe\Versioned\Versioned::canViewVersioned()) Provides additional can view checks for versioned records. This is called by `canView()` and should not be called directly. +- [`canPublish()`](api:SilverStripe\Versioned\Mode\Versioned::canPublish()): Determines if a given `Member` is allowed to publish the record +- [`canUnpublish()`](api:SilverStripe\Versioned\Mode\Versioned::canUnpublish()) Determines if a given `Member` is allowed to unpublish the record +- [`canViewStage()`](api:SilverStripe\Versioned\Mode\Versioned::canViewStage()) Determines if a given `Member` can view the latest version of this record on a specific stage. Beware that this is *not* invoked when calling `canView()`. If you want to affect the result of regular `canView()` checks, implement `canViewVersioned()` instead. +- [`canViewVersioned()`](api:SilverStripe\Versioned\Mode\Versioned::canViewVersioned()) Provides additional can view checks for versioned records. This is called by `canView()` and should not be called directly. -The existing [`canDelete()`](api:SilverStripe\Versioned\Versioned::canDelete()) method is used to check if a given `Member` is allowed to archive the record. The `Versioned` extension enhances this permission check for published content to ensure members that cannot unpublish content also cannot archive it. +The existing [`canDelete()`](api:SilverStripe\Versioned\Mode\Versioned::canDelete()) method is used to check if a given `Member` is allowed to archive the record. The `Versioned` extension enhances this permission check for published content to ensure members that cannot unpublish content also cannot archive it. These methods accept an optional `Member` argument. If not provided, they will assume you want to check the permission against the current `Member`. When performing a version operation on behalf of a `Member`, you'll probably want to use these methods to confirm they are authorised. @@ -260,7 +260,7 @@ if ($record->canPublish()) { The `canViewStage()` method can be used to check if a Member can view a specific stage of a record. It should be invoked by user code to check if a record is visible in the given stage. ```php -use SilverStripe\Versioned\Versioned; +use SilverStripe\Versioned\Mode\Versioned; // Check if `$member` can view the Live version of $record. $record->canViewStage(Versioned::LIVE, $member); @@ -290,7 +290,7 @@ namespace App\Model; use SilverStripe\ORM\DataObject; use SilverStripe\Security\Permission; -use SilverStripe\Versioned\Versioned; +use SilverStripe\Versioned\Mode\Versioned; class MyObject extends DataObject { @@ -353,7 +353,7 @@ E.g. namespace App\Model; use SilverStripe\ORM\DataObject; -use SilverStripe\Versioned\Versioned; +use SilverStripe\Versioned\Mode\Versioned; class MyObject extends DataObject { @@ -400,7 +400,7 @@ namespace App\Model; use App\PageType\MyPage; use SilverStripe\Assets\Image; use SilverStripe\ORM\DataObject; -use SilverStripe\Versioned\Versioned; +use SilverStripe\Versioned\Mode\Versioned; class Banner extends DataObject { @@ -446,7 +446,7 @@ You must declare both `owns` and `cascade_deletes` if you want all publish, unpu #### Unversioned `DataObject` ownership Ownership can be used with non-versioned DataObjects, as the necessary functionality is included by default -by the versioned object through the [`RecursivePublishable`](api:SilverStripe\Versioned\RecursivePublishable) extension which is +by the versioned object through the [`RecursivePublishable`](api:SilverStripe\Versioned\Staged\RecursivePublishable) extension which is applied to all objects. However, it is important to note that even when saving un-versioned objects, it is necessary to explicitly call @@ -472,7 +472,7 @@ For example: namespace App\Model; use SilverStripe\ORM\DataObject; -use SilverStripe\Versioned\Versioned; +use SilverStripe\Versioned\Mode\Versioned; class MyParent extends DataObject { @@ -495,7 +495,7 @@ class MyParent extends DataObject namespace App\Model; use SilverStripe\ORM\DataObject; -use SilverStripe\Versioned\Versioned; +use SilverStripe\Versioned\Mode\Versioned; class MyChild extends DataObject { @@ -527,7 +527,7 @@ the shortcode references the database identifier of the `Image` object and ensur ### Controlling how CMS users interact with versioned `DataObject` records -The versioned module includes a [`VersionedGridfieldDetailForm`](api:SilverStripe\Versioned\VersionedGridFieldDetailForm) extension which provides versioning support for DataObjects edited in a [`GridField`](api:SilverStripe\Forms\GridField\GridField). This is applied to [`GridFieldDetailForm`](api:SilverStripe\Forms\GridField\GridFieldDetailForm) by default. +The versioned module includes a [`VersionedGridfieldDetailForm`](api:SilverStripe\Versioned\Versioned\VersionedGridFieldDetailForm) extension which provides versioning support for DataObjects edited in a [`GridField`](api:SilverStripe\Forms\GridField\GridField). This is applied to [`GridFieldDetailForm`](api:SilverStripe\Forms\GridField\GridFieldDetailForm) by default. You can disable this on a per-model basis by setting the `versioned_gridfield_extensions` configuration property to false. You can do that in PHP: @@ -560,7 +560,7 @@ namespace { use SilverStripe\Forms\GridField\GridField; use SilverStripe\Forms\GridField\GridFieldConfig_RelationEditor; use SilverStripe\Forms\GridField\GridFieldDetailForm; - use SilverStripe\Versioned\VersionedGridFieldItemRequest; + use SilverStripe\Versioned\Versioned\VersionedGridFieldItemRequest; class Page extends SiteTree { @@ -591,10 +591,10 @@ By default, all records are retrieved from the "Stage" (aka draft) stage, which You can explicitly request a specific stage through various static methods on the `Versioned` class. > [!TIP] -> Note that in the below examples we just return the `DataList` without executing it. We don't need to execute the query, the reading mode is attached to the `DataList` as soon as it's created via the [`augmentDataQueryCreation()`](api:SilverStripe\Versioned\Versioned::augmentDataQueryCreation()) extension hook implementation. +> Note that in the below examples we just return the `DataList` without executing it. We don't need to execute the query, the reading mode is attached to the `DataList` as soon as it's created via the [`augmentDataQueryCreation()`](api:SilverStripe\Versioned\Mode\Versioned::augmentDataQueryCreation()) extension hook implementation. ```php -use SilverStripe\Versioned\Versioned; +use SilverStripe\Versioned\Mode\Versioned; // Fetching multiple records $stageRecords = Versioned::get_by_stage(MyRecord::class, Versioned::DRAFT); @@ -605,10 +605,10 @@ $stageRecord = Versioned::get_by_stage(MyRecord::class, Versioned::DRAFT)->byID( $liveRecord = Versioned::get_by_stage(MyRecord::class, Versioned::LIVE)->byID(99); ``` -You can also use [`Versioned::withVersionedMode()`](api:SilverStripe\Versioned\Versioned::withVersionedMode()) in conjunction with [`Versioned::set_stage()`](api:SilverStripe\Versioned\Versioned::set_stage()) to temporarily change what stage is being used for queries. +You can also use [`Versioned::withVersionedMode()`](api:SilverStripe\Versioned\Mode\Versioned::withVersionedMode()) in conjunction with [`Versioned::set_stage()`](api:SilverStripe\Versioned\Mode\Versioned::set_stage()) to temporarily change what stage is being used for queries. ```php -use SilverStripe\Versioned\Versioned; +use SilverStripe\Versioned\Mode\Versioned; $liveRecords = Versioned::withVersionedMode(function () { // Set the reading mode we want - note we don't have to set it back afterwards, @@ -622,7 +622,7 @@ $liveRecords = Versioned::withVersionedMode(function () { You can use `Versioned::set_stage()` outside of calls to `Versioned::withVersionedMode()`, but you *must* remember to set the reading mode back to what is was before you started, or you risk unexpected side effects. The only exception to this is if you explicitly want the rest of the request execution to be performed with a given reading mode (e.g. if a given action on a controller must be explicitly completely executed ina given stage). ```php -use SilverStripe\Versioned\Versioned; +use SilverStripe\Versioned\Mode\Versioned; // Temporarily store the current mode before setting the mode we want to use $oldMode = Versioned::get_reading_mode(); @@ -643,7 +643,7 @@ The above commands will just retrieve the latest version of its respective stage in the `_versions` tables (see [How versioned DataObjects are tracked in the database](#versions-in-the-database)). ```php -use SilverStripe\Versioned\Versioned; +use SilverStripe\Versioned\Mode\Versioned; // the "id" parameter is the ID of the record, and the "version" parameter is the specific version number to fetch $historicalRecord = Versioned::get_version(MyRecord::class, id: 5, version: 6); @@ -654,7 +654,7 @@ The record is retrieved as a regular `DataObject` record with its values set to > [!CAUTION] > Saving modifications via `write()` will create a *new* version, rather than modifying the existing one. -In order to get a list of all versions for a specific record, we get the record version data as specialized [`Versioned_Version`](api:SilverStripe\Versioned\Versioned_Version) +In order to get a list of all versions for a specific record, we get the record version data as specialized [`Versioned_Version`](api:SilverStripe\Versioned\Mode\Versioned_Version) objects, which expose the same database information as a `DataObject`, but also include information about when and how a record was published. @@ -670,7 +670,7 @@ $version = $versions->First()->Version; When you call the `write()` method on a versioned `DataObject` record, this will transparently create a new version of the record in the "Stage" stage. -To write your changes without creating new version, call [`writeWithoutVersion()`](api:SilverStripe\Versioned\Versioned::writeWithoutVersion()) instead. +To write your changes without creating new version, call [`writeWithoutVersion()`](api:SilverStripe\Versioned\Mode\Versioned::writeWithoutVersion()) instead. ```php // This will retrieve the latest draft version of record ID 99. @@ -698,8 +698,8 @@ An "unpublish" operation *removes* that record from the "Live" stage. There's two main methods used to publish a versioned `DataObject` record: -- [`publishSingle()`](api:SilverStripe\Versioned\Versioned::writeWithoutVersion()) publishes *only* this record to live from the draft -- [`publishRecursive()`](api:SilverStripe\Versioned\RecursivePublishable::publishRecursive()) publishes this record and any dependent objects this record may refer to. +- [`publishSingle()`](api:SilverStripe\Versioned\Mode\Versioned::writeWithoutVersion()) publishes *only* this record to live from the draft +- [`publishRecursive()`](api:SilverStripe\Versioned\Staged\RecursivePublishable::publishRecursive()) publishes this record and any dependent objects this record may refer to. In most regular cases, you'll want to use `publishRecursive()`. @@ -723,7 +723,7 @@ Archiving and unpublishing are similar operations, both will prevent a versioned Both of these operations create a new entry in the relevant `_Versions` table with the `WasDeleted` column set to `1` (see [How versioned DataObjects are tracked in the database](#versions-in-the-database)). -Call [`doUnpublish()`](api:SilverStripe\Versioned\Versioned::doUnpublish()) to unpublish an item. Either call [`doArchive()`](api:SilverStripe\Versioned\Versioned::doArchive()) or simply call `delete()` to archive an item. The Silverstripe ORM doesn't allow you to *hard-delete* versioned DataObjects. Instead they are simply removed from all stages, but all version history is retained. This allowed you to restore archived records later on, if you want to. +Call [`doUnpublish()`](api:SilverStripe\Versioned\Mode\Versioned::doUnpublish()) to unpublish an item. Either call [`doArchive()`](api:SilverStripe\Versioned\Mode\Versioned::doArchive()) or simply call `delete()` to archive an item. The Silverstripe ORM doesn't allow you to *hard-delete* versioned DataObjects. Instead they are simply removed from all stages, but all version history is retained. This allowed you to restore archived records later on, if you want to. ```php $record = MyRecord::get()->byID(99); @@ -744,12 +744,12 @@ Note that `doUnpublish()` and `doArchive()` do not work recursively. If you wish ### Rolling back to an older version -Rolling back allows you to return a record to a previous state. You can rollback a single record using the [`rollbackSingle()`](api:SilverStripe\Versioned\Versioned::rollbackSingle()) method. You can also rollback all dependent records using the [`rollbackRecursive()`](api:SilverStripe\Versioned\Versioned::rollbackRecursive()) method. +Rolling back allows you to return a record to a previous state. You can rollback a single record using the [`rollbackSingle()`](api:SilverStripe\Versioned\Mode\Versioned::rollbackSingle()) method. You can also rollback all dependent records using the [`rollbackRecursive()`](api:SilverStripe\Versioned\Mode\Versioned::rollbackRecursive()) method. Both `rollbackSingle()` and `rollbackRecursive()` expect a single argument, which may be a specific version ID or a stage name. ```php -use SilverStripe\Versioned\Versioned; +use SilverStripe\Versioned\Mode\Versioned; $record = MyRecord::get()->byID(99); @@ -774,7 +774,7 @@ Archived records can still be retrieved using `get_including_deleted()`. This wi ```php use App\Model\MyRecord; -use SilverStripe\Versioned\Versioned; +use SilverStripe\Versioned\Mode\Versioned; // This script will restore all archived entries for MyRecord. $allMyRecords = Versioned::get_including_deleted(MyRecord::class); @@ -846,19 +846,19 @@ automatically joined as required: ### Writing custom queries to retrieve versioned `DataObject` We generally discourage writing `Versioned` queries from scratch, due to the complexities involved through joining -multiple tables across an inherited table scheme (see [Versioned::augmentSQL()](api:SilverStripe\Versioned\Versioned::augmentSQL())). If possible, try to stick to smaller modifications of the generated `DataList` objects. +multiple tables across an inherited table scheme (see [Versioned::augmentSQL()](api:SilverStripe\Versioned\Mode\Versioned::augmentSQL())). If possible, try to stick to smaller modifications of the generated `DataList` objects. Example: Get the first 10 live records, filtered by creation date: ```php -use SilverStripe\Versioned\Versioned; +use SilverStripe\Versioned\Mode\Versioned; $records = Versioned::get_by_stage(MyRecord::class, Versioned::LIVE)->limit(10)->sort('Created', 'ASC'); ``` ### Controlling what stage is displayed in the front end -The current stage for each request is determined by [`VersionedHTTPMiddleware`](api:SilverStripe\Versioned\VersionedHTTPMiddleware) before any controllers initialize, through -[`Versioned::choose_site_stage()`](api:SilverStripe\Versioned\Versioned::choose_site_stage()). It checks for a `stage` GET parameter, so you can force a "Stage" (draft) stage by appending +The current stage for each request is determined by [`VersionedHTTPMiddleware`](api:SilverStripe\Versioned\Staged\VersionedHTTPMiddleware) before any controllers initialize, through +[`Versioned::choose_site_stage()`](api:SilverStripe\Versioned\Mode\Versioned::choose_site_stage()). It checks for a `stage` GET parameter, so you can force a "Stage" (draft) stage by appending `?stage=Stage` to your request. The current stage setting is not "sticky" in the session. @@ -882,7 +882,7 @@ use App\Control\MyObjectController; use SilverStripe\Control\Controller; use SilverStripe\Core\Injector\Injector; use SilverStripe\ORM\DataObject; -use SilverStripe\Versioned\Versioned; +use SilverStripe\Versioned\Mode\Versioned; class MyObject extends DataObject { @@ -997,9 +997,9 @@ class MyController extends Controller Silverstripe CMS will usually call these low level methods for you. However if you have specialised needs, you may call them directly. -To move a saved version from one stage to another, call [`writeToStage()`](api:SilverStripe\Versioned\Versioned::writeToStage()) on the object, passing in the stage you want to write to. This is used internally to publish DataObjects. +To move a saved version from one stage to another, call [`writeToStage()`](api:SilverStripe\Versioned\Mode\Versioned::writeToStage()) on the object, passing in the stage you want to write to. This is used internally to publish DataObjects. -[`copyVersionToStage()`](api:SilverStripe\Versioned\Versioned::copyVersionToStage()) allows you to copy a specific version to a specific stage. This is used internally when performing a rollback, copying whichever version you're rolling back to into the "Stage" stage. +[`copyVersionToStage()`](api:SilverStripe\Versioned\Mode\Versioned::copyVersionToStage()) allows you to copy a specific version to a specific stage. This is used internally when performing a rollback, copying whichever version you're rolling back to into the "Stage" stage. The current stage is stored as global state on the `Versioned` object. It is usually modified by controllers, e.g. when a preview is initialized. But it can also be set and reset temporarily to force a specific operation to run on a certain stage. @@ -1020,14 +1020,14 @@ See [Reading versions by stage](#reading-versions-by-stage) for more about using ## Using the history viewer -You can add the [`HistoryViewerField`](api:SilverStripe\VersionedAdmin\Forms\HistoryViewerField) to the edit form of any [`DataObject`](api:SilverStripe\ORM\DataObject) with the [`Versioned`](api:SilverStripe\Versioned\Versioned) extension. This will allow CMS users revert to a previous version of the record. +You can add the [`HistoryViewerField`](api:SilverStripe\VersionedAdmin\Forms\HistoryViewerField) to the edit form of any [`DataObject`](api:SilverStripe\ORM\DataObject) with the [`Versioned`](api:SilverStripe\Versioned\Mode\Versioned) extension. This will allow CMS users revert to a previous version of the record. ```php // app/src/Models/MyDataObject.php namespace App\Models; use SilverStripe\ORM\DataObject; -use SilverStripe\Versioned\Versioned; +use SilverStripe\Versioned\Mode\Versioned; use SilverStripe\VersionedAdmin\Forms\HistoryViewerField; class MyDataObject extends DataObject @@ -1052,5 +1052,5 @@ class MyDataObject extends DataObject ## API documentation -- [Versioned](api:SilverStripe\Versioned\Versioned) +- [Versioned](api:SilverStripe\Versioned\Mode\Versioned) - [HistoryViewerField](api:SilverStripe\VersionedAdmin\Forms\HistoryViewerField) diff --git a/en/02_Developer_Guides/01_Templates/11_Partial_Template_Caching.md b/en/02_Developer_Guides/01_Templates/11_Partial_Template_Caching.md index ad0bf924a..892dd881b 100644 --- a/en/02_Developer_Guides/01_Templates/11_Partial_Template_Caching.md +++ b/en/02_Developer_Guides/01_Templates/11_Partial_Template_Caching.md @@ -57,7 +57,7 @@ Here is how it works in detail: won't have any effect until template recompilation (e.g. on cache flush). By default it equals to `'$CurrentReadingMode, $CurrentUser.ID'`. - This ensures the current [Versioned](api:SilverStripe\Versioned\Versioned) state and user ID are used. + This ensures the current [Versioned](api:SilverStripe\Versioned\Mode\Versioned) state and user ID are used. At runtime that will become something like `'LIVE, 0'` (for unauthenticated users in live mode). As usual, you may override its value via YAML configs. For example: diff --git a/en/02_Developer_Guides/06_Testing/00_Unit_Testing.md b/en/02_Developer_Guides/06_Testing/00_Unit_Testing.md index a002f22bb..8619442fb 100644 --- a/en/02_Developer_Guides/06_Testing/00_Unit_Testing.md +++ b/en/02_Developer_Guides/06_Testing/00_Unit_Testing.md @@ -107,7 +107,7 @@ namespace App\Test; use SilverStripe\Core\Config\Config; use SilverStripe\Dev\SapphireTest; -use SilverStripe\Versioned\Versioned; +use SilverStripe\Versioned\Mode\Versioned; class PageTest extends SapphireTest { diff --git a/en/02_Developer_Guides/14_Files/03_File_Security.md b/en/02_Developer_Guides/14_Files/03_File_Security.md index d75727bd1..36aa3f8f9 100644 --- a/en/02_Developer_Guides/14_Files/03_File_Security.md +++ b/en/02_Developer_Guides/14_Files/03_File_Security.md @@ -422,7 +422,7 @@ the `Versioned` extension. namespace App\Model; use SilverStripe\ORM\DataObject; -use SilverStripe\Versioned\Versioned; +use SilverStripe\Versioned\Mode\Versioned; class MyVersionedObject extends DataObject { diff --git a/en/02_Developer_Guides/14_Files/05_File_Manipulation.md b/en/02_Developer_Guides/14_Files/05_File_Manipulation.md index ae4f976d7..848a99c0a 100644 --- a/en/02_Developer_Guides/14_Files/05_File_Manipulation.md +++ b/en/02_Developer_Guides/14_Files/05_File_Manipulation.md @@ -136,11 +136,11 @@ if ($file) { } ``` -Note that you can cause the file to be moved immediately by [setting the Versioned reading mode](api:SilverStripe\Versioned\Versioned::set_reading_mode()) to draft temporarily. +Note that you can cause the file to be moved immediately by [setting the Versioned reading mode](api:SilverStripe\Versioned\Mode\Versioned::set_reading_mode()) to draft temporarily. ```php use SilverStripe\Assets\File; -use SilverStripe\Versioned\Versioned; +use SilverStripe\Versioned\Mode\Versioned; $file = File::get()->filter('Name', 'oldname.jpg')->first(); if ($file) { diff --git a/en/02_Developer_Guides/15_Customising_the_Admin_Interface/04_Preview.md b/en/02_Developer_Guides/15_Customising_the_Admin_Interface/04_Preview.md index 183b7d4c2..e67af7583 100644 --- a/en/02_Developer_Guides/15_Customising_the_Admin_Interface/04_Preview.md +++ b/en/02_Developer_Guides/15_Customising_the_Admin_Interface/04_Preview.md @@ -98,7 +98,7 @@ an inline PDF document in the preview panel. ### Preview states {#preview-states-php} The preview state(s) you apply to your `DataObject` will depend primarily on whether it uses -the [Versioned](api:SilverStripe\Versioned\Versioned) extension or not. +the [Versioned](api:SilverStripe\Versioned\Mode\Versioned) extension or not. #### Versioned `DataObject` models @@ -491,7 +491,7 @@ namespace App\Model; use App\PageType\ProductPage; use SilverStripe\ORM\CMSPreviewable; use SilverStripe\ORM\DataObject; -use SilverStripe\Versioned\Versioned; +use SilverStripe\Versioned\Mode\Versioned; class Product extends DataObject implements CMSPreviewable { diff --git a/en/02_Developer_Guides/15_Customising_the_Admin_Interface/How_Tos/Customise_CMS_Tree.md b/en/02_Developer_Guides/15_Customising_the_Admin_Interface/How_Tos/Customise_CMS_Tree.md index 474f4f9ae..8787b5231 100644 --- a/en/02_Developer_Guides/15_Customising_the_Admin_Interface/How_Tos/Customise_CMS_Tree.md +++ b/en/02_Developer_Guides/15_Customising_the_Admin_Interface/How_Tos/Customise_CMS_Tree.md @@ -50,7 +50,7 @@ code like this: By applying the proper style sheet, the snippet html above could produce the look of: ![Page Node Screenshot](../../../_images/tree_node.png "Page Node") -SiteTree is a [DataObject](api:SilverStripe\ORM\DataObject) which is versioned by [Versioned](api:SilverStripe\Versioned\Versioned) extension. +SiteTree is a [DataObject](api:SilverStripe\ORM\DataObject) which is versioned by [Versioned](api:SilverStripe\Versioned\Mode\Versioned) extension. Each node can optionally have publication status flags, e.g. "Removed from draft". Each flag has a unique identifier, which is also used as a CSS class for easier styling. diff --git a/en/08_Changelogs/5.0.0.md b/en/08_Changelogs/5.0.0.md index 2d1055c90..2e6227c0f 100644 --- a/en/08_Changelogs/5.0.0.md +++ b/en/08_Changelogs/5.0.0.md @@ -564,7 +564,7 @@ Note that as part of this change, the namespaces of several classes changed. Ref [Extension](api:SilverStripe\Core\Extension) classes don't expose `protected` methods, but they *can* be used for extension hooks. This reduces the surface of methods exposed from your extensions into `Extensible` classes. For example, you might have a `protected function updateCMSFields()` method which is called after writing some `DataObject` - but because this method is `protected`, it *cannot* be accessed directly from the `DataObject` instances. You can still expose some method from the `Extension` by making it `public` - and that method *can* be accessed directly from the `DataObject` instances. When invoking an extension hook (e.g. via `extend()`), methods prefixed with "extend" take precedence. i.e. if an `Extension` class has a `onAfterWrite()` method and an `extendOnAfterWrite()` method and you call `$this->extend('onAfterWrite')` - the `extendOnAfterWrite()` method on that `Extension` will be called, and `onAfterWrite()` will not. -This empowers advanced `Extension` functionality such as [Versioned::canPublish()](api:SilverStripe\Versioned\Versioned::canPublish()) which invokes `$owner->extendedCan('canPublish')` but doesn't result in a cycle, because the same class also implements [extendCanPublish()](api:SilverStripe\Versioned\Versioned::extendCanPublish()). +This empowers advanced `Extension` functionality such as [Versioned::canPublish()](api:SilverStripe\Versioned\Mode\Versioned::canPublish()) which invokes `$owner->extendedCan('canPublish')` but doesn't result in a cycle, because the same class also implements [extendCanPublish()](api:SilverStripe\Versioned\Mode\Versioned::extendCanPublish()). ### Other new features {#other-features} @@ -1072,7 +1072,7 @@ This sections contains the full list of APIs that have been changed or removed b - Removed deprecated class `SilverStripe\Dev\SapphireInfo` without equivalent functionality to replace it - Removed deprecated class `SilverStripe\Dev\Tasks\MigrateFileTask` without equivalent functionality to replace it - Removed deprecated class `SilverStripe\Dev\TestSession_STResponseWrapper` without equivalent functionality to replace it -- Removed deprecated class `SilverStripe\Forms\GridField\GridFieldVersionedState` - use [`SilverStripe\Versioned\VersionedGridFieldState\VersionedGridFieldState`](api:SilverStripe\Versioned\VersionedGridFieldState\VersionedGridFieldState) instead +- Removed deprecated class `SilverStripe\Forms\GridField\GridFieldVersionedState` - use [`SilverStripe\Versioned\Mode\VersionedGridFieldState\VersionedGridFieldState`](api:SilverStripe\Versioned\Mode\VersionedGridFieldState\VersionedGridFieldState) instead - Removed deprecated class `SilverStripe\Forms\HTMLEditor\TinyMCEGZIPGenerator` without equivalent functionality to replace it - Removed deprecated class `SilverStripe\ORM\Connect\PDOConnector` without equivalent functionality to replace it - Removed deprecated class `SilverStripe\ORM\Connect\PDOQuery` without equivalent functionality to replace it @@ -1773,16 +1773,16 @@ This sections contains the full list of APIs that have been changed or removed b ### `silverstripe/versioned` -- Removed deprecated method `SilverStripe\Versioned\Versioned::allVersions()` - use [`SilverStripe\Versioned\Versioned::Versions()`](api:SilverStripe\Versioned\Versioned::Versions()) instead -- Removed deprecated method `SilverStripe\Versioned\Versioned::doPublish()` - use [`SilverStripe\Versioned\Versioned::publishRecursive()`](api:SilverStripe\Versioned\Versioned::publishRecursive()) instead -- Removed deprecated method `SilverStripe\Versioned\Versioned::doRollbackTo()` - use [`SilverStripe\Versioned\Versioned::rollbackRecursive()`](api:SilverStripe\Versioned\Versioned::rollbackRecursive()) instead -- Removed deprecated method `SilverStripe\Versioned\Versioned::getLastEditedForVersion()` - use [`SilverStripe\Versioned\Versioned::getLastEditedAndStageForVersion()`](api:SilverStripe\Versioned\Versioned::getLastEditedAndStageForVersion()) instead -- Removed deprecated method `SilverStripe\Versioned\Versioned::migrateVersion()` - use [`SilverStripe\Versioned\Versioned::setMigratingVersion()`](api:SilverStripe\Versioned\Versioned::setMigratingVersion()) instead -- Removed deprecated method `SilverStripe\Versioned\Versioned::onAfterRevertToLive()` without equivalent functionality to replace it -- Removed deprecated method `SilverStripe\Versioned\Versioned::onAfterRollback()` without equivalent functionality to replace it -- Removed deprecated method `SilverStripe\Versioned\Versioned::publish()` - use [`SilverStripe\Versioned\Versioned::copyVersionToStage()`](api:SilverStripe\Versioned\Versioned::copyVersionToStage()) instead -- Removed deprecated method `SilverStripe\Versioned\Versioned::VersionsList()` - use [`SilverStripe\Versioned\Versioned::allVersions()`](api:SilverStripe\Versioned\Versioned::allVersions()) instead -- Removed deprecated parameter in [`SilverStripe\Versioned\Versioned::copyVersionToStage()`](api:SilverStripe\Versioned\Versioned::copyVersionToStage()) named `$createNewVersion` +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::allVersions()` - use [`SilverStripe\Versioned\Mode\Versioned::Versions()`](api:SilverStripe\Versioned\Mode\Versioned::Versions()) instead +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::doPublish()` - use [`SilverStripe\Versioned\Mode\Versioned::publishRecursive()`](api:SilverStripe\Versioned\Mode\Versioned::publishRecursive()) instead +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::doRollbackTo()` - use [`SilverStripe\Versioned\Mode\Versioned::rollbackRecursive()`](api:SilverStripe\Versioned\Mode\Versioned::rollbackRecursive()) instead +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::getLastEditedForVersion()` - use [`SilverStripe\Versioned\Mode\Versioned::getLastEditedAndStageForVersion()`](api:SilverStripe\Versioned\Mode\Versioned::getLastEditedAndStageForVersion()) instead +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::migrateVersion()` - use [`SilverStripe\Versioned\Mode\Versioned::setMigratingVersion()`](api:SilverStripe\Versioned\Mode\Versioned::setMigratingVersion()) instead +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::onAfterRevertToLive()` without equivalent functionality to replace it +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::onAfterRollback()` without equivalent functionality to replace it +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::publish()` - use [`SilverStripe\Versioned\Mode\Versioned::copyVersionToStage()`](api:SilverStripe\Versioned\Mode\Versioned::copyVersionToStage()) instead +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::VersionsList()` - use [`SilverStripe\Versioned\Mode\Versioned::allVersions()`](api:SilverStripe\Versioned\Mode\Versioned::allVersions()) instead +- Removed deprecated parameter in [`SilverStripe\Versioned\Mode\Versioned::copyVersionToStage()`](api:SilverStripe\Versioned\Mode\Versioned::copyVersionToStage()) named `$createNewVersion` - Changed return type for [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::clear()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::clear()) from dynamic to `bool` - Changed return type for [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::delete()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::delete()) from dynamic to `bool` - Changed return type for [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::deleteMultiple()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::deleteMultiple()) from dynamic to `bool` @@ -1792,7 +1792,7 @@ This sections contains the full list of APIs that have been changed or removed b - Changed return type for [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::prune()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::prune()) from dynamic to `bool` - Changed return type for [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::set()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::set()) from dynamic to `bool` - Changed return type for [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::setMultiple()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::setMultiple()) from dynamic to `bool` -- [`SilverStripe\Versioned\Versioned::__construct()`](api:SilverStripe\Versioned\Versioned::__construct()) now explicitly only accepts `$mode` as a single argument. +- [`SilverStripe\Versioned\Mode\Versioned::__construct()`](api:SilverStripe\Versioned\Mode\Versioned::__construct()) now explicitly only accepts `$mode` as a single argument. - Changed parameter type in [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::delete()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::delete()) for `$key` from dynamic to `string` - Changed parameter type in [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::deleteMultiple()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::deleteMultiple()) for `$keys` from dynamic to `iterable` - Changed parameter type in [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::get()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::get()) for `$key` from dynamic to `string` diff --git a/en/08_Changelogs/5.2.0.md b/en/08_Changelogs/5.2.0.md index 287aba318..bd60d9065 100644 --- a/en/08_Changelogs/5.2.0.md +++ b/en/08_Changelogs/5.2.0.md @@ -327,7 +327,7 @@ Alongside this change, we've also added some more HTTP status codes to the list ### Versioned status badges for elemental {#elemental-badges} -Elemental content blocks now feature versioned status badges which adds a textual indicator of whether the block is in draft or a modified state. This textual label is in addition to the dot icon indicator that was already there. The new label is only provided if the [`Versioned`](api:SilverStripe\Versioned\Versioned) extension is used for elemental blocks, which it is by default. +Elemental content blocks now feature versioned status badges which adds a textual indicator of whether the block is in draft or a modified state. This textual label is in addition to the dot icon indicator that was already there. The new label is only provided if the [`Versioned`](api:SilverStripe\Versioned\Mode\Versioned) extension is used for elemental blocks, which it is by default. ![examples of the versioned labels](../_images/changelogs/5.2.0/elemental-badge.png) @@ -566,7 +566,7 @@ The [`SiteTree.hide_ancestor`](api:SilverStripe\CMS\Model\SiteTree->hide_ancesto ### `silverstripe/versioned` {#api-silverstripe-versioned} -The `$having` parameter in the [`Versioned::Versions()`](api:SilverStripe\Versioned\Versioned::Versions()) method has been deprecated. This parameter was never used, and has been removed from the method signature. +The `$having` parameter in the [`Versioned::Versions()`](api:SilverStripe\Versioned\Mode\Versioned::Versions()) method has been deprecated. This parameter was never used, and has been removed from the method signature. ## Bug fixes diff --git a/en/08_Changelogs/alpha/5.0.0-alpha1.md b/en/08_Changelogs/alpha/5.0.0-alpha1.md index 9e611820d..870969bec 100644 --- a/en/08_Changelogs/alpha/5.0.0-alpha1.md +++ b/en/08_Changelogs/alpha/5.0.0-alpha1.md @@ -109,12 +109,12 @@ This is an alpha of a major release and as a result there are a number of breaki #### `silverstripe/versioned` -- Removed deprecated method `SilverStripe\Versioned\Versioned::doPublish()` -- Removed deprecated method `SilverStripe\Versioned\Versioned::doRollbackTo()` -- Removed deprecated method `SilverStripe\Versioned\Versioned::migrateVersion()` -- Removed deprecated method `SilverStripe\Versioned\Versioned::onAfterRevertToLive()` -- Removed deprecated method `SilverStripe\Versioned\Versioned::onAfterRollback()` -- Removed deprecated method `SilverStripe\Versioned\Versioned::publish()` +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::doPublish()` +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::doRollbackTo()` +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::migrateVersion()` +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::onAfterRevertToLive()` +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::onAfterRollback()` +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::publish()` #### `silverstripe/versioned-admin` @@ -133,7 +133,7 @@ This is an alpha of a major release and as a result there are a number of breaki - `SilverStripe\Dev\MigrationTask` is now abstract. - `SilverStripe\Dev\SapphireTest` is now abstract. - `SilverStripe\Core\Extensible::invokeWithExtensions()` and `SilverStripe\Core\Extensible::extend()` now use the splat operator instead of having a concrete number of possible arguments. -- The constructor for `SilverStripe\Versioned\Versioned` now explicitly only accepts mode as a single argument. +- The constructor for `SilverStripe\Versioned\Mode\Versioned` now explicitly only accepts mode as a single argument. ### ORM {#api-orm} @@ -155,7 +155,7 @@ their aliases (applied by setting a string key for the array) were being ignored [Extension](api:SilverStripe\Core\Extension) classes don't expose `protected` methods, but they *can* be used for extension hooks. This reduces the surface of methods exposed from your extensions into `Extensible` classes. For example, you might have a `protected function updateCMSFields()` method which will be called after writing some `DataObject` - but because this method is `protected`, it *cannot* be accessed directly from the `DataObject` instances. You can however still expose some method from the `Extension` by making it `public` - and that method *can* be accessed directly from the `DataObject` instances. When invoking an extension hook (e.g. via `extend()`), methods prefixed with "extend" will take precendence. i.e. if an `Extension` class has a `onAfterWrite()` method and an `extendOnAfterWrite()` method and I call `$this->extend('onAfterWrite')` - the `extendOnAfterWrite()` method on that `Extension` will be called, and `onAfterWrite()` will not. -This empowers advanced `Extension` functionality such as [Versioned::canPublish()](api:SilverStripe\Versioned\Versioned::canPublish()) which invokes `$owner->extendedCan('canPublish')` but doesn't result in a cycle, because the same class also implements [extendCanPublish()](api:SilverStripe\Versioned\Versioned::extendCanPublish()). +This empowers advanced `Extension` functionality such as [Versioned::canPublish()](api:SilverStripe\Versioned\Mode\Versioned::canPublish()) which invokes `$owner->extendedCan('canPublish')` but doesn't result in a cycle, because the same class also implements [extendCanPublish()](api:SilverStripe\Versioned\Mode\Versioned::extendCanPublish()). ### Other new features {#other-features} diff --git a/en/08_Changelogs/beta/5.0.0-beta1.md b/en/08_Changelogs/beta/5.0.0-beta1.md index 9b83d1c3a..87a045ded 100644 --- a/en/08_Changelogs/beta/5.0.0-beta1.md +++ b/en/08_Changelogs/beta/5.0.0-beta1.md @@ -661,7 +661,7 @@ Note that as part of this change the namespaces of several classes changed. Refe [Extension](api:SilverStripe\Core\Extension) classes don't expose `protected` methods, but they *can* be used for extension hooks. This reduces the surface of methods exposed from your extensions into `Extensible` classes. For example, you might have a `protected function updateCMSFields()` method which will be called after writing some `DataObject` - but because this method is `protected`, it *cannot* be accessed directly from the `DataObject` instances. You can however still expose some method from the `Extension` by making it `public` - and that method *can* be accessed directly from the `DataObject` instances. When invoking an extension hook (e.g. via `extend()`), methods prefixed with "extend" will take precedence. i.e. if an `Extension` class has a `onAfterWrite()` method and an `extendOnAfterWrite()` method and I call `$this->extend('onAfterWrite')` - the `extendOnAfterWrite()` method on that `Extension` will be called, and `onAfterWrite()` will not. -This empowers advanced `Extension` functionality such as [Versioned::canPublish()](api:SilverStripe\Versioned\Versioned::canPublish()) which invokes `$owner->extendedCan('canPublish')` but doesn't result in a cycle, because the same class also implements [extendCanPublish()](api:SilverStripe\Versioned\Versioned::extendCanPublish()). +This empowers advanced `Extension` functionality such as [Versioned::canPublish()](api:SilverStripe\Versioned\Mode\Versioned::canPublish()) which invokes `$owner->extendedCan('canPublish')` but doesn't result in a cycle, because the same class also implements [extendCanPublish()](api:SilverStripe\Versioned\Mode\Versioned::extendCanPublish()). ### Other new features {#other-features} @@ -1803,16 +1803,16 @@ This is a major release and contains many breaking API changes. Deprecation warn #### `silverstripe/versioned` -- Removed deprecated method `SilverStripe\Versioned\Versioned::allVersions()` -- Removed deprecated method `SilverStripe\Versioned\Versioned::doPublish()` -- Removed deprecated method `SilverStripe\Versioned\Versioned::doRollbackTo()` -- Removed deprecated method `SilverStripe\Versioned\Versioned::getLastEditedForVersion()` -- Removed deprecated method `SilverStripe\Versioned\Versioned::migrateVersion()` -- Removed deprecated method `SilverStripe\Versioned\Versioned::onAfterRevertToLive()` -- Removed deprecated method `SilverStripe\Versioned\Versioned::onAfterRollback()` -- Removed deprecated method `SilverStripe\Versioned\Versioned::publish()` -- Removed deprecated method `SilverStripe\Versioned\Versioned::VersionsList()` -- Removed deprecated parameter in [`SilverStripe\Versioned\Versioned::copyVersionToStage()`](api:SilverStripe\Versioned\Versioned::copyVersionToStage()) named `$createNewVersion` +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::allVersions()` +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::doPublish()` +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::doRollbackTo()` +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::getLastEditedForVersion()` +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::migrateVersion()` +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::onAfterRevertToLive()` +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::onAfterRollback()` +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::publish()` +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::VersionsList()` +- Removed deprecated parameter in [`SilverStripe\Versioned\Mode\Versioned::copyVersionToStage()`](api:SilverStripe\Versioned\Mode\Versioned::copyVersionToStage()) named `$createNewVersion` - Changed return type for [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::clear()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::clear()) from dynamic to `bool` - Changed return type for [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::delete()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::delete()) from dynamic to `bool` - Changed return type for [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::deleteMultiple()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::deleteMultiple()) from dynamic to `bool` @@ -1822,7 +1822,7 @@ This is a major release and contains many breaking API changes. Deprecation warn - Changed return type for [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::prune()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::prune()) from dynamic to `bool` - Changed return type for [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::set()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::set()) from dynamic to `bool` - Changed return type for [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::setMultiple()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::setMultiple()) from dynamic to `bool` -- [`SilverStripe\Versioned\Versioned::__construct()`](api:SilverStripe\Versioned\Versioned::__construct()) now explicitly only accepts `$mode` as a single argument. +- [`SilverStripe\Versioned\Mode\Versioned::__construct()`](api:SilverStripe\Versioned\Mode\Versioned::__construct()) now explicitly only accepts `$mode` as a single argument. - Changed parameter type in [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::delete()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::delete()) for `$key` from dynamic to `string` - Changed parameter type in [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::deleteMultiple()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::deleteMultiple()) for `$keys` from dynamic to `iterable` - Changed parameter type in [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::get()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::get()) for `$key` from dynamic to `string` diff --git a/en/08_Changelogs/beta/5.2.0-beta1.md b/en/08_Changelogs/beta/5.2.0-beta1.md index 16f368b7f..1a74fd339 100644 --- a/en/08_Changelogs/beta/5.2.0-beta1.md +++ b/en/08_Changelogs/beta/5.2.0-beta1.md @@ -520,7 +520,7 @@ The [`SiteTree.hide_ancestor`](api:SilverStripe\CMS\Model\SiteTree->hide_ancesto ### `silverstripe/versioned` {#api-silverstripe-versioned} -The `$having` parameter in the [`Versioned::Versions()`](api:SilverStripe\Versioned\Versioned::Versions()) method has been deprecated. This parameter was never used, and has been removed from the method signature. +The `$having` parameter in the [`Versioned::Versions()`](api:SilverStripe\Versioned\Mode\Versioned::Versions()) method has been deprecated. This parameter was never used, and has been removed from the method signature. ## Bug fixes diff --git a/en/08_Changelogs/rc/5.0.0-rc1.md b/en/08_Changelogs/rc/5.0.0-rc1.md index 81fb5b9d2..4e36f6c02 100644 --- a/en/08_Changelogs/rc/5.0.0-rc1.md +++ b/en/08_Changelogs/rc/5.0.0-rc1.md @@ -547,7 +547,7 @@ Note that as part of this change the namespaces of several classes changed. Refe [Extension](api:SilverStripe\Core\Extension) classes don't expose `protected` methods, but they *can* be used for extension hooks. This reduces the surface of methods exposed from your extensions into `Extensible` classes. For example, you might have a `protected function updateCMSFields()` method which will be called after writing some `DataObject` - but because this method is `protected`, it *cannot* be accessed directly from the `DataObject` instances. You can however still expose some method from the `Extension` by making it `public` - and that method *can* be accessed directly from the `DataObject` instances. When invoking an extension hook (e.g. via `extend()`), methods prefixed with "extend" will take precedence. i.e. if an `Extension` class has a `onAfterWrite()` method and an `extendOnAfterWrite()` method and I call `$this->extend('onAfterWrite')` - the `extendOnAfterWrite()` method on that `Extension` will be called, and `onAfterWrite()` will not. -This empowers advanced `Extension` functionality such as [Versioned::canPublish()](api:SilverStripe\Versioned\Versioned::canPublish()) which invokes `$owner->extendedCan('canPublish')` but doesn't result in a cycle, because the same class also implements [extendCanPublish()](api:SilverStripe\Versioned\Versioned::extendCanPublish()). +This empowers advanced `Extension` functionality such as [Versioned::canPublish()](api:SilverStripe\Versioned\Mode\Versioned::canPublish()) which invokes `$owner->extendedCan('canPublish')` but doesn't result in a cycle, because the same class also implements [extendCanPublish()](api:SilverStripe\Versioned\Mode\Versioned::extendCanPublish()). ### Other new features {#other-features} @@ -1703,16 +1703,16 @@ This is a major release and contains many breaking API changes. Deprecation warn #### `silverstripe/versioned` -- Removed deprecated method `SilverStripe\Versioned\Versioned::allVersions()` -- Removed deprecated method `SilverStripe\Versioned\Versioned::doPublish()` -- Removed deprecated method `SilverStripe\Versioned\Versioned::doRollbackTo()` -- Removed deprecated method `SilverStripe\Versioned\Versioned::getLastEditedForVersion()` -- Removed deprecated method `SilverStripe\Versioned\Versioned::migrateVersion()` -- Removed deprecated method `SilverStripe\Versioned\Versioned::onAfterRevertToLive()` -- Removed deprecated method `SilverStripe\Versioned\Versioned::onAfterRollback()` -- Removed deprecated method `SilverStripe\Versioned\Versioned::publish()` -- Removed deprecated method `SilverStripe\Versioned\Versioned::VersionsList()` -- Removed deprecated parameter in [`SilverStripe\Versioned\Versioned::copyVersionToStage()`](api:SilverStripe\Versioned\Versioned::copyVersionToStage()) named `$createNewVersion` +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::allVersions()` +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::doPublish()` +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::doRollbackTo()` +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::getLastEditedForVersion()` +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::migrateVersion()` +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::onAfterRevertToLive()` +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::onAfterRollback()` +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::publish()` +- Removed deprecated method `SilverStripe\Versioned\Mode\Versioned::VersionsList()` +- Removed deprecated parameter in [`SilverStripe\Versioned\Mode\Versioned::copyVersionToStage()`](api:SilverStripe\Versioned\Mode\Versioned::copyVersionToStage()) named `$createNewVersion` - Changed return type for [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::clear()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::clear()) from dynamic to `bool` - Changed return type for [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::delete()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::delete()) from dynamic to `bool` - Changed return type for [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::deleteMultiple()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::deleteMultiple()) from dynamic to `bool` @@ -1722,7 +1722,7 @@ This is a major release and contains many breaking API changes. Deprecation warn - Changed return type for [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::prune()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::prune()) from dynamic to `bool` - Changed return type for [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::set()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::set()) from dynamic to `bool` - Changed return type for [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::setMultiple()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::setMultiple()) from dynamic to `bool` -- [`SilverStripe\Versioned\Versioned::__construct()`](api:SilverStripe\Versioned\Versioned::__construct()) now explicitly only accepts `$mode` as a single argument. +- [`SilverStripe\Versioned\Mode\Versioned::__construct()`](api:SilverStripe\Versioned\Mode\Versioned::__construct()) now explicitly only accepts `$mode` as a single argument. - Changed parameter type in [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::delete()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::delete()) for `$key` from dynamic to `string` - Changed parameter type in [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::deleteMultiple()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::deleteMultiple()) for `$keys` from dynamic to `iterable` - Changed parameter type in [`SilverStripe\Versioned\Caching\ProxyCacheAdapter::get()`](api:SilverStripe\Versioned\Caching\ProxyCacheAdapter::get()) for `$key` from dynamic to `string` diff --git a/en/08_Changelogs/rc/5.2.0-rc1.md b/en/08_Changelogs/rc/5.2.0-rc1.md index f76d4a59e..27719220b 100644 --- a/en/08_Changelogs/rc/5.2.0-rc1.md +++ b/en/08_Changelogs/rc/5.2.0-rc1.md @@ -337,7 +337,7 @@ Alongside this change, we've also added some more HTTP status codes to the list ### Versioned status badges for elemental {#elemental-badges} -Elemental content blocks now feature versioned status badges which adds a textual indicator of whether the block is in draft or a modified state. This textual label is in addition to the dot icon indicator that was already there. The new label is only provided if the [`Versioned`](api:SilverStripe\Versioned\Versioned) extension is used for elemental blocks, which it is by default. +Elemental content blocks now feature versioned status badges which adds a textual indicator of whether the block is in draft or a modified state. This textual label is in addition to the dot icon indicator that was already there. The new label is only provided if the [`Versioned`](api:SilverStripe\Versioned\Mode\Versioned) extension is used for elemental blocks, which it is by default. ![examples of the versioned labels](../../_images/changelogs/5.2.0/elemental-badge.png) @@ -576,7 +576,7 @@ The [`SiteTree.hide_ancestor`](api:SilverStripe\CMS\Model\SiteTree->hide_ancesto ### `silverstripe/versioned` {#api-silverstripe-versioned} -The `$having` parameter in the [`Versioned::Versions()`](api:SilverStripe\Versioned\Versioned::Versions()) method has been deprecated. This parameter was never used, and has been removed from the method signature. +The `$having` parameter in the [`Versioned::Versions()`](api:SilverStripe\Versioned\Mode\Versioned::Versions()) method has been deprecated. This parameter was never used, and has been removed from the method signature. ## Bug fixes