ulex / epic-repositories
EPIC Repositories - An epic Laravel package
Installs: 5 371
Dependents: 0
Suggesters: 0
Security: 0
Stars: 3
Watchers: 1
Forks: 0
Open Issues: 0
Type:project
Requires
- php: ^7.4|^8.0
README
Documentation, Installation, and Usage Instructions
First, install the package via Composer:
composer require ulex/epic-repositories
Service Provider
For Laravel
You should publish the RepositoriesServiceProvider:
php artisan vendor:publish --provider="Ulex\EpicRepositories\RepositoriesServiceProvider" --tag=epic-repositories-config
Optional: The service provider will automatically get registered. Or you may manually add the service provider in your config/app.php file: Laravel
'providers' => [ // ... Ulex\EpicRepositories\RepositoriesServiceProvider::class, ];
For Lumen
In your bootstrap/app.php
add this:
$app->register(Ulex\EpicRepositories\RepositoriesServiceProvider::class);
Config
If config file epic-repositories.php
was not published copy it to config folder with:
cp vendor/ulex/epic-repositories/config/epic-repositories.php config/epic-repositories.php
Take some time to review this config file. Here you can adjust various configurations for your repositories setup.
- Set a custom TTL for each of you models.
- Set the namespaces of your folders
- Enable/add the repositories and decorators you will use.
- Add your model bindings for each repository and which decorators to use for that repository.
Note: In order to use elastic
repository you will have to add "elasticsearch/elasticsearch" package to your composer.json.
Create Repository/ies, Decorator/s with their Interfaces for a Model
First declare your models in config/epic-repositories
... 'bindings' => [ 'eloquent' => [ 'decorators' => ['caching'], 'models' => [ 'User' => App\Models\User::class, //'NewModel => App\Models\NewModel::class, ] ], ...
Run the following php artisan command:
php artisan make:epic
Depending on you configuration, the necessary folders & classes will be created in your app/Repositories
folder.
Example:
UserEloquentRepository created successfully. UserEloquentInterface created successfully. UserEloquentCachingDecorator created successfully.
How to use
This package provides an abstract structure that uses the Repository design pattern with caching decorator/s for you application.
Once installed you can create Repositories for your models that cache the data from your queries. Eloquent and Elastic Repositories are provided and ready to use if enabled. Follow the same principle for any data resource you have on your application.
# Example when injecting to a controller use App\Repositories\Interfaces\UserEloquentInterface; public function __construct(UserEloquentInterface $userRepository) { $this->userRepository = $userRepository; } ... public function find($id) { //retrieve from db and then cache the result $user = $this->userRepository->find($id); //retrieve straight from source, uncached $user = $this->userRepository->fromSource()->find($id); }
Extending a model's CachingDecorator
For GET functions use the remember
function the same way as in the AbstractCachingDecorator. This will ensure that this function is cached and invalidated properly.
Function remember
signature
protected function remember(string $function, $arguments, bool $isCollection = false)
Functions that return a single result:
PostsEloquentCachingDecorator.php
public function getLatestPost($user_id) { return $this->remember(__FUNCTION__, func_get_args()); }
Note: Remember to add the cache invalidation of the new function by extending flushGetKeys in the model's CachingDecorator.
public function flushGetKeys($model, $attributes = null) { $this->flushFunction('getLatestPost', ['user_id' => $model->user_id]); parent::flushGetKeys($model, $attributes); }
PostsEloquentRepository.php
Add the query in the model's repository
public function getLatestPost($user_id) { return $this->model->query()->where('user_id', '=', $user_id)->latest()->first(); }
Functions that return a collection of results:
For GET functions that return collections you MUST pass TRUE
to the $isCollection param on remember
function.
public function getUserPosts($user_id) { return $this->remember(__FUNCTION__, func_get_args(), true); }
The above will be flushed in flushGetKeys
which calls flushCollections()
.
Note: If you are adding functions that create a new column, you need to add $this->flushCollections();
after the entry is created so that all collections are flushed and can include your new entry/ies. Check create
in AbstractCachingDecorator.
Contributing
This package is mostly based on Jeffrey Way's awesome Laracasts lessons when using the repository design pattern on Laravel From Scratch series.
License
The MIT License (MIT). Please see License File for more information.