| 
									
										
										
										
											2018-06-24 13:20:29 +02:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * BudgetLimitRequest.php | 
					
						
							|  |  |  |  * Copyright (c) 2018 thegrumpydictator@gmail.com | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This file is part of Firefly III. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Firefly III is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU General Public License as published by | 
					
						
							|  |  |  |  * the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  |  * (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Firefly III is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with Firefly III. If not, see <http://www.gnu.org/licenses/>. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | declare(strict_types=1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Api\V1\Requests; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Class BudgetLimitRequest | 
					
						
							| 
									
										
										
										
											2019-04-12 04:53:18 +02:00
										 |  |  |  * | 
					
						
							|  |  |  |  * @codeCoverageIgnore | 
					
						
							| 
									
										
										
										
											2019-08-12 17:10:58 +02:00
										 |  |  |  * TODO AFTER 4.8,0: split this into two request classes. | 
					
						
							| 
									
										
										
										
											2018-06-24 13:20:29 +02:00
										 |  |  |  */ | 
					
						
							|  |  |  | class BudgetLimitRequest extends Request | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-07-06 07:15:42 +02:00
										 |  |  |      * Authorize logged in users. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-06-24 13:20:29 +02:00
										 |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function authorize(): bool | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         // Only allow authenticated users
 | 
					
						
							|  |  |  |         return auth()->check(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-07-06 07:15:42 +02:00
										 |  |  |      * Get all data from the request. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-06-24 13:20:29 +02:00
										 |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getAll(): array | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return [ | 
					
						
							| 
									
										
										
										
											2018-12-09 08:45:53 +01:00
										 |  |  |             'budget_id'     => $this->integer('budget_id'), | 
					
						
							|  |  |  |             'start'         => $this->date('start'), | 
					
						
							|  |  |  |             'end'           => $this->date('end'), | 
					
						
							|  |  |  |             'amount'        => $this->string('amount'), | 
					
						
							|  |  |  |             'currency_id'   => $this->integer('currency_id'), | 
					
						
							|  |  |  |             'currency_code' => $this->string('currency_code'), | 
					
						
							| 
									
										
										
										
											2018-06-24 13:20:29 +02:00
										 |  |  |         ]; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-07-06 07:15:42 +02:00
										 |  |  |      * The rules that the incoming request must be matched against. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-06-24 13:20:29 +02:00
										 |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function rules(): array | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $rules = [ | 
					
						
							| 
									
										
										
										
											2018-12-09 08:45:53 +01:00
										 |  |  |             'budget_id'     => 'required|exists:budgets,id|belongsToUser:budgets,id', | 
					
						
							|  |  |  |             'start'         => 'required|before:end|date', | 
					
						
							|  |  |  |             'end'           => 'required|after:start|date', | 
					
						
							|  |  |  |             'amount'        => 'required|more:0', | 
					
						
							|  |  |  |             'currency_id'   => 'numeric|exists:transaction_currencies,id', | 
					
						
							|  |  |  |             'currency_code' => 'min:3|max:3|exists:transaction_currencies,code', | 
					
						
							| 
									
										
										
										
											2018-06-24 13:20:29 +02:00
										 |  |  |         ]; | 
					
						
							|  |  |  |         switch ($this->method()) { | 
					
						
							|  |  |  |             default: | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             case 'PUT': | 
					
						
							|  |  |  |             case 'PATCH': | 
					
						
							|  |  |  |                 $rules['budget_id'] = 'required|exists:budgets,id|belongsToUser:budgets,id'; | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-12-09 08:45:53 +01:00
										 |  |  |         // if request has a budget already, drop the rule.
 | 
					
						
							|  |  |  |         $budget = $this->route()->parameter('budget'); | 
					
						
							|  |  |  |         if (null !== $budget) { | 
					
						
							|  |  |  |             unset($rules['budget_id']); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-24 13:20:29 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return $rules; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-22 20:32:02 +02:00
										 |  |  | } |