From 95d6ec51016b84aa437afa2d7593c1e926eed07e Mon Sep 17 00:00:00 2001 From: mctekk Date: Thu, 13 Jun 2019 16:22:04 -0400 Subject: [PATCH] improve the way we get the information on the rapid controllers, instead of relaying on the id, we are based on the primary key --- src/Contracts/Api/CrudBehaviorTrait.php | 19 ++++++++++++++----- 1 file changed, 14 insertions(+), 5 deletions(-) diff --git a/src/Contracts/Api/CrudBehaviorTrait.php b/src/Contracts/Api/CrudBehaviorTrait.php index c939797..28dcd5a 100644 --- a/src/Contracts/Api/CrudBehaviorTrait.php +++ b/src/Contracts/Api/CrudBehaviorTrait.php @@ -87,7 +87,8 @@ protected function processInput(array $request): array return $request; } - // TODO: Move it to its own class. + // TODO: Move it to its own class. + /** * Given a process request return the records. * @@ -147,7 +148,6 @@ protected function processIndex() $processedRequest = $this->processRequest($this->request); $records = $this->getRecords($processedRequest); - //get the results and append its relationships $results = $this->appendRelationshipsToResult($this->request, $records['results']); @@ -177,7 +177,10 @@ protected function processIndex() public function getById($id): Response { //find the info - $record = $this->model::findFirstOrFail($id); + $record = $this->model::findFirstOrFail([ + 'conditions' => $this->model->getPrimaryKey() . '= ?0', + 'bind' => [$id] + ]); //get the results and append its relationships $result = $this->appendRelationshipsToResult($this->request, $record); @@ -222,7 +225,10 @@ protected function processCreate(Request $request): ModelInterface */ public function edit($id): Response { - $record = $this->model::getByIdOrFail($id); + $record = $this->model::findFirstOrFail([ + 'conditions' => $this->model->getPrimaryKey() . '= ?0', + 'bind' => [$id] + ]); //process the input $result = $this->processEdit($this->request, $record); @@ -256,7 +262,10 @@ protected function processEdit(Request $request, ModelInterface $record): ModelI */ public function delete($id): Response { - $record = $this->model::getByIdOrFail($id); + $record = $this->model::findFirstOrFail([ + 'conditions' => $this->model->getPrimaryKey() . '= ?0', + 'bind' => [$id] + ]); if ($this->softDelete == 1) { $record->softDelete();