Moodle APIs 4.3
Moodle 4.3.6 (Build: 20240812)
|
Context maintenance and helper methods. More...
Public Member Functions | |
__get ($name) | |
Magic method getter, redirects to read only values. | |
__isset ($name) | |
Full support for isset on our magic read only properties. | |
__set ($name, $value) | |
Magic setter method, we do not want anybody to modify properties from the outside. | |
__unset ($name) | |
All properties are read only, sorry. | |
delete () | |
Delete the context content and the context record itself. | |
delete_capabilities () | |
Unassign all capabilities from a context. | |
delete_content () | |
Delete all data linked to content, do not delete the context record itself. | |
get_capabilities (string $sort=self::DEFAULT_CAPABILITY_SORT) | |
Returns array of relevant context capability records. | |
get_child_contexts () | |
Recursive function which, given a context, find all its children context ids. | |
get_context_name ($withprefix=true, $short=false, $escape=true) | |
Returns human readable context identifier. | |
get_course_context ($strict=true) | |
Is this context part of any course? If yes return course context. | |
get_parent_context () | |
Returns parent context. | |
get_parent_context_ids ($includeself=false) | |
Returns parent context ids of this context in reversed order, i.e. | |
get_parent_context_paths ($includeself=false) | |
Returns parent context paths of this context. | |
get_parent_contexts ($includeself=false) | |
Returns parent contexts of this context in reversed order, i.e. | |
get_url () | |
Returns the most relevant URL for this context. | |
getIterator () | |
Create an iterator because magic vars can't be seen by 'foreach'. | |
is_child_of (context $possibleparent, bool $includeself) | |
Determine if the current context is a child of the possible parent. | |
is_locked () | |
Whether the current context is locked. | |
is_parent_of (context $possiblechild, bool $includeself) | |
Determine if the current context is a parent of the possible child. | |
mark_dirty () | |
Mark a context as dirty (with timestamp) so as to force reloading of the context. | |
reload_if_dirty () | |
Reset all cached permissions and definitions if the necessary. | |
reset_paths ($rebuild=true) | |
Remove all context path info and optionally rebuild it. | |
set_locked (bool $locked) | |
Set whether this context has been locked or not. | |
update_moved (context $newparent) | |
Update context info after moving context in the tree structure. | |
Static Public Member Functions | |
static | build_all_paths ($force=false) |
Rebuild paths and depths in all context levels. | |
static | cleanup_instances () |
Remove stale contexts that belonged to deleted instances. | |
static | create_instances ($contextlevel=null, $buildpaths=true) |
Create all context instances at the given level and above. | |
static | delete_instance ($contextlevel, $instanceid) |
Delete context instance. | |
static | get_all_levels () |
Returns a list of all context levels. | |
static | get_child_levels (int $parentlevel) |
Get list of possible child levels for given level. | |
static | get_class_for_level (int $contextlevel) |
Returns a class name of the context level class. | |
static | get_compatible_levels (string $archetype) |
Returns context levels that compatible with role archetype assignments. | |
static | get_level_name ($contextlevel) |
Returns the name of specified context level. | |
static | get_navigation_filter_context (?context $context) |
Gets the current context to be used for navigation tree filtering. | |
static | get_possible_parent_levels () |
Returns list of all possible parent context levels, it may include itself if nesting is allowed. | |
static | get_preload_record_columns ($tablealias) |
Returns all fields necessary for context preloading from user $rec. | |
static | get_preload_record_columns_sql ($tablealias) |
Returns all fields necessary for context preloading from user $rec. | |
static | get_short_name () |
Returns short context name. | |
static | instance_by_id ($id, $strictness=MUST_EXIST) |
Get a context instance as an object, from a given context id. | |
static | parse_external_level ($extlevel) |
Converts legacy context_* class name to new class name. | |
static | preload_contexts_by_id (array $contextids) |
Preload a set of contexts using their contextid. | |
static | preload_course ($courseid) |
Preload all contexts instances from course. | |
static | preload_from_record (stdClass $rec) |
Preloads context cache with information from db record and strips the cached info. | |
static | reset_caches () |
Resets the cache to remove all data. | |
static | reset_levels () |
Reset internal context levels array. | |
static | resolve_behat_reference (string $level, string $reference) |
Resolve reference to context used in behat feature files. | |
Static Protected Member Functions | |
static | build_paths ($force) |
Rebuild context paths and depths at context level. | |
static | cache_add (context $context) |
Adds a context to the cache. | |
static | cache_get ($contextlevel, $instance) |
Gets a context from the cache. | |
static | cache_get_by_id ($id) |
Gets a context from the cache based on its id. | |
static | cache_remove (context $context) |
Removes a context from the cache. | |
static | create_instance_from_record (stdClass $record) |
This function is also used to work around 'protected' keyword problems in context_helper. | |
static | create_level_instances () |
Create missing context instances at given level. | |
static | get_behat_reference_columns () |
Returns list of columns that can be used from behat to look up context by reference. | |
static | get_cleanup_sql () |
Returns sql necessary for purging of stale context instances. | |
static | get_compatible_role_archetypes () |
Returns list of all role archetypes that are compatible with role assignments in context level. | |
static | get_instance_table () |
Returns context instance database name. | |
static | insert_context_record ($contextlevel, $instanceid, $parentpath) |
Utility method for context creation. | |
static | merge_context_temp_table () |
Copy prepared new contexts from temp table to context table, we do this in db specific way for perf reasons only. | |
Protected Attributes | |
int | $_contextlevel |
The context level Can be accessed publicly through $context->contextlevel One of CONTEXT_* e.g. | |
int | $_depth |
The depth of the context in relation to parent contexts Can be accessed publicly through $context->depth. | |
int | $_id |
The context id Can be accessed publicly through $context->id. | |
int | $_instanceid |
Id of the item this context is related to e.g. | |
int | $_locked |
Whether this context is locked or not. | |
string | $_path |
The path to the context always starting from the system context Can be accessed publicly through $context->path. | |
string const | DEFAULT_CAPABILITY_SORT = 'contextlevel, component, name' |
Default sorting of capabilities in {. | |
Static Protected Attributes | |
static int | $cache_count = 0 |
Context count Why do we do count contexts? Because count($array) is horribly slow for large arrays. | |
static array | $cache_preloaded = array() |
Context caching info. | |
static context system | $systemcontext = null |
The system context once initialised. | |
Context maintenance and helper methods.
This is "extends context" is a bloody hack that tires to work around the deficiencies in the "protected" keyword in PHP, this helps us to hide all the internals of context level implementation from the rest of code, the code completion returns what developers need.
Thank you Tim Hunt for helping me with this nasty trick.
|
inherited |
Magic method getter, redirects to read only values.
string | $name |
mixed |
|
inherited |
Full support for isset on our magic read only properties.
string | $name |
bool |
|
inherited |
Magic setter method, we do not want anybody to modify properties from the outside.
string | $name | |
mixed | $value |
|
inherited |
All properties are read only, sorry.
string | $name |
|
static |
Rebuild paths and depths in all context levels.
bool | $force | false means add missing only |
void |
|
staticprotectedinherited |
Rebuild context paths and depths at context level.
bool | $force |
void |
Reimplemented in core\context\course, core\context\coursecat, core\context\module, core\context\system, and core\context\user.
|
staticprotectedinherited |
Adds a context to the cache.
If the cache is full, discards a batch of older entries.
context | $context | New context to add |
void |
|
staticprotectedinherited |
Gets a context from the cache.
int | $contextlevel | Context level |
int | $instance | Instance ID |
context|bool | Context or false if not in cache |
|
staticprotectedinherited |
Gets a context from the cache based on its id.
int | $id | Context ID |
context|bool | Context or false if not in cache |
|
staticprotectedinherited |
Removes a context from the cache.
context | $context | Context object to remove |
void |
|
static |
Remove stale contexts that belonged to deleted instances.
Ideally all code should cleanup contexts properly, unfortunately accidents happen...
void |
|
staticprotectedinherited |
This function is also used to work around 'protected' keyword problems in context_helper.
stdClass | $record |
context | instance |
|
static |
Create all context instances at the given level and above.
int | $contextlevel | null means all levels |
bool | $buildpaths |
void |
|
staticprotectedinherited |
Create missing context instances at given level.
void |
Reimplemented in core\context\block, core\context\course, core\context\coursecat, core\context\module, core\context\system, and core\context\user.
|
static |
Delete context instance.
int | $contextlevel | |
int | $instanceid |
void |
|
static |
Returns a list of all context levels.
array | int=>string (level=>level class name) |
|
staticprotectedinherited |
Returns list of columns that can be used from behat to look up context by reference.
array | list of column names from instance table |
Reimplemented in core\context\course, core\context\coursecat, core\context\module, and core\context\user.
|
abstractinherited |
Returns array of relevant context capability records.
string | $sort | SQL order by snippet for sorting returned capabilities sensibly for display |
array |
Reimplemented in core\context\block, core\context\course, core\context\coursecat, core\context\module, core\context\system, and core\context\user.
|
inherited |
Recursive function which, given a context, find all its children context ids.
For course category contexts it will return immediate children and all subcategory contexts. It will NOT recurse into courses or subcategories categories. If you want to do that, call it on the returned courses/categories.
When called for a course context, it will return the modules and blocks displayed in the course page and blocks displayed on the module pages.
If called on a user/course/module context it will populate the cache with the appropriate contexts ;-)
array | Array of child records |
Reimplemented in core\context\block, core\context\coursecat, and core\context\system.
|
static |
Get list of possible child levels for given level.
int | $parentlevel |
int[] | list of context levels that my be children of given context level. |
|
static |
Returns a class name of the context level class.
int | $contextlevel | (CONTEXT_SYSTEM, etc.) |
string | class name of the context class |
coding_exception | if level does not exist |
|
staticprotectedinherited |
Returns sql necessary for purging of stale context instances.
string | cleanup SQL |
Reimplemented in core\context\course, core\context\coursecat, core\context\module, core\context\system, and core\context\user.
|
static |
Returns context levels that compatible with role archetype assignments.
string | $archetype |
array |
|
staticprotectedinherited |
Returns list of all role archetypes that are compatible with role assignments in context level.
string[] |
Reimplemented in core\context\course, core\context\coursecat, core\context\module, and core\context\system.
|
inherited |
Returns human readable context identifier.
boolean | $withprefix | whether to prefix the name of the context with the type of context, e.g. User, Course, Forum, etc. |
boolean | $short | whether to use the short name of the thing. Only applies to course contexts |
boolean | $escape | Whether the returned name of the thing is to be HTML escaped or not. |
string | the human readable context name. |
Reimplemented in core\context\block, core\context\course, core\context\coursecat, core\context\module, core\context\system, and core\context\user.
|
inherited |
Is this context part of any course? If yes return course context.
bool | $strict | true means throw exception if not found, false means return false if not found |
context\course|false | context of the enclosing course, null if not found or exception |
Reimplemented in core\context\block, core\context\course, and core\context\module.
|
staticprotectedinherited |
Returns context instance database name.
string|null | table name for all levels except system. |
Reimplemented in core\context\course, core\context\coursecat, core\context\module, and core\context\user.
|
static |
Returns the name of specified context level.
int | $contextlevel |
string | name of the context level |
|
static |
Gets the current context to be used for navigation tree filtering.
context | null | $context | The current context to be checked against. |
context|null | the context that navigation tree filtering should use. |
|
inherited |
Returns parent context.
context|false |
|
inherited |
Returns parent context ids of this context in reversed order, i.e.
parent first, then grand parent, etc.
bool | $includeself | true means include self too |
array | of context ids |
|
inherited |
Returns parent context paths of this context.
bool | $includeself | true means include self too |
array | of context paths |
|
inherited |
Returns parent contexts of this context in reversed order, i.e.
parent first, then grand parent, etc.
bool | $includeself | true means include self too |
array | of context instances |
|
staticinherited |
Returns list of all possible parent context levels, it may include itself if nesting is allowed.
int[] |
Reimplemented in core\context\block, core\context\course, core\context\coursecat, core\context\module, core\context\system, and core\context\user.
|
static |
Returns all fields necessary for context preloading from user $rec.
This helps with performance when dealing with hundreds of contexts.
string | $tablealias | context table alias in the query |
array | (table.column=>alias, ...) |
|
static |
Returns all fields necessary for context preloading from user $rec.
This helps with performance when dealing with hundreds of contexts.
string | $tablealias | context table alias in the query |
string |
|
staticinherited |
Returns short context name.
string |
Reimplemented in core\context\block, core\context\course, core\context\coursecat, core\context\module, core\context\system, and core\context\user.
|
abstractinherited |
Returns the most relevant URL for this context.
moodle_url |
Reimplemented in core\context\block, core\context\course, core\context\coursecat, core\context\module, core\context\system, and core\context\user.
|
inherited |
Create an iterator because magic vars can't be seen by 'foreach'.
Now we can convert context object to array using convert_to_array(), and feed it properly to json_encode().
|
staticprotectedinherited |
Utility method for context creation.
int | $contextlevel | |
int | $instanceid | |
string | $parentpath |
stdClass | context record |
|
staticinherited |
Get a context instance as an object, from a given context id.
int | $id | context id |
int | $strictness | IGNORE_MISSING means compatible mode, false returned if record not found, debug message if more found; MUST_EXIST means throw exception if no record found |
context|bool | the context object or false if not found |
|
inherited |
Determine if the current context is a child of the possible parent.
context | $possibleparent | |
bool | $includeself | Whether to check the current context |
bool |
|
inherited |
Whether the current context is locked.
bool |
|
inherited |
Determine if the current context is a parent of the possible child.
context | $possiblechild | |
bool | $includeself | Whether to check the current context |
bool |
|
static |
Converts legacy context_* class name to new class name.
NOTE: this is needed for external API which uses short context names.
int | string | $extlevel |
string|null | context class name or null if not found |
|
static |
Preload a set of contexts using their contextid.
array | $contextids |
|
static |
Preload all contexts instances from course.
To be used if you expect multiple queries for course activities...
int | $courseid |
|
static |
Preloads context cache with information from db record and strips the cached info.
The db request has to contain all columns from context_helper\get_preload_record_columns().
stdClass | $rec |
void | This is intentional. See MDL-37115. You will need to get the context in the normal way, but it is now cached, so that will be fast. |
Reimplemented from core\context.
|
inherited |
Reset all cached permissions and definitions if the necessary.
void |
|
static |
Resets the cache to remove all data.
Reimplemented from core\context.
|
inherited |
Remove all context path info and optionally rebuild it.
bool | $rebuild |
void |
|
static |
Resolve reference to context used in behat feature files.
string | $level | |
string | $reference |
context|null |
|
inherited |
Set whether this context has been locked or not.
bool | $locked |
$this |
Reimplemented in core\context\system.
|
inherited |
Update context info after moving context in the tree structure.
context | $newparent |
void |
|
protectedinherited |
The context level Can be accessed publicly through $context->contextlevel One of CONTEXT_* e.g.
CONTEXT_COURSE, CONTEXT_MODULE
|
protectedinherited |
Id of the item this context is related to e.g.
COURSE_CONTEXT => course.id Can be accessed publicly through $context->instanceid
|
protectedinherited |
Whether this context is locked or not.
Can be accessed publicly through $context->locked.
|
protectedinherited |
Default sorting of capabilities in {.