strakez / entity-decorator-api
Implements a decorator pattern to access and customize typed access to an entity's properties and methods
Installs: 18
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Type:drupal-module
Requires
- php: >=8.1
Requires (Dev)
- drupal/core: ^9.5 || ^10
- drupal/devel: ^5.1
- drush/drush: ^11 || ^12
- phpunit/phpunit: ^9
- psr/log: 3.x-dev
- squizlabs/php_codesniffer: 4.0.x-dev
This package is auto-updated.
Last update: 2025-02-09 01:13:47 UTC
README
Implements a decorator pattern to access and customize an entity's properties and methods, with the option to strongly type return values.
Installation
composer require strakez/drupal-entity-decorator
Requirements
- PHP 8.1+
- Drupal 10+
Purpose
Provides a simple means to retrieve and display entity data, and solves some of the challenges experienced when working with entities. This implementation of the decorator pattern wraps the entity and provides customized methods for interacting with the entity.
Please note, this only exposes classes for use in other modules and does not provide any Drupal functionality on its own. There will not be anything to display via the UI unless specifically implemented.
Usage
$id = 1; $node = NodeDecorator::load($id); // Collection $node->id(); // 1 $node->get('title'); // 'My First Node' $node->get('sticky'); // false
For information on using and extending decorators, see the Decorator documentation.
For tips and best practices, see the Tips & Best Practices section.
Working with Collections
When loading multiple decorators at a time, the data will be representated in a collection. This provides an advantage over simple arrays, as this data can be easily sorted, mutated, counted, and indexed.
$set = NodeDecorator::loadByOwned($user); // Collection
For more information, see the Collection documentation.
Final Words
Please have fun using this API, and feel free to submit your comments and/or improvements if you find any. Thanks!