| 
									
										
										
										
											2016-05-20 08:57:45 +02:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2016-05-20 12:41:23 +02:00
										 |  |  | /** | 
					
						
							|  |  |  |  * TransactionJournal.php | 
					
						
							|  |  |  |  * Copyright (C) 2016 thegrumpydictator@gmail.com | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2016-10-05 06:52:15 +02:00
										 |  |  |  * This software may be modified and distributed under the terms of the | 
					
						
							|  |  |  |  * Creative Commons Attribution-ShareAlike 4.0 International License. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * See the LICENSE file for details. | 
					
						
							| 
									
										
										
										
											2016-05-20 12:41:23 +02:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-20 08:57:45 +02:00
										 |  |  | declare(strict_types = 1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Models; | 
					
						
							| 
									
										
										
										
											2015-02-06 04:52:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-07 08:23:44 +01:00
										 |  |  | use Carbon\Carbon; | 
					
						
							| 
									
										
										
										
											2015-02-07 06:49:24 +01:00
										 |  |  | use Crypt; | 
					
						
							| 
									
										
										
										
											2016-09-09 11:19:40 +02:00
										 |  |  | use FireflyIII\Support\CacheProperties; | 
					
						
							| 
									
										
										
										
											2016-03-02 19:41:22 +01:00
										 |  |  | use FireflyIII\Support\Models\TransactionJournalSupport; | 
					
						
							| 
									
										
										
										
											2015-02-07 08:23:44 +01:00
										 |  |  | use Illuminate\Database\Eloquent\Builder as EloquentBuilder; | 
					
						
							| 
									
										
										
										
											2015-02-22 08:38:46 +01:00
										 |  |  | use Illuminate\Database\Eloquent\Relations\HasMany; | 
					
						
							| 
									
										
										
										
											2015-02-07 23:19:28 +01:00
										 |  |  | use Illuminate\Database\Eloquent\SoftDeletes; | 
					
						
							| 
									
										
										
										
											2016-09-09 11:19:40 +02:00
										 |  |  | use Log; | 
					
						
							|  |  |  | use Preferences; | 
					
						
							| 
									
										
										
										
											2016-01-09 15:53:11 +01:00
										 |  |  | use Symfony\Component\HttpKernel\Exception\NotFoundHttpException; | 
					
						
							| 
									
										
										
										
											2016-01-18 13:15:11 +01:00
										 |  |  | use Watson\Validating\ValidatingTrait; | 
					
						
							| 
									
										
										
										
											2015-02-07 08:23:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-02 11:59:39 +01:00
										 |  |  | /** | 
					
						
							|  |  |  |  * FireflyIII\Models\TransactionJournal | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2016-03-02 12:03:04 +01:00
										 |  |  |  * @property integer                                                                                   $id | 
					
						
							|  |  |  |  * @property \Carbon\Carbon                                                                            $created_at | 
					
						
							|  |  |  |  * @property \Carbon\Carbon                                                                            $updated_at | 
					
						
							|  |  |  |  * @property \Carbon\Carbon                                                                            $deleted_at | 
					
						
							|  |  |  |  * @property integer                                                                                   $user_id | 
					
						
							|  |  |  |  * @property integer                                                                                   $transaction_type_id | 
					
						
							|  |  |  |  * @property integer                                                                                   $bill_id | 
					
						
							|  |  |  |  * @property integer                                                                                   $transaction_currency_id | 
					
						
							|  |  |  |  * @property string                                                                                    $description | 
					
						
							|  |  |  |  * @property boolean                                                                                   $completed | 
					
						
							|  |  |  |  * @property \Carbon\Carbon                                                                            $date | 
					
						
							|  |  |  |  * @property \Carbon\Carbon                                                                            $interest_date | 
					
						
							|  |  |  |  * @property \Carbon\Carbon                                                                            $book_date | 
					
						
							|  |  |  |  * @property boolean                                                                                   $encrypted | 
					
						
							|  |  |  |  * @property integer                                                                                   $order | 
					
						
							|  |  |  |  * @property integer                                                                                   $tag_count | 
					
						
							|  |  |  |  * @property-read \Illuminate\Database\Eloquent\Collection|\FireflyIII\Models\Attachment[]             $attachments | 
					
						
							|  |  |  |  * @property-read \FireflyIII\Models\Bill                                                              $bill | 
					
						
							|  |  |  |  * @property-read \Illuminate\Database\Eloquent\Collection|\FireflyIII\Models\Budget[]                 $budgets | 
					
						
							|  |  |  |  * @property-read \Illuminate\Database\Eloquent\Collection|\FireflyIII\Models\Category[]               $categories | 
					
						
							|  |  |  |  * @property-read \Illuminate\Database\Eloquent\Collection|\FireflyIII\Models\PiggyBankEvent[]         $piggyBankEvents | 
					
						
							|  |  |  |  * @property-read \Illuminate\Database\Eloquent\Collection|\FireflyIII\Models\Tag[]                    $tags | 
					
						
							|  |  |  |  * @property-read \FireflyIII\Models\TransactionCurrency                                               $transactionCurrency | 
					
						
							|  |  |  |  * @property-read \FireflyIII\Models\TransactionType                                                   $transactionType | 
					
						
							|  |  |  |  * @property-read \Illuminate\Database\Eloquent\Collection|\FireflyIII\Models\TransactionGroup[]       $transactiongroups | 
					
						
							| 
									
										
										
										
											2016-03-02 11:59:39 +01:00
										 |  |  |  * @property-read \Illuminate\Database\Eloquent\Collection|\FireflyIII\Models\TransactionJournalMeta[] $transactionjournalmeta | 
					
						
							| 
									
										
										
										
											2016-03-02 12:03:04 +01:00
										 |  |  |  * @property-read \Illuminate\Database\Eloquent\Collection|\FireflyIII\Models\Transaction[]            $transactions | 
					
						
							|  |  |  |  * @property-read \FireflyIII\User                                                                     $user | 
					
						
							| 
									
										
										
										
											2016-03-02 11:59:39 +01:00
										 |  |  |  * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\TransactionJournal after($date) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\TransactionJournal before($date) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\TransactionJournal transactionTypes($types) | 
					
						
							| 
									
										
										
										
											2016-05-20 11:27:41 +02:00
										 |  |  |  * @property string                                                                                    $transaction_type_type | 
					
						
							| 
									
										
										
										
											2016-03-12 07:17:00 +01:00
										 |  |  |  * @property-read string                                                                               $transaction_currency_code | 
					
						
							|  |  |  |  * @property-read string                                                                               $destination_amount | 
					
						
							| 
									
										
										
										
											2016-05-20 11:27:41 +02:00
										 |  |  |  * @property string                                                                                    $destination_account_id | 
					
						
							|  |  |  |  * @property string                                                                                    $destination_account_name | 
					
						
							| 
									
										
										
										
											2016-03-12 07:17:00 +01:00
										 |  |  |  * @property-read string                                                                               $destination_account_type | 
					
						
							|  |  |  |  * @property-read string                                                                               $source_amount | 
					
						
							| 
									
										
										
										
											2016-05-20 11:27:41 +02:00
										 |  |  |  * @property string                                                                                    $source_account_id | 
					
						
							|  |  |  |  * @property string                                                                                    $source_account_name | 
					
						
							| 
									
										
										
										
											2016-03-12 07:17:00 +01:00
										 |  |  |  * @property-read string                                                                               $source_account_type | 
					
						
							| 
									
										
										
										
											2016-03-14 20:51:34 +01:00
										 |  |  |  * @property \Carbon\Carbon                                                                            $process_date | 
					
						
							| 
									
										
										
										
											2016-03-14 20:47:13 +01:00
										 |  |  |  * @property int                                                                                       $account_id | 
					
						
							|  |  |  |  * @property float                                                                                     $journalAmount | 
					
						
							|  |  |  |  * @property string                                                                                    $account_name | 
					
						
							| 
									
										
										
										
											2016-03-14 20:51:34 +01:00
										 |  |  |  * @property int                                                                                       $budget_id | 
					
						
							| 
									
										
										
										
											2016-03-12 07:36:23 +01:00
										 |  |  |  * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\TransactionJournal whereId($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\TransactionJournal whereCreatedAt($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\TransactionJournal whereUpdatedAt($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\TransactionJournal whereDeletedAt($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\TransactionJournal whereUserId($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\TransactionJournal whereTransactionTypeId($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\TransactionJournal whereBillId($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\TransactionJournal whereTransactionCurrencyId($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\TransactionJournal whereDescription($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\TransactionJournal whereCompleted($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\TransactionJournal whereDate($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\TransactionJournal whereInterestDate($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\TransactionJournal whereBookDate($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\TransactionJournal whereProcessDate($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\TransactionJournal whereEncrypted($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\TransactionJournal whereOrder($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\TransactionJournal whereTagCount($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\TransactionJournal expanded() | 
					
						
							|  |  |  |  * @mixin \Eloquent | 
					
						
							| 
									
										
										
										
											2016-05-20 08:00:35 +02:00
										 |  |  |  * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\TransactionJournal sortCorrectly() | 
					
						
							| 
									
										
										
										
											2016-10-10 06:50:24 +02:00
										 |  |  |  * @property-read \Illuminate\Database\Eloquent\Collection|\FireflyIII\Models\TransactionJournalMeta[] $transactionJournalMeta | 
					
						
							| 
									
										
										
										
											2016-03-02 11:59:39 +01:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-03-02 19:41:22 +01:00
										 |  |  | class TransactionJournal extends TransactionJournalSupport | 
					
						
							| 
									
										
										
										
											2015-02-06 05:04:06 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2016-01-18 13:15:11 +01:00
										 |  |  |     use SoftDeletes, ValidatingTrait; | 
					
						
							| 
									
										
										
										
											2015-02-09 07:56:24 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-27 19:35:00 +01:00
										 |  |  |     /** @var array */ | 
					
						
							| 
									
										
										
										
											2016-03-12 07:37:13 +01:00
										 |  |  |     protected $dates = ['created_at', 'updated_at', 'date', 'deleted_at', 'interest_date', 'book_date', 'process_date']; | 
					
						
							| 
									
										
										
										
											2016-01-27 19:35:00 +01:00
										 |  |  |     /** @var array */ | 
					
						
							| 
									
										
										
										
											2015-06-14 11:52:07 +02:00
										 |  |  |     protected $fillable | 
					
						
							| 
									
										
										
										
											2016-03-12 07:37:13 +01:00
										 |  |  |         = ['user_id', 'transaction_type_id', 'bill_id', 'interest_date', 'book_date', 'process_date', | 
					
						
							| 
									
										
										
										
											2016-03-02 11:50:37 +01:00
										 |  |  |            'transaction_currency_id', 'description', 'completed', | 
					
						
							| 
									
										
										
										
											2016-03-12 07:37:13 +01:00
										 |  |  |            'date', 'rent_date', 'encrypted', 'tag_count']; | 
					
						
							| 
									
										
										
										
											2016-01-27 19:35:00 +01:00
										 |  |  |     /** @var array */ | 
					
						
							| 
									
										
										
										
											2015-06-14 11:52:07 +02:00
										 |  |  |     protected $hidden = ['encrypted']; | 
					
						
							| 
									
										
										
										
											2016-01-27 19:35:00 +01:00
										 |  |  |     /** @var array */ | 
					
						
							| 
									
										
										
										
											2016-01-18 13:15:11 +01:00
										 |  |  |     protected $rules | 
					
						
							| 
									
										
										
										
											2016-01-27 19:35:00 +01:00
										 |  |  |         = [ | 
					
						
							| 
									
										
										
										
											2016-01-18 13:15:11 +01:00
										 |  |  |             'user_id'                 => 'required|exists:users,id', | 
					
						
							|  |  |  |             'transaction_type_id'     => 'required|exists:transaction_types,id', | 
					
						
							|  |  |  |             'transaction_currency_id' => 'required|exists:transaction_currencies,id', | 
					
						
							|  |  |  |             'description'             => 'required|between:1,1024', | 
					
						
							|  |  |  |             'completed'               => 'required|boolean', | 
					
						
							|  |  |  |             'date'                    => 'required|date', | 
					
						
							|  |  |  |             'encrypted'               => 'required|boolean', | 
					
						
							|  |  |  |         ]; | 
					
						
							| 
									
										
										
										
											2015-02-06 04:52:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-27 18:31:44 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param $value | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return mixed | 
					
						
							|  |  |  |      * @throws NotFoundHttpException | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public static function routeBinder($value) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-09-16 12:07:45 +02:00
										 |  |  |         if (auth()->check()) { | 
					
						
							| 
									
										
										
										
											2016-01-27 18:31:44 +01:00
										 |  |  |             $validTypes = [TransactionType::WITHDRAWAL, TransactionType::DEPOSIT, TransactionType::TRANSFER]; | 
					
						
							|  |  |  |             $object     = TransactionJournal::where('transaction_journals.id', $value) | 
					
						
							|  |  |  |                                             ->leftJoin('transaction_types', 'transaction_types.id', '=', 'transaction_journals.transaction_type_id') | 
					
						
							|  |  |  |                                             ->whereIn('transaction_types.type', $validTypes) | 
					
						
							| 
									
										
										
										
											2016-09-16 12:15:58 +02:00
										 |  |  |                                             ->where('user_id', auth()->user()->id)->first(['transaction_journals.*']); | 
					
						
							| 
									
										
										
										
											2016-01-27 18:31:44 +01:00
										 |  |  |             if ($object) { | 
					
						
							|  |  |  |                 return $object; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         throw new NotFoundHttpException; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @return \Illuminate\Database\Eloquent\Relations\MorphMany | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function attachments() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->morphMany('FireflyIII\Models\Attachment', 'attachable'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-11 07:35:10 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @return \Illuminate\Database\Eloquent\Relations\BelongsTo | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-02-06 05:14:27 +01:00
										 |  |  |     public function bill() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-02-06 05:35:00 +01:00
										 |  |  |         return $this->belongsTo('FireflyIII\Models\Bill'); | 
					
						
							| 
									
										
										
										
											2015-02-06 05:14:27 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-11 07:35:10 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @return \Illuminate\Database\Eloquent\Relations\BelongsToMany | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-02-06 05:14:27 +01:00
										 |  |  |     public function budgets() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-02-06 05:35:00 +01:00
										 |  |  |         return $this->belongsToMany('FireflyIII\Models\Budget'); | 
					
						
							| 
									
										
										
										
											2015-02-06 05:14:27 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-11 07:35:10 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @return \Illuminate\Database\Eloquent\Relations\BelongsToMany | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-02-06 05:14:27 +01:00
										 |  |  |     public function categories() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-02-06 05:35:00 +01:00
										 |  |  |         return $this->belongsToMany('FireflyIII\Models\Category'); | 
					
						
							| 
									
										
										
										
											2015-02-06 05:14:27 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-09 11:19:40 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param string $name | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function deleteMeta(string $name):bool | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->transactionJournalMeta()->where('name', $name)->delete(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-11 07:35:10 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2015-05-14 09:51:54 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-02-11 07:35:10 +01:00
										 |  |  |      * @param $value | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-02-06 05:14:27 +01:00
										 |  |  |     public function getDescriptionAttribute($value) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if ($this->encrypted) { | 
					
						
							|  |  |  |             return Crypt::decrypt($value); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $value; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-03-02 11:56:47 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-02 11:50:37 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-09-09 11:19:40 +02:00
										 |  |  |      * @param string $name | 
					
						
							| 
									
										
										
										
											2016-03-02 11:50:37 +01:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-09-09 11:19:40 +02:00
										 |  |  |     public function getMeta(string $name) | 
					
						
							| 
									
										
										
										
											2016-03-02 11:50:37 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-09-09 11:19:40 +02:00
										 |  |  |         $value = null; | 
					
						
							|  |  |  |         $cache = new CacheProperties; | 
					
						
							|  |  |  |         $cache->addProperty('journal-meta'); | 
					
						
							|  |  |  |         $cache->addProperty($this->id); | 
					
						
							|  |  |  |         $cache->addProperty($name); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							|  |  |  |             return $cache->get(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         Log::debug(sprintf('Looking for journal #%d meta field "%s".', $this->id, $name)); | 
					
						
							|  |  |  |         $entry = $this->transactionJournalMeta()->where('name', $name)->first(); | 
					
						
							|  |  |  |         if (!is_null($entry)) { | 
					
						
							|  |  |  |             $value = $entry->data; | 
					
						
							|  |  |  |             // cache:
 | 
					
						
							|  |  |  |             $cache->store($value); | 
					
						
							| 
									
										
										
										
											2016-03-02 11:50:37 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-09 11:19:40 +02:00
										 |  |  |         // convert to Carbon if name is _date
 | 
					
						
							|  |  |  |         if (!is_null($value) && substr($name, -5) === '_date') { | 
					
						
							|  |  |  |             $value = new Carbon($value); | 
					
						
							|  |  |  |             // cache:
 | 
					
						
							|  |  |  |             $cache->store($value); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $value; | 
					
						
							| 
									
										
										
										
											2016-03-02 11:50:37 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-10 18:36:52 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param string $name | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function hasMeta(string $name): bool | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return !is_null($this->getMeta($name)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-27 18:31:44 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function isDeposit() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-03-02 12:03:04 +01:00
										 |  |  |         if (!is_null($this->transaction_type_type)) { | 
					
						
							|  |  |  |             return $this->transaction_type_type == TransactionType::DEPOSIT; | 
					
						
							| 
									
										
										
										
											2016-01-27 18:31:44 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $this->transactionType->isDeposit(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-03-02 11:58:31 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-01-27 18:31:44 +01:00
										 |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function isOpeningBalance() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-03-02 12:03:04 +01:00
										 |  |  |         if (!is_null($this->transaction_type_type)) { | 
					
						
							|  |  |  |             return $this->transaction_type_type == TransactionType::OPENING_BALANCE; | 
					
						
							| 
									
										
										
										
											2016-01-27 18:31:44 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $this->transactionType->isOpeningBalance(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-03-02 11:58:31 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-01-27 18:31:44 +01:00
										 |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function isTransfer() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-03-02 12:03:04 +01:00
										 |  |  |         if (!is_null($this->transaction_type_type)) { | 
					
						
							|  |  |  |             return $this->transaction_type_type == TransactionType::TRANSFER; | 
					
						
							| 
									
										
										
										
											2016-01-27 18:31:44 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $this->transactionType->isTransfer(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-03-02 11:58:31 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-01-27 18:31:44 +01:00
										 |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function isWithdrawal() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-03-02 12:03:04 +01:00
										 |  |  |         if (!is_null($this->transaction_type_type)) { | 
					
						
							|  |  |  |             return $this->transaction_type_type == TransactionType::WITHDRAWAL; | 
					
						
							| 
									
										
										
										
											2016-01-27 18:31:44 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $this->transactionType->isWithdrawal(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-11 07:35:10 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @return \Illuminate\Database\Eloquent\Relations\HasMany | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-02-06 05:14:27 +01:00
										 |  |  |     public function piggyBankEvents() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-02-06 05:35:00 +01:00
										 |  |  |         return $this->hasMany('FireflyIII\Models\PiggyBankEvent'); | 
					
						
							| 
									
										
										
										
											2015-02-06 05:14:27 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-27 18:31:44 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Save the model to the database. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param  array $options | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function save(array $options = []) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $count           = $this->tags()->count(); | 
					
						
							|  |  |  |         $this->tag_count = $count; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return parent::save($options); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-07 08:23:44 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2015-05-14 09:51:54 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-02-07 08:23:44 +01:00
										 |  |  |      * @param EloquentBuilder $query | 
					
						
							|  |  |  |      * @param Carbon          $date | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-05-26 18:57:31 +00:00
										 |  |  |      * @return EloquentBuilder | 
					
						
							| 
									
										
										
										
											2015-02-07 08:23:44 +01:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function scopeAfter(EloquentBuilder $query, Carbon $date) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $query->where('transaction_journals.date', '>=', $date->format('Y-m-d 00:00:00')); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2015-05-14 09:51:54 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-02-07 08:23:44 +01:00
										 |  |  |      * @param EloquentBuilder $query | 
					
						
							|  |  |  |      * @param Carbon          $date | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-05-26 18:57:31 +00:00
										 |  |  |      * @return EloquentBuilder | 
					
						
							| 
									
										
										
										
											2015-02-07 08:23:44 +01:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function scopeBefore(EloquentBuilder $query, Carbon $date) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $query->where('transaction_journals.date', '<=', $date->format('Y-m-d 00:00:00')); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-02 12:09:34 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param EloquentBuilder $query | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function scopeExpanded(EloquentBuilder $query) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         // left join transaction type:
 | 
					
						
							| 
									
										
										
										
											2016-03-02 12:52:36 +01:00
										 |  |  |         if (!self::isJoined($query, 'transaction_types')) { | 
					
						
							|  |  |  |             $query->leftJoin('transaction_types', 'transaction_types.id', '=', 'transaction_journals.transaction_type_id'); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-03-02 12:09:34 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-02 12:25:00 +01:00
										 |  |  |         // left join transaction currency:
 | 
					
						
							|  |  |  |         $query->leftJoin('transaction_currencies', 'transaction_currencies.id', '=', 'transaction_journals.transaction_currency_id'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-16 09:09:54 +02:00
										 |  |  |         // extend group by:
 | 
					
						
							|  |  |  |         $query->groupBy( | 
					
						
							|  |  |  |             [ | 
					
						
							|  |  |  |                 'transaction_journals.id', | 
					
						
							|  |  |  |                 'transaction_journals.created_at', | 
					
						
							|  |  |  |                 'transaction_journals.updated_at', | 
					
						
							|  |  |  |                 'transaction_journals.deleted_at', | 
					
						
							|  |  |  |                 'transaction_journals.user_id', | 
					
						
							|  |  |  |                 'transaction_journals.transaction_type_id', | 
					
						
							|  |  |  |                 'transaction_journals.bill_id', | 
					
						
							|  |  |  |                 'transaction_journals.transaction_currency_id', | 
					
						
							|  |  |  |                 'transaction_journals.description', | 
					
						
							|  |  |  |                 'transaction_journals.date', | 
					
						
							|  |  |  |                 'transaction_journals.interest_date', | 
					
						
							|  |  |  |                 'transaction_journals.book_date', | 
					
						
							|  |  |  |                 'transaction_journals.process_date', | 
					
						
							|  |  |  |                 'transaction_journals.order', | 
					
						
							|  |  |  |                 'transaction_journals.tag_count', | 
					
						
							|  |  |  |                 'transaction_journals.encrypted', | 
					
						
							|  |  |  |                 'transaction_journals.completed', | 
					
						
							|  |  |  |                 'transaction_types.type', | 
					
						
							|  |  |  |                 'transaction_currencies.code', | 
					
						
							| 
									
										
										
										
											2016-09-16 12:07:45 +02:00
										 |  |  |             ] | 
					
						
							|  |  |  |         ); | 
					
						
							| 
									
										
										
										
											2016-05-11 07:57:16 +02:00
										 |  |  |         $query->with(['categories', 'budgets', 'attachments', 'bill', 'transactions']); | 
					
						
							| 
									
										
										
										
											2016-03-02 12:09:34 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-20 11:27:41 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param EloquentBuilder $query | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function scopeSortCorrectly(EloquentBuilder $query) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $query->orderBy('transaction_journals.date', 'DESC'); | 
					
						
							|  |  |  |         $query->orderBy('transaction_journals.order', 'ASC'); | 
					
						
							|  |  |  |         $query->orderBy('transaction_journals.id', 'DESC'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-07 08:23:44 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2015-05-14 09:51:54 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-02-07 08:23:44 +01:00
										 |  |  |      * @param EloquentBuilder $query | 
					
						
							|  |  |  |      * @param array           $types | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function scopeTransactionTypes(EloquentBuilder $query, array $types) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-03-02 12:47:15 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-02 12:52:36 +01:00
										 |  |  |         if (!self::isJoined($query, 'transaction_types')) { | 
					
						
							| 
									
										
										
										
											2016-03-02 12:47:15 +01:00
										 |  |  |             $query->leftJoin('transaction_types', 'transaction_types.id', '=', 'transaction_journals.transaction_type_id'); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2015-02-07 08:23:44 +01:00
										 |  |  |         $query->whereIn('transaction_types.type', $types); | 
					
						
							| 
									
										
										
										
											2016-05-15 18:36:40 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-02-07 08:23:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-11 07:35:10 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2015-05-14 09:51:54 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-02-11 07:35:10 +01:00
										 |  |  |      * @param $value | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-02-06 05:14:27 +01:00
										 |  |  |     public function setDescriptionAttribute($value) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-05-08 14:00:49 +02:00
										 |  |  |         $this->attributes['description'] = Crypt::encrypt($value); | 
					
						
							| 
									
										
										
										
											2015-02-06 05:14:27 +01:00
										 |  |  |         $this->attributes['encrypted']   = true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-18 09:49:19 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-09-09 11:19:40 +02:00
										 |  |  |      * @param string $name | 
					
						
							|  |  |  |      * @param        $value | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return TransactionJournalMeta | 
					
						
							| 
									
										
										
										
											2015-07-18 09:49:19 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-09-09 11:19:40 +02:00
										 |  |  |     public function setMeta(string $name, $value): TransactionJournalMeta | 
					
						
							| 
									
										
										
										
											2015-07-18 09:49:19 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-09-09 11:19:40 +02:00
										 |  |  |         if (is_null($value)) { | 
					
						
							|  |  |  |             $this->deleteMeta($name); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             return new TransactionJournalMeta(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($value instanceof Carbon) { | 
					
						
							|  |  |  |             $value = $value->toW3cString(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         Log::debug(sprintf('Going to set "%s" with value "%s"', $name, json_encode($value))); | 
					
						
							|  |  |  |         $entry = $this->transactionJournalMeta()->where('name', $name)->first(); | 
					
						
							|  |  |  |         if (is_null($entry)) { | 
					
						
							|  |  |  |             $entry = new TransactionJournalMeta(); | 
					
						
							|  |  |  |             $entry->transactionJournal()->associate($this); | 
					
						
							|  |  |  |             $entry->name = $name; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $entry->data = $value; | 
					
						
							|  |  |  |         $entry->save(); | 
					
						
							|  |  |  |         Preferences::mark(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $entry; | 
					
						
							| 
									
										
										
										
											2015-07-18 09:49:19 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-11 07:35:10 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-09-09 11:19:40 +02:00
										 |  |  |      * @return \Illuminate\Database\Eloquent\Relations\BelongsToMany | 
					
						
							| 
									
										
										
										
											2015-02-11 07:35:10 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-09-09 11:19:40 +02:00
										 |  |  |     public function tags() | 
					
						
							| 
									
										
										
										
											2015-02-06 05:14:27 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-09-09 11:19:40 +02:00
										 |  |  |         return $this->belongsToMany('FireflyIII\Models\Tag'); | 
					
						
							| 
									
										
										
										
											2015-02-06 05:14:27 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-11 07:35:10 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @return \Illuminate\Database\Eloquent\Relations\BelongsTo | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-09-09 11:19:40 +02:00
										 |  |  |     public function transactionCurrency() | 
					
						
							| 
									
										
										
										
											2015-02-06 05:14:27 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-09-09 11:19:40 +02:00
										 |  |  |         return $this->belongsTo('FireflyIII\Models\TransactionCurrency'); | 
					
						
							| 
									
										
										
										
											2015-02-06 05:14:27 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-11 07:35:10 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-09-09 11:19:40 +02:00
										 |  |  |      * @return HasMany | 
					
						
							| 
									
										
										
										
											2015-02-11 07:35:10 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-09-09 11:19:40 +02:00
										 |  |  |     public function transactionJournalMeta(): HasMany | 
					
						
							| 
									
										
										
										
											2015-02-06 05:14:27 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-09-09 11:19:40 +02:00
										 |  |  |         return $this->hasMany('FireflyIII\Models\TransactionJournalMeta'); | 
					
						
							| 
									
										
										
										
											2015-02-06 05:14:27 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-10 16:26:42 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-09-09 11:19:40 +02:00
										 |  |  |      * @return \Illuminate\Database\Eloquent\Relations\BelongsTo | 
					
						
							| 
									
										
										
										
											2016-02-10 16:26:42 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-09-09 11:19:40 +02:00
										 |  |  |     public function transactionType() | 
					
						
							| 
									
										
										
										
											2016-02-10 16:26:42 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-09-09 11:19:40 +02:00
										 |  |  |         return $this->belongsTo('FireflyIII\Models\TransactionType'); | 
					
						
							| 
									
										
										
										
											2016-02-10 16:26:42 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-11 07:35:10 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-01-27 18:31:44 +01:00
										 |  |  |      * @return \Illuminate\Database\Eloquent\Relations\HasMany | 
					
						
							| 
									
										
										
										
											2015-12-09 22:39:50 -02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-01-27 18:31:44 +01:00
										 |  |  |     public function transactions() | 
					
						
							| 
									
										
										
										
											2015-12-09 22:39:50 -02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-01-27 18:31:44 +01:00
										 |  |  |         return $this->hasMany('FireflyIII\Models\Transaction'); | 
					
						
							| 
									
										
										
										
											2015-12-09 22:39:50 -02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-01-09 15:53:11 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-01-27 18:31:44 +01:00
										 |  |  |      * @return \Illuminate\Database\Eloquent\Relations\BelongsTo | 
					
						
							| 
									
										
										
										
											2016-01-09 15:53:11 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-01-27 18:31:44 +01:00
										 |  |  |     public function user() | 
					
						
							| 
									
										
										
										
											2016-01-09 15:53:11 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-01-27 18:31:44 +01:00
										 |  |  |         return $this->belongsTo('FireflyIII\User'); | 
					
						
							| 
									
										
										
										
											2016-01-09 15:53:11 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-09-09 11:19:40 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-06 04:52:16 +01:00
										 |  |  | } |