silverstripe-cms/code/Model/SiteTreeExtension.php

93 lines
2.6 KiB
PHP
Raw Normal View History

<?php
2016-07-22 11:32:32 +12:00
namespace SilverStripe\CMS\Model;
use SilverStripe\ORM\DataExtension;
2016-07-22 11:32:32 +12:00
use SilverStripe\Security\Member;
/**
* Plug-ins for additional functionality in your SiteTree classes.
2024-01-19 10:00:46 +13:00
*
* @template T of SiteTree
* @extends DataExtension<T>
*/
2017-01-26 09:59:25 +13:00
abstract class SiteTreeExtension extends DataExtension
{
2017-01-26 09:59:25 +13:00
/**
* Hook called before the page's {@link Versioned::publishSingle()} action is completed
*
* @param SiteTree &$original The current Live SiteTree record prior to publish
*/
protected function onBeforePublish(&$original)
2017-01-26 09:59:25 +13:00
{
}
2017-01-26 09:59:25 +13:00
/**
* Hook called after the page's {@link Versioned::publishSingle()} action is completed
*
* @param SiteTree &$original The current Live SiteTree record prior to publish
*/
protected function onAfterPublish(&$original)
2017-01-26 09:59:25 +13:00
{
}
2016-03-09 09:50:55 +13:00
2017-01-26 09:59:25 +13:00
/**
* Hook called before the page's {@link Versioned::doUnpublish()} action is completed
*/
protected function onBeforeUnpublish()
2017-01-26 09:59:25 +13:00
{
}
2016-03-09 09:50:55 +13:00
2017-01-26 09:59:25 +13:00
/**
* Hook called after the page's {@link SiteTree::doUnpublish()} action is completed
*/
protected function onAfterUnpublish()
2017-01-26 09:59:25 +13:00
{
}
2016-03-09 09:50:55 +13:00
2017-01-26 09:59:25 +13:00
/**
* Hook called to determine if a user may add children to this SiteTree object
*
* @see SiteTree::canAddChildren()
*
* @param Member $member The member to check permission against, or the currently
* logged in user
* @return boolean|null Return false to deny rights, or null to yield to default
*/
public function canAddChildren($member)
{
}
2016-03-09 09:50:55 +13:00
2017-01-26 09:59:25 +13:00
/**
* Hook called to determine if a user may publish this SiteTree object
*
* @see SiteTree::canPublish()
*
* @param Member $member The member to check permission against, or the currently
* logged in user
* @return boolean|null Return false to deny rights, or null to yield to default
*/
public function canPublish($member)
{
}
2017-01-26 09:59:25 +13:00
/**
* Hook called to modify the $base url of this page, with a given $action,
* before {@link SiteTree::RelativeLink()} calls {@link Controller::join_links()}
* on the $base and $action
*
* @param string &$link The URL of this page relative to siteroot including
2017-01-26 09:59:25 +13:00
* the action
* @param string $base The URL of this page relative to siteroot, not including
* the action
* @param string|boolean $action The action or subpage called on this page.
2017-01-26 09:59:25 +13:00
* (Legacy support) If this is true, then do not reduce the 'home' urlsegment
* to an empty link
*/
public function updateRelativeLink(&$link, $base, $action)
2017-01-26 09:59:25 +13:00
{
}
}