| 
									
										
										
										
											2016-01-15 11:16:41 +01:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2016-05-20 12:41:23 +02:00
										 |  |  | /** | 
					
						
							|  |  |  |  * RuleGroupRepositoryInterface.php | 
					
						
							| 
									
										
										
										
											2020-02-16 14:00:57 +01:00
										 |  |  |  * Copyright (c) 2019 james@firefly-iii.org | 
					
						
							| 
									
										
										
										
											2016-05-20 12:41:23 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This file is part of Firefly III (https://github.com/firefly-iii). | 
					
						
							| 
									
										
										
										
											2016-10-05 06:52:15 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This program is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU Affero General Public License as | 
					
						
							|  |  |  |  * published by the Free Software Foundation, either version 3 of the | 
					
						
							|  |  |  |  * License, or (at your option) any later version. | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * GNU Affero General Public License for more details. | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * You should have received a copy of the GNU Affero General Public License | 
					
						
							|  |  |  |  * along with this program.  If not, see <https://www.gnu.org/licenses/>. | 
					
						
							| 
									
										
										
										
											2016-05-20 12:41:23 +02:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-04-09 07:44:22 +02:00
										 |  |  | declare(strict_types=1); | 
					
						
							| 
									
										
										
										
											2016-01-15 11:16:41 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Repositories\RuleGroup; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-15 11:27:27 +01:00
										 |  |  | use FireflyIII\Models\RuleGroup; | 
					
						
							| 
									
										
										
										
											2016-02-17 17:27:41 +01:00
										 |  |  | use FireflyIII\User; | 
					
						
							| 
									
										
										
										
											2016-01-15 11:27:27 +01:00
										 |  |  | use Illuminate\Support\Collection; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-15 13:13:21 +01:00
										 |  |  | /** | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |  * Interface RuleGroupRepositoryInterface. | 
					
						
							| 
									
										
										
										
											2016-01-15 13:13:21 +01:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-01-15 11:27:27 +01:00
										 |  |  | interface RuleGroupRepositoryInterface | 
					
						
							| 
									
										
										
										
											2016-01-15 11:16:41 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2021-03-11 06:29:07 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Make sure rule group order is correct in DB. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function correctRuleGroupOrder(): void; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-24 16:50:55 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @return int | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-04-06 09:27:45 +02:00
										 |  |  |     public function count(): int; | 
					
						
							| 
									
										
										
										
											2016-01-24 16:50:55 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-15 11:27:27 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2020-07-11 15:13:15 +02:00
										 |  |  |      * @param RuleGroup      $ruleGroup | 
					
						
							| 
									
										
										
										
											2017-01-14 19:43:33 +01:00
										 |  |  |      * @param RuleGroup|null $moveTo | 
					
						
							| 
									
										
										
										
											2016-01-15 11:27:27 +01:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2017-07-23 19:06:24 +02:00
										 |  |  |     public function destroy(RuleGroup $ruleGroup, ?RuleGroup $moveTo): bool; | 
					
						
							| 
									
										
										
										
											2016-01-15 11:27:27 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-12 06:20:01 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Delete everything. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function destroyAll(): void; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-23 12:10:22 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param int $ruleGroupId | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-07-22 21:09:57 +02:00
										 |  |  |      * @return RuleGroup|null | 
					
						
							| 
									
										
										
										
											2016-10-23 12:10:22 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-07-22 21:09:57 +02:00
										 |  |  |     public function find(int $ruleGroupId): ?RuleGroup; | 
					
						
							| 
									
										
										
										
											2016-10-23 12:10:22 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-13 06:39:05 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param string $title | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return RuleGroup|null | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function findByTitle(string $title): ?RuleGroup; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-15 11:27:27 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-02-28 21:32:59 +01:00
										 |  |  |      * Get all rule groups. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-01-19 13:59:54 +01:00
										 |  |  |      * @return Collection | 
					
						
							| 
									
										
										
										
											2016-01-15 11:27:27 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-04-06 09:27:45 +02:00
										 |  |  |     public function get(): Collection; | 
					
						
							| 
									
										
										
										
											2016-01-15 11:27:27 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-28 10:34:11 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @return Collection | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-05-29 18:28:28 +02:00
										 |  |  |     public function getActiveGroups(): Collection; | 
					
						
							| 
									
										
										
										
											2017-04-28 10:34:11 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-07 15:36:04 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param RuleGroup $group | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Collection | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getActiveRules(RuleGroup $group): Collection; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-28 10:34:11 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param RuleGroup $group | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Collection | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getActiveStoreRules(RuleGroup $group): Collection; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param RuleGroup $group | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Collection | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getActiveUpdateRules(RuleGroup $group): Collection; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-15 11:27:27 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2021-09-18 10:26:12 +02:00
										 |  |  |      * Also inactive groups. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2021-02-12 20:15:23 +01:00
										 |  |  |      * @param string|null $filter | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-02-17 17:27:41 +01:00
										 |  |  |      * @return Collection | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2021-09-18 10:26:12 +02:00
										 |  |  |     public function getAllRuleGroupsWithRules(?string $filter): Collection; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @return int | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getHighestOrderRuleGroup(): int; | 
					
						
							| 
									
										
										
										
											2016-02-17 17:27:41 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-17 05:39:56 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param string|null $filter | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Collection | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2021-09-18 10:26:12 +02:00
										 |  |  |     public function getRuleGroupsWithRules(?string $filter): Collection; | 
					
						
							| 
									
										
										
										
											2021-04-17 05:39:56 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-12 21:49:28 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param RuleGroup $group | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Collection | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getRules(RuleGroup $group): Collection; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-12 06:20:01 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Get highest possible order for a rule group. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return int | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function maxOrder(): int; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-15 11:27:27 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2021-03-14 10:41:17 +01:00
										 |  |  |     public function resetOrder(): bool; | 
					
						
							| 
									
										
										
										
											2016-01-15 11:27:27 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-01-15 17:38:09 +01:00
										 |  |  |      * @param RuleGroup $ruleGroup | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-01-15 11:27:27 +01:00
										 |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2021-03-14 10:41:17 +01:00
										 |  |  |     public function resetRuleOrder(RuleGroup $ruleGroup): bool; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-12 06:20:01 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param string $query | 
					
						
							|  |  |  |      * @param int    $limit | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Collection | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function searchRuleGroup(string $query, int $limit): Collection; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-21 09:15:40 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param RuleGroup $ruleGroup | 
					
						
							|  |  |  |      * @param int       $newOrder | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function setOrder(RuleGroup $ruleGroup, int $newOrder): void; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-30 16:40:49 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param User $user | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function setUser(User $user); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-15 11:27:27 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param array $data | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return RuleGroup | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-04-06 09:27:45 +02:00
										 |  |  |     public function store(array $data): RuleGroup; | 
					
						
							| 
									
										
										
										
											2016-01-15 11:27:27 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param RuleGroup $ruleGroup | 
					
						
							| 
									
										
										
										
											2021-03-05 07:03:28 +01:00
										 |  |  |      * @param array     $data | 
					
						
							| 
									
										
										
										
											2016-01-15 11:27:27 +01:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return RuleGroup | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-04-06 09:27:45 +02:00
										 |  |  |     public function update(RuleGroup $ruleGroup, array $data): RuleGroup; | 
					
						
							| 
									
										
										
										
											2016-01-28 21:50:20 +01:00
										 |  |  | } |