app = $application; $this->initalizeModel($this->model()); } /** * Return the model backing this repository. * * @return string|\Closure|object */ abstract public function model(); /** * Return the model being used for this repository. * * @return mixed */ public function getModel() { return $this->model; } /** * Setup column selection functionality. * * @param array|string $columns * @return $this */ public function setColumns($columns = ['*']) { $clone = clone $this; $clone->columns = is_array($columns) ? $columns : func_get_args(); return $clone; } /** * Return the columns to be selected in the repository call. * * @return array */ public function getColumns() { return $this->columns; } /** * Stop repository update functions from returning a fresh * model when changes are committed. * * @return $this */ public function withoutFreshModel() { return $this->setFreshModel(false); } /** * Return a fresh model with a repository updates a model. * * @return $this */ public function withFreshModel() { return $this->setFreshModel(true); } /** * Set wether or not the repository should return a fresh model * when changes are committed. * * @param bool $fresh * @return $this */ public function setFreshModel(bool $fresh = true) { $clone = clone $this; $clone->withFresh = $fresh; return $clone; } /** * Take the provided model and make it accessible to the rest of the repository. * * @param array $model * @return mixed */ protected function initalizeModel(...$model) { switch (count($model)) { case 1: return $this->model = $this->app->make($model[0]); case 2: return $this->model = call_user_func([$this->app->make($model[0]), $model[1]]); default: throw new InvalidArgumentException('Model must be a FQCN or an array with a count of two.'); } } }