class GroupSubsites extends Extension implements PermissionProvider (View source)

Extension for the Group object to add subsites support

Properties

protected T $owner

The object this extension is applied to.

from  Extension

Methods

public
__construct()

No description

public static 
add_to_class(string $class, string $extensionClass, mixed $args = null)

Called when this extension is added to a particular class

public
setOwner(object $owner)

Set the owner of this extension.

public
mixed
withOwner(mixed $owner, callable $callback, array $args = [])

Temporarily modify the owner. The original owner is ensured to be restored

public
clearOwner()

Clear the current owner, and restore extension to the state prior to the last setOwner()

public
T
getOwner()

Returns the owner of this extension.

public static 
string
get_classname_without_arguments(string $extensionStr)

Helper method to strip eval'ed arguments from a string that's passed to DataObject::$extensions or Object::add_extension().

public
mixed
invokeExtension(object $owner, string $method, array ...$arguments)

Invoke extension point. This will prefer explicit extend prefixed methods.

protected
onRequireDefaultRecords()

Migrations for GroupSubsites data.

protected
updateCMSFields(FieldList $fields)

No description

protected
updateTreeTitle(string $title)

If this group belongs to a subsite, append the subsites title to the group title to make it easy to distinguish in the tree-view of the security admin interface.

protected
augmentSQL(SQLSelect $query, DataQuery|null $dataQuery = null)

Update any requests to limit the results to the current site

protected
onBeforeWrite()

No description

protected
onAfterWrite()

No description

public
alternateCanEdit()

No description

public
providePermissions()

Return a map of permission codes to add to the dropdown shown in the Security section of the CMS.

void
ManyManyList() $Subsite> Subsites()

No description

Details

__construct()

No description

static add_to_class(string $class, string $extensionClass, mixed $args = null)

Called when this extension is added to a particular class

Parameters

string $class
string $extensionClass
mixed $args

setOwner(object $owner)

Set the owner of this extension.

Parameters

object $owner

The owner object

mixed withOwner(mixed $owner, callable $callback, array $args = [])

Temporarily modify the owner. The original owner is ensured to be restored

Parameters

mixed $owner

Owner to set

callable $callback

Callback to invoke

array $args

Args to pass to callback

Return Value

mixed

clearOwner()

Clear the current owner, and restore extension to the state prior to the last setOwner()

T getOwner()

Returns the owner of this extension.

Return Value

T

static string get_classname_without_arguments(string $extensionStr)

Helper method to strip eval'ed arguments from a string that's passed to DataObject::$extensions or Object::add_extension().

Parameters

string $extensionStr

E.g. "Versioned('Stage','Live')"

Return Value

string

Extension classname, e.g. "Versioned"

mixed invokeExtension(object $owner, string $method, array ...$arguments)

Invoke extension point. This will prefer explicit extend prefixed methods.

Parameters

object $owner
string $method
array ...$arguments

Return Value

mixed

protected onRequireDefaultRecords()

Migrations for GroupSubsites data.

protected updateCMSFields(FieldList $fields)

No description

Parameters

FieldList $fields

protected updateTreeTitle(string $title)

If this group belongs to a subsite, append the subsites title to the group title to make it easy to distinguish in the tree-view of the security admin interface.

Parameters

string $title

protected augmentSQL(SQLSelect $query, DataQuery|null $dataQuery = null)

Update any requests to limit the results to the current site

Parameters

SQLSelect $query
DataQuery|null $dataQuery

protected onBeforeWrite()

No description

protected onAfterWrite()

No description

alternateCanEdit()

No description

providePermissions()

Return a map of permission codes to add to the dropdown shown in the Security section of the CMS.

array( 'VIEW_SITE' => 'View the site', );

void ManyManyList() $Subsite> Subsites()

No description

Parameters

) $Subsite> Subsites(

Return Value

void