| 
									
										
										
										
											2015-02-09 07:23:39 +01:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2016-02-05 12:08:25 +01:00
										 |  |  | declare(strict_types = 1); | 
					
						
							| 
									
										
										
										
											2015-02-09 07:23:39 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Repositories\Account; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-29 21:27:51 +02:00
										 |  |  | use Carbon\Carbon; | 
					
						
							| 
									
										
										
										
											2015-02-14 14:25:29 +01:00
										 |  |  | use FireflyIII\Models\Account; | 
					
						
							| 
									
										
										
										
											2015-03-13 08:44:07 +01:00
										 |  |  | use FireflyIII\Models\Preference; | 
					
						
							| 
									
										
										
										
											2015-04-03 09:30:44 +02:00
										 |  |  | use FireflyIII\Models\Transaction; | 
					
						
							| 
									
										
										
										
											2015-03-29 21:27:51 +02:00
										 |  |  | use FireflyIII\Models\TransactionJournal; | 
					
						
							| 
									
										
										
										
											2015-04-07 18:48:34 +02:00
										 |  |  | use Illuminate\Pagination\LengthAwarePaginator; | 
					
						
							| 
									
										
										
										
											2015-03-13 08:44:07 +01:00
										 |  |  | use Illuminate\Support\Collection; | 
					
						
							| 
									
										
										
										
											2015-03-29 21:27:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-11 07:35:10 +01:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Interface AccountRepositoryInterface | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @package FireflyIII\Repositories\Account | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2015-02-09 07:23:39 +01:00
										 |  |  | interface AccountRepositoryInterface | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2016-02-04 08:53:15 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-04 21:23:37 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param array $types | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return int | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 16:22:12 +01:00
										 |  |  |     public function countAccounts(array $types): int; | 
					
						
							| 
									
										
										
										
											2015-04-04 21:23:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-14 14:25:29 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param Account $account | 
					
						
							| 
									
										
										
										
											2015-07-10 20:48:45 +02:00
										 |  |  |      * @param Account $moveTo | 
					
						
							| 
									
										
										
										
											2015-02-14 14:25:29 +01:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return boolean | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 16:22:12 +01:00
										 |  |  |     public function destroy(Account $account, Account $moveTo = null): bool; | 
					
						
							| 
									
										
										
										
											2015-02-14 14:25:29 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-13 08:44:07 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-02-05 09:25:15 +01:00
										 |  |  |      * @param int $accountId | 
					
						
							| 
									
										
										
										
											2015-04-04 21:23:37 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-01-19 13:59:54 +01:00
										 |  |  |      * @deprecated | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Account | 
					
						
							| 
									
										
										
										
											2015-04-04 21:23:37 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 16:22:12 +01:00
										 |  |  |     public function find(int $accountId): Account; | 
					
						
							| 
									
										
										
										
											2015-04-04 21:23:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-04 08:53:15 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Gets all the accounts by ID, for a given set. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param array $ids | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-02-23 15:54:13 +01:00
										 |  |  |      * @return \Illuminate\Support\Collection | 
					
						
							| 
									
										
										
										
											2016-02-04 08:53:15 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 16:22:12 +01:00
										 |  |  |     public function get(array $ids): Collection; | 
					
						
							| 
									
										
										
										
											2016-02-04 08:53:15 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-04 21:23:37 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-01-19 13:59:54 +01:00
										 |  |  |      * @param array $types | 
					
						
							| 
									
										
										
										
											2015-04-04 21:23:37 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-01-19 13:59:54 +01:00
										 |  |  |      * @return Collection | 
					
						
							| 
									
										
										
										
											2015-03-13 08:44:07 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 16:22:12 +01:00
										 |  |  |     public function getAccounts(array $types): Collection; | 
					
						
							| 
									
										
										
										
											2015-03-13 08:44:07 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-07 10:14:10 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2015-12-27 07:59:00 +01:00
										 |  |  |      * This method returns the users credit cards, along with some basic information about the | 
					
						
							|  |  |  |      * balance they have on their CC. To be used in the JSON boxes on the front page that say | 
					
						
							|  |  |  |      * how many bills there are still left to pay. The balance will be saved in field "balance". | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * To get the balance, the field "date" is necessary. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Carbon $date | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-04-07 10:14:10 +02:00
										 |  |  |      * @return Collection | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 16:22:12 +01:00
										 |  |  |     public function getCreditCards(Carbon $date): Collection; | 
					
						
							| 
									
										
										
										
											2015-04-07 10:14:10 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-13 20:43:58 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-01-19 13:59:54 +01:00
										 |  |  |      * @param TransactionJournal $journal | 
					
						
							|  |  |  |      * @param Account            $account | 
					
						
							| 
									
										
										
										
											2015-04-13 20:43:58 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-01-19 13:59:54 +01:00
										 |  |  |      * @return Transaction | 
					
						
							| 
									
										
										
										
											2015-04-13 20:43:58 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 16:22:12 +01:00
										 |  |  |     public function getFirstTransaction(TransactionJournal $journal, Account $account): Transaction; | 
					
						
							| 
									
										
										
										
											2015-04-13 20:43:58 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-13 08:44:07 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param Preference $preference | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Collection | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 16:22:12 +01:00
										 |  |  |     public function getFrontpageAccounts(Preference $preference): Collection; | 
					
						
							| 
									
										
										
										
											2015-03-13 08:44:07 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param Account $account | 
					
						
							|  |  |  |      * @param Carbon  $start | 
					
						
							|  |  |  |      * @param Carbon  $end | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-02-06 16:22:12 +01:00
										 |  |  |      * @return Collection | 
					
						
							| 
									
										
										
										
											2015-03-13 08:44:07 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 16:22:12 +01:00
										 |  |  |     public function getFrontpageTransactions(Account $account, Carbon $start, Carbon $end): Collection; | 
					
						
							| 
									
										
										
										
											2015-03-13 08:44:07 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-14 14:25:29 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param Account $account | 
					
						
							| 
									
										
										
										
											2015-05-05 10:23:01 +02:00
										 |  |  |      * @param         $page | 
					
						
							| 
									
										
										
										
											2015-02-14 14:25:29 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-04-07 18:48:34 +02:00
										 |  |  |      * @return LengthAwarePaginator | 
					
						
							| 
									
										
										
										
											2015-02-14 14:25:29 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 16:22:12 +01:00
										 |  |  |     public function getJournals(Account $account, $page): LengthAwarePaginator; | 
					
						
							| 
									
										
										
										
											2015-02-14 14:25:29 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-07 20:54:43 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-01-19 13:59:54 +01:00
										 |  |  |      * Get the accounts of a user that have piggy banks connected to them. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Collection | 
					
						
							| 
									
										
										
										
											2015-04-07 20:54:43 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 16:22:12 +01:00
										 |  |  |     public function getPiggyBankAccounts(): Collection; | 
					
						
							| 
									
										
										
										
											2015-04-07 20:54:43 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-21 12:16:41 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2015-04-04 21:23:37 +02:00
										 |  |  |      * Get savings accounts and the balance difference in the period. | 
					
						
							| 
									
										
										
										
											2015-02-21 12:16:41 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-04-04 21:23:37 +02:00
										 |  |  |      * @return Collection | 
					
						
							| 
									
										
										
										
											2015-02-21 12:16:41 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 16:22:12 +01:00
										 |  |  |     public function getSavingsAccounts() : Collection; | 
					
						
							| 
									
										
										
										
											2015-02-14 14:25:29 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-21 12:16:41 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param Account $account | 
					
						
							| 
									
										
										
										
											2015-05-20 19:55:53 +02:00
										 |  |  |      * @param Carbon  $date | 
					
						
							| 
									
										
										
										
											2015-02-21 12:16:41 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-02-06 16:22:12 +01:00
										 |  |  |      * @return string | 
					
						
							| 
									
										
										
										
											2015-02-21 12:16:41 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 16:22:12 +01:00
										 |  |  |     public function leftOnAccount(Account $account, Carbon $date): string; | 
					
						
							| 
									
										
										
										
											2015-02-24 21:10:25 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param Account $account | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-02-06 16:22:12 +01:00
										 |  |  |      * @return TransactionJournal | 
					
						
							| 
									
										
										
										
											2015-02-24 21:10:25 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 16:22:12 +01:00
										 |  |  |     public function openingBalanceTransaction(Account $account) : TransactionJournal; | 
					
						
							| 
									
										
										
										
											2015-03-21 08:51:34 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2015-04-04 21:23:37 +02:00
										 |  |  |      * @param array $data | 
					
						
							| 
									
										
										
										
											2015-03-21 08:51:34 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-04-04 21:23:37 +02:00
										 |  |  |      * @return Account | 
					
						
							| 
									
										
										
										
											2015-03-21 08:51:34 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 16:22:12 +01:00
										 |  |  |     public function store(array $data) : Account; | 
					
						
							| 
									
										
										
										
											2015-04-03 09:30:44 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-19 13:59:54 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 16:22:12 +01:00
										 |  |  |     public function sumOfEverything() : string; | 
					
						
							| 
									
										
										
										
											2016-01-19 13:59:54 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-03 09:30:44 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2015-04-04 21:23:37 +02:00
										 |  |  |      * @param Account $account | 
					
						
							|  |  |  |      * @param array   $data | 
					
						
							| 
									
										
										
										
											2015-04-03 09:30:44 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-04-04 21:23:37 +02:00
										 |  |  |      * @return Account | 
					
						
							| 
									
										
										
										
											2015-04-03 09:30:44 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-06 16:22:12 +01:00
										 |  |  |     public function update(Account $account, array $data): Account; | 
					
						
							| 
									
										
										
										
											2015-03-29 08:14:32 +02:00
										 |  |  | } |