- PHP ^8.0 or higher
- Laravel 9.0 or higher
- Eloquent 8.0 or higher
You can install the library using Composer:
composer require jetcod/eloquent-repository
To use the library, you need to create a repository class for each of your Eloquent models. You can either extend the Jetcod\LaravelRepository\Eloquent\BaseRepository class to get started or use artisan command to generate the repository class:
php artisan make:repository UserRepository
Here's an example of a UserRepository class:
<?php
namespace App\Repositories;
use App\Models\User;
use Illuminate\Database\Eloquent\Model;
use Jetcod\LaravelRepository\Eloquent\BaseRepository
class UserRepository extends BaseRepository
{
protected function getModelName()
{
return User::class;
}
}
In this example, the UserRepository extends the BaseRepository class and connects the repository to User mode by implementing getModelName()
method . You can then use the repository to perform CRUD operations on the User model, like this:
<?php
namespace App\Services;
use App\Models\User;
use Illuminate\Database\Eloquent\Model;
use Jetcod\LaravelRepository\Eloquent\BaseRepository
class UserService
{
protected $repository;
protected function __construct(UserRepository $repository)
{
$this->repository = $repository;
}
public function getAdmins()
{
return $this->repository->findBy([
['role', '=', 'ADMIN']
]);
}
}
The following methods are available in the BaseRepository class:
find(int $id)
: Find a model by ID.findAll()
: Get all models.findBy(array $conditions, array $relations = [], bool $paginate = true, int $pageSize = 10)
: Find all models and their identified relations by conditions. The result can ne either paginated or return as a collection.findOneBy(array $conditions, array $relations = [])
: Find a model and its identified relations by conditions.with($relations, $callback = null)
: Set the relationships that should be eager loaded.countBy(array $conditions)
: Count models by conditions.delete($model)
: Delete a modelinsert(array $rows)
: Bulk insert datacreate(array $attributes)
: Create a new model.updateOrCreate(array $data, array $conditions)
: Create or update a record matching the attributes, and fill it with valuesupdate(Model $model, array $data, array $fillable = [])
: Update an existing model.fill(Model $model, array $data, array $fillable = [])
: Fill the given model by the given array of data.delete($model)
: Delete a model.destroy($ids)
: Destroy an array or collection of ids.query()
: Query builder instance.
You can also extend the BaseRepository * class to add custom methods for your specific use case.
If you find any bugs or have ideas for new features, please open an issue or submit a pull request on GitHub.
My Eloquent Repository Library is open-sourced software licensed under the MIT license.