Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bosnadev/repository
Laravel Repositories is a package for Laravel 5 which is used to abstract the database layer. This makes applications much easier to maintain.
https://github.com/bosnadev/repository
criteria database-layer laravel laravel-repositories php
Last synced: 1 day ago
JSON representation
Laravel Repositories is a package for Laravel 5 which is used to abstract the database layer. This makes applications much easier to maintain.
- Host: GitHub
- URL: https://github.com/bosnadev/repository
- Owner: bosnadev
- Created: 2015-02-18T19:57:34.000Z (almost 10 years ago)
- Default Branch: master
- Last Pushed: 2022-07-17T17:28:21.000Z (over 2 years ago)
- Last Synced: 2025-01-14T23:43:06.281Z (8 days ago)
- Topics: criteria, database-layer, laravel, laravel-repositories, php
- Language: PHP
- Homepage: https://bosnadev.com
- Size: 115 KB
- Stars: 825
- Watchers: 59
- Forks: 241
- Open Issues: 65
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Laravel Repositories
[![Build Status](https://travis-ci.org/bosnadev/repository.svg?branch=master)](https://travis-ci.org/bosnadev/repository)
[![SensioLabsInsight](https://img.shields.io/sensiolabs/i/f39e6dc7-1364-481d-b722-8413bdc3200f.svg?style=flat)](https://insight.sensiolabs.com/projects/f39e6dc7-1364-481d-b722-8413bdc3200f)
[![Latest Stable Version](https://poser.pugx.org/bosnadev/repositories/v/stable)](https://packagist.org/packages/bosnadev/repositories)
[![Total Downloads](https://poser.pugx.org/bosnadev/repositories/downloads)](https://packagist.org/packages/bosnadev/repositories)
[![Monthly Downloads](https://poser.pugx.org/bosnadev/repositories/d/monthly)](https://packagist.org/packages/bosnadev/repositories)
[![License](https://poser.pugx.org/bosnadev/repositories/license)](https://packagist.org/packages/bosnadev/repositories)Laravel Repositories is a package for Laravel 5 which is used to abstract the database layer. This makes applications much easier to maintain.
## Installation
Run the following command from you terminal:
```bash
composer require "bosnadev/repositories: 0.*"
```or add this to require section in your composer.json file:
```
"bosnadev/repositories": "0.*"
```then run ```composer update```
## Usage
First, create your repository class. Note that your repository class MUST extend ```Bosnadev\Repositories\Eloquent\Repository``` and implement model() method
```php
'float'
];
}
```And finally, use the repository in the controller:
```php
film = $film;
}public function index() {
return \Response::json($this->film->all());
}
}
```## Available Methods
The following methods are available:
##### Bosnadev\Repositories\Contracts\RepositoryInterface
```php
public function all($columns = array('*'))
public function lists($value, $key = null)
public function paginate($perPage = 1, $columns = array('*'));
public function create(array $data)
// if you use mongodb then you'll need to specify primary key $attribute
public function update(array $data, $id, $attribute = "id")
public function delete($id)
public function find($id, $columns = array('*'))
public function findBy($field, $value, $columns = array('*'))
public function findAllBy($field, $value, $columns = array('*'))
public function findWhere($where, $columns = array('*'))
```##### Bosnadev\Repositories\Contracts\CriteriaInterface
```php
public function apply($model, Repository $repository)
```### Example usage
Create a new film in repository:
```php
$this->film->create(Input::all());
```Update existing film:
```php
$this->film->update(Input::all(), $film_id);
```Delete film:
```php
$this->film->delete($id);
```Find film by film_id;
```php
$this->film->find($id);
```you can also chose what columns to fetch:
```php
$this->film->find($id, ['title', 'description', 'release_date']);
```Get a single row by a single column criteria.
```php
$this->film->findBy('title', $title);
```Or you can get all rows by a single column criteria.
```php
$this->film->findAllBy('author_id', $author_id);
```Get all results by multiple fields
```php
$this->film->findWhere([
'author_id' => $author_id,
['year','>',$year]
]);
```## Criteria
Criteria is a simple way to apply specific condition, or set of conditions to the repository query. Your criteria class MUST extend the abstract ```Bosnadev\Repositories\Criteria\Criteria``` class.
Here is a simple criteria:
```php
where('length', '>', 120);
return $model;
}
}
```Now, inside you controller class you call pushCriteria method:
```php
film = $film;
}public function index() {
$this->film->pushCriteria(new LengthOverTwoHours());
return \Response::json($this->film->all());
}
}
```## Credits
This package is largely inspired by [this](https://github.com/prettus/l5-repository) great package by @andersao. [Here](https://github.com/anlutro/laravel-repository/) is another package I used as reference.