150 lines
3.0 KiB
PHP
150 lines
3.0 KiB
PHP
<?php
|
|
|
|
namespace CachetHQ\Cachet\Repositories;
|
|
|
|
use Exception;
|
|
use Illuminate\Database\Eloquent\ModelNotFoundException;
|
|
|
|
abstract class EloquentRepository
|
|
{
|
|
/**
|
|
* Returns all models.
|
|
*
|
|
* @return object
|
|
*/
|
|
public function all()
|
|
{
|
|
return $this->model->all();
|
|
}
|
|
|
|
/**
|
|
* Returns an object with related relationships.
|
|
*
|
|
* @param id $id
|
|
* @param array $with Array of model relationships
|
|
*
|
|
* @return object|ModelNotFoundException
|
|
*/
|
|
public function with($id, array $with = [])
|
|
{
|
|
return $this->model->with($with)->findOrFail($id);
|
|
}
|
|
|
|
/**
|
|
* Sets the model to query against a user id.
|
|
*
|
|
* @param int $id
|
|
* @param string $column
|
|
*
|
|
* @return $this
|
|
*/
|
|
public function withAuth($id, $column = 'user_id')
|
|
{
|
|
$this->model = $this->model->where($column, $id);
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Finds a model by ID.
|
|
*
|
|
* @param int $id
|
|
*
|
|
* @return object
|
|
*/
|
|
public function find(int $id)
|
|
{
|
|
return $this->model->find($id);
|
|
}
|
|
|
|
/**
|
|
* Finds a model by ID.
|
|
*
|
|
* @param int $id
|
|
*
|
|
* @return object|ModelNotFoundException
|
|
*/
|
|
public function findOrFail($id)
|
|
{
|
|
return $this->model->findOrFail($id);
|
|
}
|
|
|
|
/**
|
|
* Finds a model by type.
|
|
*
|
|
* @param string $key
|
|
* @param string $value
|
|
* @param array $columns
|
|
*
|
|
* @return object|ModelNotFoundException
|
|
*/
|
|
public function findByOrFail($key, $value, $columns = ['*'])
|
|
{
|
|
if (! is_null($item = $this->model->where($key, $value)->first($columns))) {
|
|
return $item;
|
|
}
|
|
|
|
throw new ModelNotFoundException();
|
|
}
|
|
|
|
/**
|
|
* Counts the number of rows returned.
|
|
*
|
|
* @param string $key
|
|
* @param string $value
|
|
*
|
|
* @return int
|
|
*/
|
|
public function count($key = null, $value = null)
|
|
{
|
|
if (is_null($key) || is_null($value)) {
|
|
return $this->model->where($key, $value)->count();
|
|
}
|
|
|
|
return $this->model->count();
|
|
}
|
|
|
|
/**
|
|
* Deletes a model by ID.
|
|
*
|
|
* @param inetegr $id
|
|
*/
|
|
public function destroy($id)
|
|
{
|
|
$this->model->delete($id);
|
|
}
|
|
|
|
/**
|
|
* Validate a given model with Watson validation.
|
|
*
|
|
* @param object $model
|
|
*
|
|
* @return Exception
|
|
*/
|
|
public function validate($model)
|
|
{
|
|
if ($model->isInvalid()) {
|
|
throw new Exception('Invalid model validation');
|
|
}
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Validate whether a model has a correct relationship.
|
|
*
|
|
* @param object $model
|
|
* @param string $relationship Name of the relationship to validate against
|
|
*
|
|
* @return Exception
|
|
*/
|
|
public function hasRelationship($model, $relationship)
|
|
{
|
|
if (! $model->$relationship) {
|
|
throw new Exception('Invalid relationship exception');
|
|
}
|
|
|
|
return $this;
|
|
}
|
|
}
|