| Package Data | |
|---|---|
| Maintainer Username: | freevital | 
| Maintainer Contact: | vital.kravchyshyn@gmail.com (Vitaliy Kravchyshyn) | 
| Package Create Date: | 2017-02-01 | 
| Package Last Update: | 2017-05-15 | 
| Language: | PHP | 
| License: | MIT | 
| Last Refreshed: | 2025-10-30 03:01:58 | 
| Package Statistics | |
|---|---|
| Total Downloads: | 361 | 
| Monthly Downloads: | 0 | 
| Daily Downloads: | 0 | 
| Total Stars: | 9 | 
| Total Watchers: | 2 | 
| Total Forks: | 1 | 
| Total Open Issues: | 0 | 
Laravel Repositories to abstract a database layer.
Run the following command to install the latest version:
composer require "freevital/laravel-repository"
Your repository class must extend Freevital\Repository\Eloquent\BaseRepository abstract class and implement method model() which returns model's class name.
namespace App\Repositories\Eloquent;
use Freevital\Repository\Eloquent\BaseRepository;   
class PostRepository extends BaseRepository
{
    /**
     * Specify Model class name.
     *
     * @return string
     */
    public function model()
    {
        return "App\Post";
    }
}
namespace App\Http\Controllers;
use App\Http\Controllers\Controller;
use App\Repositories\Criteria\BySlugCriteria;
use App\Repositories\Criteria\WithCommentsCriteria;
use App\Repositories\Eloquent\PostRepository;
class PostController extends Controller
{
    /**
     * @var PostRepository
     */
    protected $postRepository;
    /**
     * @param PostRepository $postRepository
     */
    public function __construct(PostRepository $postRepository)
    {
        $this->postRepository = $postRepository;
    }
    /**
     * Get all posts.
     *
     * @return \Illuminate\Http\JsonResponse
     */
    public function index()
    {
        $posts = $this->postRepository->all();
    
        return \Response::json(compact('posts'));
    }
}
Optionally you may create a separate Criteria class to apply specific query conditions. Your Criteria class must implement Freevital\Repository\Contracts\CriteriaContract interface.
namespace App\Repositories\Criteria;
use Illuminate\Database\Eloquent\Builder;
use Freevital\Repository\Contracts\CriteriaContract;
use Freevital\Repository\Contracts\RepositoryContract;
class BySlugCriteria implements CriteriaContract
{
    /**
     * @var string
     */
    protected $slug;
    /**
     * @param string $slug
     */
    public function __construct($slug)
    {
        $this->slug = $slug;
    }
    /**
     * Apply criteria in query repository.
     *
     * @param Builder            $query
     * @param RepositoryContract $repository
     *
     * @return \Illuminate\Database\Eloquent\Builder
     */
    public function apply(Builder $query, RepositoryContract $repository)
    {
        return $query->where('slug', $this->slug);
    }
}
You may use multiple criteria in the repository.
namespace App\Http\Controllers;
use App\Http\Controllers\Controller;
use App\Repositories\Criteria\BySlugCriteria;
use App\Repositories\Criteria\WithCommentsCriteria;
use App\Repositories\Eloquent\PostRepository;
class PostController extends Controller
{
     /**
     * Get a post by slug.
     *
     * @param string $slug
     *
     * @return \Illuminate\Http\JsonResponse
     */
    public function show($slug)
    {
        $post = $this->postRepository
            ->pushCriteria(new WithCommentsCriteria())
            ->pushCriteria(new BySlugCriteria($slug))
            ->first();
    
        return \Response::json(compact('post'));
    }
}
If you would like to extend the repository functionality with custom common scope (ex. ActiveCriteria), you may use BaseRepository's macro method. For example, from a service provider's boot method:
namespace App\Providers;
use Freevital\Repository\Criteria\ActiveCriteria;
use Freevital\Repository\Eloquent\BaseRepository;
use Illuminate\Support\ServiceProvider;
class RepositoryMacroServiceProvider extends ServiceProvider
{
    /**
     * Register the application's repository macros.
     *
     * @return void
     */
    public function boot()
    {
        BaseRepository::macro('active', function (BaseRepository $repository) {
            $repository->pushCriteria(new ActiveCriteria());
        });
    }
}
The macro function accepts a name as its first argument, and a Closure as its second. The macro's Closure will be executed when calling the macro name from any Repository instance:
$this->postRepository->active()->all();
paginate($limit = null, $columns = ['*'], $method = 'paginate')
simplePaginate($limit = null, $columns = ['*'])
all($columns = ['*'])
lists($column, $key = null)
find($id, $columns = ['*'])
first($columns = ['*'])
findByAttribute($attribute, $value, $columns = ['*'])
findWhere(array $where, $columns = ['*'])
findWhereIn($attribute, array $values, $columns = ['*'])
findWhereNotIn($attribute, array $values, $columns = ['*'])
count()
create(array $attributes)
update(array $attributes, $id)
updateOrCreate(array $attributes, array $values = [])
updateActiveStatus($status, int $id)
delete($id)
forceDelete($id)
deleteWhere(array $where)
forceDeleteWhere(array $where)
has($relation)
with($relations)
whereHas($relation, $closure)
orderBy($column, $direction = 'asc')
visible(array $attributes)
hidden(array $attributes)
scopeQuery(\Closure $scope)
resetScope()
pushCriteria($criteria)
popCriteria($criteria)
getCriteria()
getByCriteria(CriteriaContract $criteria)
skipCriteria($status = true)
resetCriteria()
apply(Builder $query, RepositoryContract $repository)
Get all entities:
$this->postRepository->all();
// Fetch the specific columns
$this->postRepository->all(['id', 'title']);
Entity pagination:
$this->postRepository->paginate(20);
Get an entity by id:
$this->postRepository->find($id);
Get first entity:
$this->postRepository->pushCriteria(...)->first();
Get entities count:
$this->postRepository->pushCriteria(...)->count();
Create new entity:
$this->postRepository->create(Input::all());
Update an entity by id:
$this->postRepository->update(Input::all(), $id);
Delete or force delete an entity by id:
$this->postRepository->delete($id);
$this->postRepository->forceDelete($id);
This package in mainly based on package by @andersao.
The contents of this repository is released under the MIT license.