| 
									
										
										
										
											2018-06-10 16:59:03 +02:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * RecurrenceTransaction.php | 
					
						
							| 
									
										
										
										
											2020-02-16 13:55:32 +01:00
										 |  |  |  * Copyright (c) 2019 james@firefly-iii.org | 
					
						
							| 
									
										
										
										
											2018-06-10 16:59:03 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This file is part of Firefly III (https://github.com/firefly-iii). | 
					
						
							| 
									
										
										
										
											2018-06-10 16:59:03 +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. | 
					
						
							| 
									
										
										
										
											2018-06-10 16:59:03 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							| 
									
										
										
										
											2018-06-10 16:59:03 +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. | 
					
						
							| 
									
										
										
										
											2018-06-10 16:59:03 +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/>. | 
					
						
							| 
									
										
										
										
											2018-06-10 16:59:03 +02:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | declare(strict_types=1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Models; | 
					
						
							| 
									
										
										
										
											2021-08-28 15:47:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-10 06:51:59 +01:00
										 |  |  | use Carbon\Carbon; | 
					
						
							| 
									
										
										
										
											2020-03-17 16:46:00 +01:00
										 |  |  | use Eloquent; | 
					
						
							| 
									
										
										
										
											2023-12-10 06:51:59 +01:00
										 |  |  | use FireflyIII\Support\Models\ReturnsIntegerIdTrait; | 
					
						
							| 
									
										
										
										
											2023-01-02 06:44:52 +01:00
										 |  |  | use Illuminate\Database\Eloquent\Casts\Attribute; | 
					
						
							| 
									
										
										
										
											2021-08-28 15:47:09 +02:00
										 |  |  | use Illuminate\Database\Eloquent\Collection; | 
					
						
							| 
									
										
										
										
											2018-06-10 16:59:03 +02:00
										 |  |  | use Illuminate\Database\Eloquent\Model; | 
					
						
							|  |  |  | use Illuminate\Database\Eloquent\Relations\BelongsTo; | 
					
						
							|  |  |  | use Illuminate\Database\Eloquent\Relations\HasMany; | 
					
						
							| 
									
										
										
										
											2018-06-20 21:16:42 +02:00
										 |  |  | use Illuminate\Database\Eloquent\SoftDeletes; | 
					
						
							| 
									
										
										
										
											2020-03-17 16:46:00 +01:00
										 |  |  | use Illuminate\Database\Query\Builder; | 
					
						
							| 
									
										
										
										
											2023-12-10 06:51:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-10 16:59:03 +02:00
										 |  |  | /** | 
					
						
							| 
									
										
										
										
											2020-12-04 06:20:44 +01:00
										 |  |  |  * FireflyIII\Models\RecurrenceTransaction | 
					
						
							| 
									
										
										
										
											2018-06-10 16:59:03 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2023-12-20 19:35:52 +01:00
										 |  |  |  * @property int                                    $id | 
					
						
							|  |  |  |  * @property null|Carbon                            $created_at | 
					
						
							|  |  |  |  * @property null|Carbon                            $updated_at | 
					
						
							|  |  |  |  * @property null|Carbon                            $deleted_at | 
					
						
							|  |  |  |  * @property int                                    $recurrence_id | 
					
						
							|  |  |  |  * @property int                                    $transaction_currency_id | 
					
						
							|  |  |  |  * @property null|int|string                        $foreign_currency_id | 
					
						
							|  |  |  |  * @property int                                    $source_id | 
					
						
							|  |  |  |  * @property int                                    $destination_id | 
					
						
							|  |  |  |  * @property string                                 $amount | 
					
						
							|  |  |  |  * @property string                                 $foreign_amount | 
					
						
							|  |  |  |  * @property string                                 $description | 
					
						
							|  |  |  |  * @property Account                                $destinationAccount | 
					
						
							|  |  |  |  * @property null|TransactionCurrency               $foreignCurrency | 
					
						
							|  |  |  |  * @property Recurrence                             $recurrence | 
					
						
							|  |  |  |  * @property Collection|RecurrenceTransactionMeta[] $recurrenceTransactionMeta | 
					
						
							|  |  |  |  * @property null|int                               $recurrence_transaction_meta_count | 
					
						
							|  |  |  |  * @property Account                                $sourceAccount | 
					
						
							|  |  |  |  * @property TransactionCurrency                    $transactionCurrency | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2020-03-17 16:46:00 +01:00
										 |  |  |  * @method static \Illuminate\Database\Eloquent\Builder|RecurrenceTransaction newModelQuery() | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Eloquent\Builder|RecurrenceTransaction newQuery() | 
					
						
							| 
									
										
										
										
											2023-12-20 19:35:52 +01:00
										 |  |  |  * @method static Builder|RecurrenceTransaction                               onlyTrashed() | 
					
						
							| 
									
										
										
										
											2020-03-17 16:46:00 +01:00
										 |  |  |  * @method static \Illuminate\Database\Eloquent\Builder|RecurrenceTransaction query() | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Eloquent\Builder|RecurrenceTransaction whereAmount($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Eloquent\Builder|RecurrenceTransaction whereCreatedAt($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Eloquent\Builder|RecurrenceTransaction whereDeletedAt($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Eloquent\Builder|RecurrenceTransaction whereDescription($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Eloquent\Builder|RecurrenceTransaction whereDestinationId($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Eloquent\Builder|RecurrenceTransaction whereForeignAmount($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Eloquent\Builder|RecurrenceTransaction whereForeignCurrencyId($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Eloquent\Builder|RecurrenceTransaction whereId($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Eloquent\Builder|RecurrenceTransaction whereRecurrenceId($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Eloquent\Builder|RecurrenceTransaction whereSourceId($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Eloquent\Builder|RecurrenceTransaction whereTransactionCurrencyId($value) | 
					
						
							|  |  |  |  * @method static \Illuminate\Database\Eloquent\Builder|RecurrenceTransaction whereUpdatedAt($value) | 
					
						
							| 
									
										
										
										
											2023-12-20 19:35:52 +01:00
										 |  |  |  * @method static Builder|RecurrenceTransaction                               withTrashed() | 
					
						
							|  |  |  |  * @method static Builder|RecurrenceTransaction                               withoutTrashed() | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @property null|int $transaction_type_id | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2021-03-12 06:30:40 +01:00
										 |  |  |  * @method static \Illuminate\Database\Eloquent\Builder|RecurrenceTransaction whereTransactionTypeId($value) | 
					
						
							| 
									
										
										
										
											2023-12-20 19:35:52 +01:00
										 |  |  |  * | 
					
						
							|  |  |  |  * @property null|TransactionType $transactionType | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2023-03-09 06:33:23 +01:00
										 |  |  |  * @mixin Eloquent | 
					
						
							| 
									
										
										
										
											2018-06-10 16:59:03 +02:00
										 |  |  |  */ | 
					
						
							|  |  |  | class RecurrenceTransaction extends Model | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2023-11-05 19:41:37 +01:00
										 |  |  |     use ReturnsIntegerIdTrait; | 
					
						
							| 
									
										
										
										
											2018-06-20 21:16:42 +02:00
										 |  |  |     use SoftDeletes; | 
					
						
							| 
									
										
										
										
											2021-08-28 15:47:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-17 15:14:34 +02:00
										 |  |  |     protected $casts | 
					
						
							| 
									
										
										
										
											2024-01-01 14:43:56 +01:00
										 |  |  |                      = [ | 
					
						
							| 
									
										
										
										
											2024-01-01 14:45:51 +01:00
										 |  |  |                          'created_at'     => 'datetime', | 
					
						
							|  |  |  |                          'updated_at'     => 'datetime', | 
					
						
							|  |  |  |                          'deleted_at'     => 'datetime', | 
					
						
							|  |  |  |                          'amount'         => 'string', | 
					
						
							|  |  |  |                          'foreign_amount' => 'string', | 
					
						
							|  |  |  |                          'description'    => 'string', | 
					
						
							|  |  |  |                      ]; | 
					
						
							| 
									
										
										
										
											2023-11-05 09:54:53 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-16 21:47:51 +02:00
										 |  |  |     protected $fillable | 
					
						
							| 
									
										
										
										
											2024-01-01 14:43:56 +01:00
										 |  |  |                      = [ | 
					
						
							| 
									
										
										
										
											2024-01-01 14:45:51 +01:00
										 |  |  |                          'recurrence_id', | 
					
						
							|  |  |  |                          'transaction_currency_id', | 
					
						
							|  |  |  |                          'foreign_currency_id', | 
					
						
							|  |  |  |                          'source_id', | 
					
						
							|  |  |  |                          'destination_id', | 
					
						
							|  |  |  |                          'amount', | 
					
						
							|  |  |  |                          'foreign_amount', | 
					
						
							|  |  |  |                          'description', | 
					
						
							|  |  |  |                      ]; | 
					
						
							| 
									
										
										
										
											2023-12-20 19:35:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-04 17:30:06 +02:00
										 |  |  |     /** @var string The table to store the data in */ | 
					
						
							| 
									
										
										
										
											2018-06-10 16:59:03 +02:00
										 |  |  |     protected $table = 'recurrences_transactions'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function destinationAccount(): BelongsTo | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2018-07-15 09:27:38 +02:00
										 |  |  |         return $this->belongsTo(Account::class, 'destination_id'); | 
					
						
							| 
									
										
										
										
											2018-06-10 16:59:03 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function foreignCurrency(): BelongsTo | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->belongsTo(TransactionCurrency::class); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function recurrence(): BelongsTo | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->belongsTo(Recurrence::class); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function recurrenceTransactionMeta(): HasMany | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2018-06-16 21:47:51 +02:00
										 |  |  |         return $this->hasMany(RecurrenceTransactionMeta::class, 'rt_id'); | 
					
						
							| 
									
										
										
										
											2018-06-10 16:59:03 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function sourceAccount(): BelongsTo | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2018-07-15 09:27:38 +02:00
										 |  |  |         return $this->belongsTo(Account::class, 'source_id'); | 
					
						
							| 
									
										
										
										
											2018-06-10 16:59:03 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function transactionCurrency(): BelongsTo | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->belongsTo(TransactionCurrency::class); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-08-28 15:47:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-15 19:51:55 +01:00
										 |  |  |     public function transactionType(): BelongsTo | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->belongsTo(TransactionType::class); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2023-01-02 06:44:52 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     protected function amount(): Attribute | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return Attribute::make( | 
					
						
							| 
									
										
										
										
											2023-12-20 19:35:52 +01:00
										 |  |  |             get: static fn ($value) => (string)$value, | 
					
						
							| 
									
										
										
										
											2023-01-02 06:44:52 +01:00
										 |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-10 06:51:59 +01:00
										 |  |  |     protected function destinationId(): Attribute | 
					
						
							| 
									
										
										
										
											2023-01-02 06:44:52 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         return Attribute::make( | 
					
						
							| 
									
										
										
										
											2023-12-20 19:35:52 +01:00
										 |  |  |             get: static fn ($value) => (int)$value, | 
					
						
							| 
									
										
										
										
											2023-01-02 06:44:52 +01:00
										 |  |  |         ); | 
					
						
							| 
									
										
										
										
											2023-11-05 19:41:37 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-10 06:51:59 +01:00
										 |  |  |     protected function foreignAmount(): Attribute | 
					
						
							| 
									
										
										
										
											2023-11-05 19:41:37 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         return Attribute::make( | 
					
						
							| 
									
										
										
										
											2023-12-20 19:35:52 +01:00
										 |  |  |             get: static fn ($value) => (string)$value, | 
					
						
							| 
									
										
										
										
											2023-11-05 19:41:37 +01:00
										 |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-10 06:51:59 +01:00
										 |  |  |     protected function recurrenceId(): Attribute | 
					
						
							| 
									
										
										
										
											2023-11-05 19:41:37 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         return Attribute::make( | 
					
						
							| 
									
										
										
										
											2023-12-20 19:35:52 +01:00
										 |  |  |             get: static fn ($value) => (int)$value, | 
					
						
							| 
									
										
										
										
											2023-11-05 19:41:37 +01:00
										 |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     protected function sourceId(): Attribute | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return Attribute::make( | 
					
						
							| 
									
										
										
										
											2023-12-20 19:35:52 +01:00
										 |  |  |             get: static fn ($value) => (int)$value, | 
					
						
							| 
									
										
										
										
											2023-11-05 19:41:37 +01:00
										 |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-10 06:51:59 +01:00
										 |  |  |     protected function transactionCurrencyId(): Attribute | 
					
						
							| 
									
										
										
										
											2023-11-05 19:41:37 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         return Attribute::make( | 
					
						
							| 
									
										
										
										
											2023-12-20 19:35:52 +01:00
										 |  |  |             get: static fn ($value) => (int)$value, | 
					
						
							| 
									
										
										
										
											2023-11-05 19:41:37 +01:00
										 |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     protected function userId(): Attribute | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return Attribute::make( | 
					
						
							| 
									
										
										
										
											2023-12-20 19:35:52 +01:00
										 |  |  |             get: static fn ($value) => (int)$value, | 
					
						
							| 
									
										
										
										
											2023-11-05 19:41:37 +01:00
										 |  |  |         ); | 
					
						
							| 
									
										
										
										
											2023-01-02 06:44:52 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-07-22 20:32:02 +02:00
										 |  |  | } |