| Elgg
    Version master
    | 
Go to the source code of this file.
| Functions | |
| elgg_get_entity_class (string $type, string $subtype) | |
| Return the class name registered as a constructor for an entity of a given type and subtype.  More... | |
| elgg_set_entity_class (string $type, string $subtype, string $class='') | |
| Sets class constructor name for entities with given type and subtype.  More... | |
| elgg_get_entity_as_row (int $guid) | |
| Returns a database row from the entities table.  More... | |
| get_entity (int $guid) | |
| Loads and returns an entity object from a guid.  More... | |
| elgg_entity_exists (int $guid) | |
| Does an entity exist?  More... | |
| elgg_get_site_entity () | |
| Get the current site entity.  More... | |
| elgg_get_entities (array $options=[]) | |
| Fetches/counts entities or performs a calculation on their properties.  More... | |
| elgg_count_entities (array $options=[]) | |
| Returns a count of entities.  More... | |
| elgg_list_entities (array $options=[], ?callable $getter=null, ?callable $viewer=null) | |
| Returns a string of rendered entities.  More... | |
| elgg_get_entity_dates (array $options=[]) | |
| Returns a list of months in which entities were updated or created.  More... | |
| elgg_search (array $options=[]) | |
| Returns search results as an array of entities, as a batch, or a count, depending on parameters given.  More... | |
| elgg_get_entity_statistics (array $options=[]) | |
| Return an array reporting the number of various entities in the system.  More... | |
| elgg_entity_has_capability (string $type, string $subtype, string $capability, bool $default=false) | |
| Checks if a capability is enabled for a specified type/subtype.  More... | |
| elgg_entity_enable_capability (string $type, string $subtype, string $capability) | |
| Enables the capability for a specified type/subtype.  More... | |
| elgg_entity_disable_capability (string $type, string $subtype, string $capability) | |
| Disables the capability for a specified type/subtype.  More... | |
| elgg_entity_types_with_capability (string $capability) | |
| Returns an array of type/subtypes with the requested capability enabled.  More... | |
| elgg_count_entities | ( | array | $options = [] | ) | 
Returns a count of entities.
| array | $options | the same options as elgg_get_entities() but forces 'count' to true | 
Definition at line 518 of file entities.php.
| elgg_entity_disable_capability | ( | string | $type, | 
| string | $subtype, | ||
| string | $capability | ||
| ) | 
Disables the capability for a specified type/subtype.
| string | $type | type of the entity | 
| string | $subtype | subtype of the entity | 
| string | $capability | name of the capability to set | 
Definition at line 745 of file entities.php.
| elgg_entity_enable_capability | ( | string | $type, | 
| string | $subtype, | ||
| string | $capability | ||
| ) | 
Enables the capability for a specified type/subtype.
| string | $type | type of the entity | 
| string | $subtype | subtype of the entity | 
| string | $capability | name of the capability to set | 
Definition at line 731 of file entities.php.
| elgg_entity_exists | ( | int | $guid | ) | 
Does an entity exist?
This function checks for the existence of an entity independent of access permissions. It is useful for situations when a user cannot access an entity and it must be determined whether entity has been deleted or the access level has changed.
| int | $guid | The GUID of the entity | 
Definition at line 89 of file entities.php.
| elgg_entity_has_capability | ( | string | $type, | 
| string | $subtype, | ||
| string | $capability, | ||
| bool | $default = false | ||
| ) | 
Checks if a capability is enabled for a specified type/subtype.
| string | $type | type of the entity | 
| string | $subtype | subtype of the entity | 
| string | $capability | name of the capability to check | 
| bool | $default | default value to return if it is not explicitly set | 
Definition at line 717 of file entities.php.
| elgg_entity_types_with_capability | ( | string | $capability | ) | 
Returns an array of type/subtypes with the requested capability enabled.
| string | $capability | name of the capability to set | 
Definition at line 757 of file entities.php.
| elgg_get_entities | ( | array | $options = [] | ) | 
Fetches/counts entities or performs a calculation on their properties.
Note that you can use singulars for most options, e.g. $options['type'] will be normalized to $options['types']
Filter entities by their type and subtype
@option string[] $types @option string[] $subtypes @option string[] $type_subtype_pairs
 $options['types'] = ['object']; $options['subtypes'] = ['blog', 'file']; $options['type_subtype_pairs'] = [ 'object' => ['blog', 'file'], 'group' => [], // all group subtypes 'user' => null, // all user subtypes ]; 
Filter entities by their guid, owner or container
@option int[]|ElggEntity[] $guids @option int[]|ElggEntity[] $owner_guids @option int[]|ElggEntity[] $container_guids
Filter entities that were created, updated or last acted on within certain bounds
@option DateTime|string|int $created_after @option DateTime|string|int $created_before @option DateTime|string|int $updated_after @option DateTime|string|int $updated_before @option DateTime|string|int $last_action_after @option DateTime|string|int $last_action_before @option DateTime|string|int $deleted_after @option DateTime|string|int $deleted_before
 $options['created_after'] = '-1 year'; $options['created_before'] = 'now'; 
Filter entities by their access_id attribute. Note that this filter apply to entities that the user has access to. You can ignore access system using elgg_call()
@option int[] $access_id
This options are used for paginating lists of entities
@option int $limit @option int $offset
Filter entities by their metadata and attributes
The following options will be merged and applied as a metadata pair to @options['metadata_name_value_pairs'] Note metadata names can contain attributes names and will be resolved automatically during query building. @option int[] $metadata_ids @option string[] $metadata_names @option mixed $metadata_values @option DateTime|string|int $metadata_created_after @option DateTime|string|int $metadata_created_before @option bool $metadata_case_sensitive
Metadata name value pairs will be joined by the boolean specified in $metadata_name_value_pairs_operator @option array $metadata_name_value_pairs @option string $metadata_name_value_pairs_operator
In addition to metadata name value pairs, you can specify search pair, which will be merged using OR boolean and will filter entities regardless of metadata name value pairs and their operator
@option array $search_name_value_pairs
 // Search for entities with: // status of draft or unsaved_draft // AND index greater than 5 // AND (title/description containing the word hello OR tags containing the word world) $options['metadata_name_value_pairs'] = [ [ 'name' => 'status', 'value' => ['draft', 'unsaved_draft'], 'operand' => 'IN', 'created_after' => '-1 day', ], [ 'name' => 'index', 'value' => 5, 'operand' => '>=', 'type' => ELGG_VALUE_INTEGER, ] ]; $options['search_name_value_pairs'] = [ [ 'name' => ['title', 'description'], 'value' => 'hello', 'operand' => 'LIKE', 'case_sensitive' => false, ], [ // 'ids' => [55, 56, 57, 58, 59, 60], // only search these 5 metadata rows 'name' => 'tags', 'value' => 'world', 'operand' => 'LIKE', 'case_sensitive' => false, 'created_after' => '-1 day', 'created_before' => 'now', ], ]; 
Filter entities by their annotations
The following options will be merged and applied as an annotation pair to @options['annotation_name_value_pairs'] @option int[] $annotation_ids @option string[] $annotation_names @option mixed $annotation_values @option bool $annotation_case_sensitive @option DateTime|string|int $annotation_created_after @option DateTime|string|int $annotation_created_before @option int[]|ElggEntity[] $annotation_owner_guids @option int[]|ElggEntity[] $annotation_access_ids
Annotation name value pairs will be joined by the boolean specified in $annotation_name_value_pairs_operator @option array $annotation_name_value_pairs @option string $annotation_name_value_pairs_operator
 $options['annotation_name_value_pairs'] = [ [ 'name' => 'likes', 'created_after' => '-1 day', ], [ 'name' => 'rating', 'value' => 5, 'operand' => '>=', 'type' => ELGG_VALUE_INTEGER, ], [ 'name' => 'review', 'value' => 'awesome', 'operand' => 'LIKE', 'type' => ELGG_VALUE_STRING, ] ]; 
Filter entities by their relationships
The following options will be merged and applied as a relationship pair to $options['relationship_name_value_pairs'] @option int[] $relationship_ids @option string[] $relationship @option int[]|ElggEntity[] $relationship_guid @option bool $inverse_relationship @option DateTime|string|int $relationship_created_after @option DateTime|string|int $relationship_created_before @option string $relationship_join_on Column name in the name main table
@option array $relationship_pairs
 // Get all entities that user with guid 25 has friended or been friended by $options['relationship_pairs'] = [ [ 'relationship' => 'friend', 'relationship_guid' => 25, 'inverse_relationship' => true, ], [ 'relationship' => 'friend', 'relationship_guid' => 25, 'inverse_relationship' => false, ], ]; 
You can specify sorting options using ONE of the following options
NOTE: Some order by options only work when fetching entities and not from derived function (eg elgg_get_annotations, elgg_get_relationships)
Order by a calculation performed on annotation name value pairs $option array annotation_sort_by_calculation e.g. avg, max, min, sum
Order by arbitrary clauses @option array $order_by
Order by attribute/annotation/metadata @option sort_by an array of sorting definitions
$sort_by = new \Elgg\Database\Clauses\EntitySortByClause(); $sort_by->property = 'private'; $sort_by->property_type = 'metadata'; $sort_by->join_type = 'left';
$fallback = new \Elgg\Database\Clauses\OrderByClause('e.time_created', 'desc');
$options['order_by'] = [ $sort_by, $fallback, ];
// single sort_by option $options['sort_by'] = [ 'property_type' => 'attribute', 'property' => 'time_created', 'direction' => 'ASC', ];
// multiple sort_by options $options['sort_by'] = [ [ 'property_type' => 'attribute', 'property' => 'time_created', 'direction' => 'ASC', ], [ 'property_type' => 'metadata', 'property' => 'name', 'direction' => 'DESC', ], [ 'property_type' => 'annotation', 'property' => 'priority', 'direction' => 'ASC', 'signed' => true, ], [ 'property_type' => 'relationship', 'property' => 'members', 'direction' => 'ASC', 'inverse_relationship' => true, ], ]; 
Performs a calculation on a set of entities that match all the criteria If any of these are specific, the return of this function will be int or float
Return total number of entities @option bool $count
Perform a calculation on a set of entity's annotations using a numeric sql function If specified, the number of annotation name value pairs can not be more than 1, or they must be merged using OR operator @option string $annotation_calculation e.g. avg, max, min, sum
Perform a calculation on a set of entity's metadata using a numeric sql function If specified, the number of metadata name value pairs can not be more than 1, or they must be merged using OR operator @option string $metadata_calculation e.g. avg, max, min, sum
@option array $selects  $options['selects'] = [ 'e.last_action AS last_action', function(QueryBuilder $qb, $main_alias) { $joined_alias = $qb->joinMetadataTable($main_alias, 'guid', 'status'); return "$joined_alias.value AS status"; } ]; 
@option array $joins  $on = function(QueryBuilder $qb, $joined_alias, $main_alias) { return $qb->compare("$joined_alias.user_guid", '=', "$main_alias.guid"); }; $options['joins'] = [ new JoinClause('access_collections_membership', 'acm', $on); ]; 
@option array $group_by @option array $having
 $options['group_by'] = [ function(QueryBuilder $qb, $main_alias) { return "$main_alias.guid"; } ]; $options['having'] = [ function(QueryBuilder $qb, $main_alias) { return $qb->compare("$main_alias.guid", '>=', 50, ELGG_VALUE_INTEGER); } ]; 
@option array $where  $options['wheres'] = [ function(QueryBuilder $qb, $main_alias) { return $qb->merge([ $qb->compare("$main_alias.guid", '>=', 50, ELGG_VALUE_INTEGER), $qb->compare("$main_alias.guid", '<=', 250, ELGG_VALUE_INTEGER), ], 'OR'); } ]; 
@option bool $distinct If set to false, Elgg will drop the DISTINCT clause from the MySQL query, which will improve performance in some situations. Avoid setting this option without a full understanding of the underlying SQL query Elgg creates. Default: true @option callable|false $callback A callback function to pass each row through Default: _elgg_services()->entityTable->rowToElggStar() @option bool $preload_owners If set to true, this function will preload all the owners of the returned entities resulting in better performance when displaying entities owned by several users Default: false @option bool $preload_containers If set to true, this function will preload all the containers of the returned entities resulting in better performance when displaying entities contained by several users/groups Default: false @option bool $batch If set to true, an \ElggBatch object will be returned instead of an array. Default: false @option bool $batch_inc_offset If "batch" is used, this tells the batch to increment the offset on each fetch. This must be set to false if you delete the batched results. Default: true @option int $batch_size If "batch" is used, this is the number of entities/rows to pull in before requesting more. Default: 25
| array | $options | Options | 
Definition at line 507 of file entities.php.
| elgg_get_entity_as_row | ( | int | $guid | ) | 
Returns a database row from the entities table.
@tip Use get_entity() to return the fully loaded entity.
| int | $guid | The GUID of the object to extract | 
Definition at line 57 of file entities.php.
| elgg_get_entity_class | ( | string | $type, | 
| string | $subtype | ||
| ) | 
Return the class name registered as a constructor for an entity of a given type and subtype.
| string | $type | The type | 
| string | $subtype | The subtype | 
Definition at line 19 of file entities.php.
| elgg_get_entity_dates | ( | array | $options = [] | ) | 
Returns a list of months in which entities were updated or created.
@tip Use this to generate a list of archives by month for when entities were added or updated.
| array | $options | all entity options supported by { | 
Definition at line 616 of file entities.php.
| elgg_get_entity_statistics | ( | array | $options = [] | ) | 
Return an array reporting the number of various entities in the system.
| array | $options | additional options | 
Definition at line 661 of file entities.php.
| elgg_get_site_entity | ( | ) | 
Get the current site entity.
Definition at line 99 of file entities.php.
| elgg_list_entities | ( | array | $options = [], | 
| ?callable | $getter = null, | ||
| ?callable | $viewer = null | ||
| ) | 
Returns a string of rendered entities.
Displays list of entities with formatting specified by the entity view.
@tip Pagination is handled automatically.
| array | $options | Any options from $getter options plus: 
 | 
| null | callable | $getter | The entity getter function to use to fetch the entities. | 
| null | callable | $viewer | The function to use to view the entity list. | 
Definition at line 551 of file entities.php.
| elgg_search | ( | array | $options = [] | ) | 
Returns search results as an array of entities, as a batch, or a count, depending on parameters given.
| array | $options | Search parameters Accepts all options supported by elgg_get_entities() | 
@option string $query Search query @option string $type Entity type. Required if no search type is set @option string $search_type Custom search type. Required if no type is set @option array $fields An array of fields to search in, supported keys are [ 'attributes' => ['some attribute', 'some other attribute'], 'metadata' => ['some metadata name', 'some other metadata name'], 'annotations' => ['some annotation name', 'some other annotation name'], ] @option bool $partial_match Allow partial matches, e.g. find 'elgg' when search for 'el' @option bool $tokenize Break down search query into tokens, e.g. find 'elgg has been released' when searching for 'elgg released'
Definition at line 644 of file entities.php.
| elgg_set_entity_class | ( | string | $type, | 
| string | $subtype, | ||
| string | $class = '' | ||
| ) | 
Sets class constructor name for entities with given type and subtype.
By default entities are loaded as one of the 4 parent objects:
Entity classes for subtypes should extend the base class for entity type, e.g. ElggBlog must extend ElggObject
| string | $type | Entity type | 
| string | $subtype | Entity subtype | 
| string | $class | Class name for the object Can be empty to reset previously declared class name | 
Definition at line 42 of file entities.php.
| get_entity | ( | int | $guid | ) | 
Loads and returns an entity object from a guid.
| int | $guid | The GUID of the entity | 
Definition at line 68 of file entities.php.