class AcsfDuplicationScrubCommentStorage in Acquia Cloud Site Factory Connector 8
Same name and namespace in other branches
- 8.2 src/Event/AcsfDuplicationScrubCommentStorage.php \Drupal\acsf\Event\AcsfDuplicationScrubCommentStorage
Comment storage class (using a SQL backend) which ignores load failures.
The idea of this class is to prefer scrubbing over consistency; we don't care much about load failures since the only reason for loading comments is being able to delete them.
Hierarchy
- class \Drupal\Core\Entity\EntityHandlerBase uses DependencySerializationTrait, StringTranslationTrait
- class \Drupal\Core\Entity\EntityStorageBase implements EntityHandlerInterface, EntityStorageInterface
- class \Drupal\Core\Entity\ContentEntityStorageBase implements ContentEntityStorageInterface, DynamicallyFieldableEntityStorageInterface uses DeprecatedServicePropertyTrait
- class \Drupal\Core\Entity\Sql\SqlContentEntityStorage implements EntityBundleListenerInterface, DynamicallyFieldableEntityStorageSchemaInterface, SqlEntityStorageInterface
- class \Drupal\comment\CommentStorage implements CommentStorageInterface
- class \Drupal\acsf\Event\AcsfDuplicationScrubCommentStorage
- class \Drupal\comment\CommentStorage implements CommentStorageInterface
- class \Drupal\Core\Entity\Sql\SqlContentEntityStorage implements EntityBundleListenerInterface, DynamicallyFieldableEntityStorageSchemaInterface, SqlEntityStorageInterface
- class \Drupal\Core\Entity\ContentEntityStorageBase implements ContentEntityStorageInterface, DynamicallyFieldableEntityStorageInterface uses DeprecatedServicePropertyTrait
- class \Drupal\Core\Entity\EntityStorageBase implements EntityHandlerInterface, EntityStorageInterface
Expanded class hierarchy of AcsfDuplicationScrubCommentStorage
File
- src/
Event/ AcsfDuplicationScrubCommentStorage.php, line 14
Namespace
Drupal\acsf\EventView source
class AcsfDuplicationScrubCommentStorage extends CommentStorage {
/**
* Invokes hook_entity_storage_load() while catching exceptions thrown.
*
* Unlike SqlContentEntityStorage's implementation, this prevents a
* hook_comment_storage_load() implementation somewhere in contrib from
* throwing exceptions while loading orphaned comments, and causing
* Wip failures.
*
* Issue https://www.drupal.org/node/2614720 was filed and this method was
* written assuming that Drupal Core itself was throwing exceptions which
* should be caught, while loading orphaned comments. Unfortunately that's not
* the case: RDF module throws a fatal error (not an exception). So now this
* method does not solve a known problem; it's just a semi random extra
* precaution in case a contrib module does funny things. This may be deleted
* if we value minimizing code over supporting random theoretical failures.
*
* @param \Drupal\Core\Entity\ContentEntityInterface[] $entities
* List of entities, keyed on the entity ID.
*/
protected function invokeStorageLoadHook(array &$entities) {
if (!empty($entities)) {
// Call hook_entity_storage_load().
foreach ($this
->moduleHandler()
->getImplementations('entity_storage_load') as $module) {
$function = $module . '_entity_storage_load';
try {
$function($entities, $this->entityTypeId);
} catch (\Exception $e) {
// Don't care.
}
}
// Call hook_TYPE_storage_load().
foreach ($this
->moduleHandler()
->getImplementations($this->entityTypeId . '_storage_load') as $module) {
$function = $module . '_' . $this->entityTypeId . '_storage_load';
try {
$function($entities);
} catch (\Exception $e) {
// Don't care.
}
}
}
}
/**
* Deletes orphaned comments without having to load the full entities first.
*
* The regular EntityStorageInterface::delete() expects fully loaded entities
* as arguments but -because of the above- we cannot load orphaned comments.
* So we'll query for IDs, and mimic delete-related methods so they need
* IDs as an argument instead of full entities.
*
* @param int $limit
* (optional) Maximum number of comments to delete in one go.
* @param int $already_processed_min_id
* (optional) If specified and >0, only delete items with an ID lower than
* this. 0 is interpreted as "no deletion is necessary".
*
* @return array
* The orphaned items that were found, and possibly deleted.
*/
public function deleteOrphanedItems($limit = 0, $already_processed_min_id = -1) {
$cids = $this
->getOrphanedItems($limit, $already_processed_min_id);
if ($cids) {
// First, check if these comments have children which are not orphaned
// (i.e. the commented node and user do exist; the parent comment is only
// orphaned because its parent does not exist). If so, add these to the
// list. (These cannot be loaded without generating fatal errors either,
// because rdf_comment_storage_load() calls $comment->getParentComment()
// which tries to load the whole parent comment which recursively etc.
// until rdf_comment_storage_load() processes the orphaned parent and
// crashes.)
$uid_and_entity_ok = array_filter($cids);
$child_cids = [];
if ($uid_and_entity_ok) {
// Database statement copied/changed from $this->getChildCids():
$child_cids = $this->database
->select('comment_field_data', 'c')
->fields('c', [
'cid',
])
->condition('pid', array_keys($uid_and_entity_ok), 'IN')
->condition('default_langcode', 1)
->execute()
->fetchCol();
}
$cids = array_merge(array_keys($cids), $child_cids);
// Mimic the parts of CommentStorage::delete() that are possible.
// The call structure:
// - Comment::preDelete: is empty.
// - invokeHook('predelete'): needs entity.
// - doDelete():
// - invokeFieldMethod('delete'): needs entity.
// - doDeleteFieldItems(): can be mimicked.
$this
->doDeleteFieldItemsById($cids);
// - resetCache()
$this
->resetCache($cids);
// - Comment::postDelete:
// - deletes child comments: done above.
// - deletes statistics: copying CommentStatistics::delete() code here:
$this->database
->delete('comment_entity_statistics')
->condition('entity_id', $cids, 'IN')
->condition('entity_type', 'comment')
->execute();
// - invokeHook('postdelete'): needs entity.
}
return $cids;
}
/**
* Gets a list of orphaned comment IDs.
*
* 'orphaned' means having an invalid user, commented entity, or parent
* comment. "Commented entity" is only checked for nodes (not other entity
* types).
*
* @param int $limit
* (optional) Maximum number of comment IDs to fetch in one go.
* @param int $already_processed_min_id
* (optional) If specified and >0, only fetch IDs lower than this. 0 is
* interpreted as "no action is necessary".
*
* @return array
* An indexed array indexed by the relevant comment IDs, with a value of 1
* if the user and commented entity are valid (so only the parent comment
* is wrong), and 0 otherwise.
*/
protected function getOrphanedItems($limit = 0, $already_processed_min_id = -1) {
if ($already_processed_min_id == 0) {
return [];
}
$where = "u.uid IS NULL OR (n.nid IS NULL and c.entity_type = 'node')\n OR (pc.cid IS NULL AND c.pid > 0)";
$args = [];
if ($already_processed_min_id > 0) {
$where = "({$where}) AND c.cid < :processed";
$args[':processed'] = $already_processed_min_id;
}
$query = "SELECT c.cid, CASE WHEN u.uid IS NULL OR (n.nid IS NULL and c.entity_type = 'node') THEN 0 ELSE 1 END AS validref\n FROM {comment_field_data} c\n LEFT JOIN {users} u ON c.uid = u.uid\n LEFT JOIN {node} n ON c.entity_id = n.nid\n LEFT JOIN {comment} pc ON c.pid = pc.cid\n WHERE {$where} ORDER BY c.cid DESC";
$statement = $limit ? $this->database
->queryRange($query, 0, $limit, $args) : $this->database
->query($query, $args);
return $statement
->fetchAllKeyed();
}
/**
* Deletes entity field values from the storage.
*
* This is a near copy of SqlContentEntityStorage::doDeleteFieldItems() except
* it takes ids as argument instead of entities.
*
* @param array $ids
* The entity ids.
*/
protected function doDeleteFieldItemsById(array $ids) {
$this->database
->delete($this->entityType
->getBaseTable())
->condition($this->idKey, $ids, 'IN')
->execute();
if ($this->revisionTable) {
$this->database
->delete($this->revisionTable)
->condition($this->idKey, $ids, 'IN')
->execute();
}
if ($this->dataTable) {
$this->database
->delete($this->dataTable)
->condition($this->idKey, $ids, 'IN')
->execute();
}
if ($this->revisionDataTable) {
$this->database
->delete($this->revisionDataTable)
->condition($this->idKey, $ids, 'IN')
->execute();
}
// For backwards compatibility (Drupal >=8.5.0 and <8.7.0).
// This class extends CommentStorage which extends SqlContentEntityStorage
// which extends ContentEntityStorageBase:
// - before Drupal 8.7, ->getBundleInfo() is reachable through
// ContentEntityStorageBase -> entityManager -> entityTypeBundleInfo;
// - starting with Drupal 8.7 ->getBundleInfo() is reachable through
// ContentEntityStorageBase -> entityTypeBundleInfo.
// The EntityManager class is deprecated; lately the purpose of this class
// was only to delegate all method calls to the appropriate service.
//
// The complete removal of the EntityManager class will happen before
// Drupal 9.0.0.
// Although we noticed that in Drupal 8.7.0, core developers started ripping
// off the usage of EntityManager from various entity classes, like:
// -- CommentStorage.php
// -- SqlContentEntityStorage.php
// -- ContentEntityStorageBase.php
// which, starting from Drupal 8.7.0 have the necessary service classes
// properly injected.
// @see https://www.drupal.org/project/drupal/issues/3025427
// @see https://git.drupalcode.org/project/drupal/commit/81915a9
// - the core commit which contains these changes.
// Keep using EntityManager is not an option since it is deprecated, and for
// Drupal versions >=8.5.0 and <8.7.0 we need to pull in the service in the
// non-elegant way.
$entityTypeBundleInfo = $this->entityTypeBundleInfo ?: \Drupal::service('entity_type.bundle.info');
// Delete as many dedicated field tables as we can find. This is slightly
// different from the original: since we don't know the original entities'
// bundles, we loop through all bundles that exist for a comment.
foreach (array_keys($entityTypeBundleInfo
->getBundleInfo('comment')) as $bundle) {
$this
->deleteFromDedicatedTablesById($ids, $bundle);
}
}
/**
* Deletes values of fields in dedicated tables for all revisions.
*
* This is a lookalike of SqlContentEntityStorage::deleteFromDedicatedTables()
* which takes an array of ids + a bundle as arguments, instead of a single
* entity.
*
* @param array $ids
* The entity ids.
* @param string $bundle
* A bundle id; must be an existing bundle for 'comment'.
*/
protected function deleteFromDedicatedTablesById(array $ids, $bundle) {
$table_mapping = $this
->getTableMapping();
// For backwards compatibility (Drupal >=8.5.0 and <8.7.0).
// This class extends CommentStorage which extends SqlContentEntityStorage
// which extends ContentEntityStorageBase:
// - before Drupal 8.7.0, ->getFieldDefinitions() is reachable through
// ContentEntityStorageBase -> entityManager -> entityFieldManager;
// - starting with Drupal 8.7.0 ->getFieldDefinitions() is reachable through
// ContentEntityStorageBase -> entityFieldManager.
// The EntityManager class is deprecated; lately the purpose of this class
// was only to delegate all method calls to the appropriate service.
//
// The complete removal of the EntityManager class will happen before
// Drupal 9.0.0.
// Although we noticed that in Drupal 8.7.0, core developers started ripping
// off the usage of EntityManager from various entity classes, like:
// -- CommentStorage.php
// -- SqlContentEntityStorage.php
// -- ContentEntityStorageBase.php
// which, starting from Drupal 8.7.0 have the necessary service classes
// properly injected.
// @see https://www.drupal.org/project/drupal/issues/3025427
// @see https://git.drupalcode.org/project/drupal/commit/81915a9
// - the core commit which contains these changes.
// Keep using EntityManager is not an option since it is deprecated, and for
// Drupal versions >=8.5.0 and <8.7.0 we need to pull in the service in the
// non-elegant way.
$entityFieldManager = $this->entityFieldManager ?: \Drupal::service('entity_field.manager');
foreach ($entityFieldManager
->getFieldDefinitions('comment', $bundle) as $field_definition) {
/** @var \Drupal\Core\Field\FieldStorageDefinitionInterface $field_definition */
$storage_definition = $field_definition
->getFieldStorageDefinition();
if (!$table_mapping
->requiresDedicatedTableStorage($storage_definition)) {
continue;
}
$table_name = $table_mapping
->getDedicatedDataTableName($storage_definition);
$revision_name = $table_mapping
->getDedicatedRevisionTableName($storage_definition);
$this->database
->delete($table_name)
->condition('entity_id', $ids, 'IN')
->execute();
if ($this->entityType
->isRevisionable()) {
$this->database
->delete($revision_name)
->condition('entity_id', $ids, 'IN')
->execute();
}
}
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
AcsfDuplicationScrubCommentStorage:: |
protected | function | Deletes values of fields in dedicated tables for all revisions. | |
AcsfDuplicationScrubCommentStorage:: |
public | function | Deletes orphaned comments without having to load the full entities first. | |
AcsfDuplicationScrubCommentStorage:: |
protected | function | Deletes entity field values from the storage. | |
AcsfDuplicationScrubCommentStorage:: |
protected | function | Gets a list of orphaned comment IDs. | |
AcsfDuplicationScrubCommentStorage:: |
protected | function |
Invokes hook_entity_storage_load() while catching exceptions thrown. Overrides ContentEntityStorageBase:: |
|
CommentStorage:: |
protected | property | The current user. | |
CommentStorage:: |
public static | function |
Instantiates a new instance of this entity handler. Overrides SqlContentEntityStorage:: |
|
CommentStorage:: |
public | function |
Gets the comment ids of the passed comment entities' children. Overrides CommentStorageInterface:: |
|
CommentStorage:: |
public | function |
Gets the display ordinal or page number for a comment. Overrides CommentStorageInterface:: |
|
CommentStorage:: |
public | function |
Gets the maximum encoded thread value for the top level comments. Overrides CommentStorageInterface:: |
|
CommentStorage:: |
public | function |
Gets the maximum encoded thread value for the children of this comment. Overrides CommentStorageInterface:: |
|
CommentStorage:: |
public | function |
Calculates the page number for the first new comment. Overrides CommentStorageInterface:: |
|
CommentStorage:: |
public | function |
Returns the number of unapproved comments. Overrides CommentStorageInterface:: |
|
CommentStorage:: |
public | function |
To display threaded comments in the correct order we keep a 'thread' field
and order by that value. This field keeps this data in
a way which is easy to update and convenient to use. Overrides CommentStorageInterface:: |
|
CommentStorage:: |
public | function |
Constructs a CommentStorage object. Overrides SqlContentEntityStorage:: |
|
ContentEntityStorageBase:: |
protected | property | The entity bundle key. | |
ContentEntityStorageBase:: |
protected | property | Cache backend. | |
ContentEntityStorageBase:: |
protected | property | ||
ContentEntityStorageBase:: |
protected | property | The entity field manager service. | |
ContentEntityStorageBase:: |
protected | property | The entity bundle info. | |
ContentEntityStorageBase:: |
protected | property | Stores the latest revision IDs for entities. | |
ContentEntityStorageBase:: |
protected | function | Ensures integer entity key values are valid. | |
ContentEntityStorageBase:: |
public | function |
Creates a new revision starting off from the specified entity object. Overrides TranslatableRevisionableStorageInterface:: |
|
ContentEntityStorageBase:: |
public | function |
Constructs a new entity translation object, without permanently saving it. Overrides TranslatableStorageInterface:: |
|
ContentEntityStorageBase:: |
public | function |
Creates an entity with sample field values. Overrides ContentEntityStorageInterface:: |
1 |
ContentEntityStorageBase:: |
public | function |
Delete a specific entity revision. Overrides EntityStorageInterface:: |
1 |
ContentEntityStorageBase:: |
protected | function |
Performs storage-specific creation of entities. Overrides EntityStorageBase:: |
|
ContentEntityStorageBase:: |
protected | function |
Performs storage-specific entity deletion. Overrides EntityStorageBase:: |
1 |
ContentEntityStorageBase:: |
protected | function |
Performs post save entity processing. Overrides EntityStorageBase:: |
|
ContentEntityStorageBase:: |
protected | function |
Performs presave entity processing. Overrides EntityStorageBase:: |
|
ContentEntityStorageBase:: |
protected | function |
Performs storage-specific saving of the entity. Overrides EntityStorageBase:: |
1 |
ContentEntityStorageBase:: |
protected | function | Gets entities from the persistent cache backend. | |
ContentEntityStorageBase:: |
public | function |
Returns the latest revision identifier for an entity. Overrides RevisionableStorageInterface:: |
|
ContentEntityStorageBase:: |
public | function |
Returns the latest revision affecting the specified translation. Overrides TranslatableRevisionableStorageInterface:: |
|
ContentEntityStorageBase:: |
protected | function | Returns an array of field names to skip when merging revision translations. | |
ContentEntityStorageBase:: |
protected | function | Checks whether the field values changed compared to the original entity. | |
ContentEntityStorageBase:: |
protected | function | Initializes field values. | |
ContentEntityStorageBase:: |
protected | function | Invokes a method on the Field objects within an entity. | |
ContentEntityStorageBase:: |
protected | function | Invokes the post save method on the Field objects within an entity. | |
ContentEntityStorageBase:: |
protected | function |
Invokes a hook on behalf of the entity. Overrides EntityStorageBase:: |
1 |
ContentEntityStorageBase:: |
protected | function | Checks translation statuses and invoke the related hooks if needed. | |
ContentEntityStorageBase:: |
protected | function | Checks whether any entity revision is translated. | |
ContentEntityStorageBase:: |
protected | function | Checks whether any stored entity revision is translated. | |
ContentEntityStorageBase:: |
public | function |
Loads multiple entity revisions. Overrides RevisionableStorageInterface:: |
1 |
ContentEntityStorageBase:: |
public | function |
Load a specific entity revision. Overrides EntityStorageInterface:: |
1 |
ContentEntityStorageBase:: |
public | function |
Loads an unchanged entity from the database. Overrides EntityStorageBase:: |
|
ContentEntityStorageBase:: |
public | function |
Reacts to the creation of a field. Overrides FieldDefinitionListenerInterface:: |
|
ContentEntityStorageBase:: |
public | function |
Reacts to the update of a field. Overrides FieldDefinitionListenerInterface:: |
|
ContentEntityStorageBase:: |
protected | function | Populates the affected flag for all the revision translations. | |
ContentEntityStorageBase:: |
protected | function |
Gathers entities from a 'preload' step. Overrides EntityStorageBase:: |
|
ContentEntityStorageBase:: |
public | function |
Purges a batch of field data. Overrides FieldableEntityStorageInterface:: |
|
ContentEntityStorageBase:: |
public | function |
Resets the internal, static entity cache. Overrides EntityStorageBase:: |
1 |
ContentEntityStorageBase:: |
protected | function | Stores entities in the persistent cache backend. | |
DependencySerializationTrait:: |
protected | property | An array of entity type IDs keyed by the property name of their storages. | |
DependencySerializationTrait:: |
protected | property | An array of service IDs keyed by property name used for serialization. | |
DependencySerializationTrait:: |
public | function | 1 | |
DependencySerializationTrait:: |
public | function | 2 | |
DeprecatedServicePropertyTrait:: |
public | function | Allows to access deprecated/removed properties. | |
EntityHandlerBase:: |
protected | property | The module handler to invoke hooks on. | 2 |
EntityHandlerBase:: |
protected | function | Gets the module handler. | 2 |
EntityHandlerBase:: |
public | function | Sets the module handler for this handler. | |
EntityStorageBase:: |
protected | property | Name of the entity class. | |
EntityStorageBase:: |
protected | property | Information about the entity type. | |
EntityStorageBase:: |
protected | property | Entity type ID for this storage. | |
EntityStorageBase:: |
protected | property | Name of the entity's ID field in the entity database table. | |
EntityStorageBase:: |
protected | property | The memory cache. | |
EntityStorageBase:: |
protected | property | The memory cache cache tag. | |
EntityStorageBase:: |
protected | property | Name of entity's UUID database table field, if it supports UUIDs. | 1 |
EntityStorageBase:: |
protected | property | The UUID service. | 1 |
EntityStorageBase:: |
protected | function | Builds the cache ID for the passed in entity ID. | 1 |
EntityStorageBase:: |
public | function |
Constructs a new entity object, without permanently saving it. Overrides EntityStorageInterface:: |
1 |
EntityStorageBase:: |
public | function |
Gets an aggregated query instance. Overrides EntityStorageInterface:: |
|
EntityStorageBase:: |
public | function |
Gets the entity type definition. Overrides EntityStorageInterface:: |
|
EntityStorageBase:: |
public | function |
Gets the entity type ID. Overrides EntityStorageInterface:: |
|
EntityStorageBase:: |
protected | function | Gets entities from the static cache. | |
EntityStorageBase:: |
public | function |
Gets an entity query instance. Overrides EntityStorageInterface:: |
|
EntityStorageBase:: |
public | function |
Determines if the storage contains any data. Overrides EntityStorageInterface:: |
3 |
EntityStorageBase:: |
public | function |
Loads one entity. Overrides EntityStorageInterface:: |
2 |
EntityStorageBase:: |
public | function |
Load entities by their property values. Overrides EntityStorageInterface:: |
3 |
EntityStorageBase:: |
public | function |
Loads one or more entities. Overrides EntityStorageInterface:: |
1 |
EntityStorageBase:: |
protected | function | Attaches data to entities upon loading. | |
EntityStorageBase:: |
protected | function | Stores entities in the static entity cache. | |
EntityStorageInterface:: |
constant | Load the most recent version of an entity's field data. | ||
EntityStorageInterface:: |
constant | Load the version of an entity's field data specified in the entity. | ||
SqlContentEntityStorage:: |
protected | property | The base table of the entity. | |
SqlContentEntityStorage:: |
protected | property | Active database connection. | |
SqlContentEntityStorage:: |
protected | property | The table that stores properties, if the entity has multilingual support. | |
SqlContentEntityStorage:: |
protected | property | The default language entity key. | |
SqlContentEntityStorage:: |
protected | property | The entity type manager. | |
SqlContentEntityStorage:: |
protected | property | The entity type's field storage definitions. | |
SqlContentEntityStorage:: |
protected | property |
The entity langcode key. Overrides EntityStorageBase:: |
|
SqlContentEntityStorage:: |
protected | property | The language manager. | |
SqlContentEntityStorage:: |
protected | property | The table that stores revision field data if the entity supports revisions. | |
SqlContentEntityStorage:: |
protected | property | Name of entity's revision database table field, if it supports revisions. | |
SqlContentEntityStorage:: |
protected | property | The table that stores revisions, if the entity supports revisions. | |
SqlContentEntityStorage:: |
protected | property | The entity type's storage schema object. | |
SqlContentEntityStorage:: |
protected | property | The mapping of field columns to SQL tables. | |
SqlContentEntityStorage:: |
protected | property | Whether this storage should use the temporary table mapping. | |
SqlContentEntityStorage:: |
protected | function |
Builds an entity query. Overrides EntityStorageBase:: |
|
SqlContentEntityStorage:: |
protected | function | Builds the query to load the entity. | |
SqlContentEntityStorage:: |
public | function |
Determines the number of entities with values for a given field. Overrides FieldableEntityStorageInterface:: |
|
SqlContentEntityStorage:: |
public | function |
Deletes permanently saved entities. Overrides EntityStorageBase:: |
|
SqlContentEntityStorage:: |
protected | function | Deletes values of fields in dedicated tables for all revisions. | |
SqlContentEntityStorage:: |
protected | function | Deletes values of fields in dedicated tables for all revisions. | |
SqlContentEntityStorage:: |
protected | function |
Deletes entity field values from the storage. Overrides ContentEntityStorageBase:: |
|
SqlContentEntityStorage:: |
protected | function |
Deletes field values of an entity revision from the storage. Overrides ContentEntityStorageBase:: |
|
SqlContentEntityStorage:: |
protected | function |
Performs storage-specific loading of entities. Overrides EntityStorageBase:: |
|
SqlContentEntityStorage:: |
protected | function |
Actually loads revision field item values from the storage. Overrides ContentEntityStorageBase:: |
|
SqlContentEntityStorage:: |
protected | function |
Actually loads revision field item values from the storage. Overrides ContentEntityStorageBase:: |
|
SqlContentEntityStorage:: |
protected | function |
Writes entity field values to the storage. Overrides ContentEntityStorageBase:: |
1 |
SqlContentEntityStorage:: |
public | function |
Performs final cleanup after all data of a field has been purged. Overrides ContentEntityStorageBase:: |
|
SqlContentEntityStorage:: |
public | function | Gets the base table name. | |
SqlContentEntityStorage:: |
public | function | Gets a table mapping for the specified entity type and storage definitions. | |
SqlContentEntityStorage:: |
public | function | Gets the data table name. | |
SqlContentEntityStorage:: |
public | function | Gets the base field definitions for a content entity type. | |
SqlContentEntityStorage:: |
protected | function | Gets entities from the storage. | |
SqlContentEntityStorage:: |
protected | function |
Gets the name of the service for the query for this entity storage. Overrides EntityStorageBase:: |
|
SqlContentEntityStorage:: |
public | function | Gets the revision data table name. | |
SqlContentEntityStorage:: |
public | function | Gets the revision table name. | |
SqlContentEntityStorage:: |
protected | function | Gets the entity type's storage schema object. | |
SqlContentEntityStorage:: |
public | function |
Gets a table mapping for the entity's SQL tables. Overrides SqlEntityStorageInterface:: |
|
SqlContentEntityStorage:: |
protected | function |
Determines if this entity already exists in storage. Overrides EntityStorageBase:: |
|
SqlContentEntityStorage:: |
protected | function | Initializes table name variables. | |
SqlContentEntityStorage:: |
protected | function | Checks whether a field column should be treated as serial. | 1 |
SqlContentEntityStorage:: |
protected | function | Loads values of fields stored in dedicated tables for a group of entities. | |
SqlContentEntityStorage:: |
protected | function | Loads values for fields stored in the shared data tables. | |
SqlContentEntityStorage:: |
protected | function |
Maps from storage records to entity objects, and attaches fields. Overrides EntityStorageBase:: |
|
SqlContentEntityStorage:: |
protected | function | Maps from an entity object to the storage record of the field data. | |
SqlContentEntityStorage:: |
protected | function | Maps from an entity object to the storage record. | |
SqlContentEntityStorage:: |
public | function |
Reacts to a bundle being created. Overrides EntityBundleListenerInterface:: |
|
SqlContentEntityStorage:: |
public | function |
Reacts to a bundle being deleted. Overrides EntityBundleListenerInterface:: |
|
SqlContentEntityStorage:: |
public | function |
Reacts to the creation of the entity type. Overrides EntityTypeListenerInterface:: |
|
SqlContentEntityStorage:: |
public | function |
Reacts to the deletion of the entity type. Overrides EntityTypeListenerInterface:: |
|
SqlContentEntityStorage:: |
public | function |
Reacts to the update of the entity type. Overrides EntityTypeListenerInterface:: |
|
SqlContentEntityStorage:: |
public | function |
Reacts to the creation of the fieldable entity type. Overrides EntityTypeListenerInterface:: |
|
SqlContentEntityStorage:: |
public | function |
Reacts to the update of a fieldable entity type. Overrides EntityTypeListenerInterface:: |
|
SqlContentEntityStorage:: |
public | function |
Reacts to the deletion of a field. Overrides ContentEntityStorageBase:: |
|
SqlContentEntityStorage:: |
public | function |
Reacts to the creation of a field storage definition. Overrides ContentEntityStorageBase:: |
|
SqlContentEntityStorage:: |
public | function |
Reacts to the deletion of a field storage definition. Overrides ContentEntityStorageBase:: |
|
SqlContentEntityStorage:: |
public | function |
Reacts to the update of a field storage definition. Overrides ContentEntityStorageBase:: |
|
SqlContentEntityStorage:: |
protected | function |
Removes field items from storage per entity during purge. Overrides ContentEntityStorageBase:: |
|
SqlContentEntityStorage:: |
protected | function |
Reads values to be purged for a single field. Overrides ContentEntityStorageBase:: |
|
SqlContentEntityStorage:: |
public | function |
Checks if existing data would be lost if the schema changes were applied. Overrides EntityStorageSchemaInterface:: |
|
SqlContentEntityStorage:: |
public | function |
Checks if the changes to the entity type requires storage schema changes. Overrides EntityStorageSchemaInterface:: |
|
SqlContentEntityStorage:: |
public | function |
Checks if existing data would be lost if the schema changes were applied. Overrides DynamicallyFieldableEntityStorageSchemaInterface:: |
|
SqlContentEntityStorage:: |
public | function |
Checks if the changes to the storage definition requires schema changes. Overrides DynamicallyFieldableEntityStorageSchemaInterface:: |
|
SqlContentEntityStorage:: |
public | function |
Restores a previously saved entity. Overrides EntityStorageBase:: |
|
SqlContentEntityStorage:: |
public | function |
Saves the entity permanently. Overrides EntityStorageBase:: |
1 |
SqlContentEntityStorage:: |
protected | function | Saves an entity revision. | |
SqlContentEntityStorage:: |
protected | function | Saves values of fields that use dedicated tables. | 1 |
SqlContentEntityStorage:: |
protected | function | Saves fields that use the shared tables. | |
SqlContentEntityStorage:: |
public | function | Updates the wrapped entity type definition. | |
SqlContentEntityStorage:: |
public | function | Updates the internal list of field storage definitions. | |
SqlContentEntityStorage:: |
public | function | Sets the wrapped table mapping definition. | |
SqlContentEntityStorage:: |
public | function | Changes the temporary state of the storage. | |
SqlContentEntityStorage:: |
protected | function | Determines whether the passed field has been already deleted. | |
SqlContentEntityStorage:: |
protected | function | Wraps a database schema exception into an entity storage exception. | |
StringTranslationTrait:: |
protected | property | The string translation service. | 1 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
StringTranslationTrait:: |
protected | function | Translates a string to the current language or to a given language. |