. */ declare(strict_types=1); namespace FireflyIII\Models; use Eloquent; use Illuminate\Database\Eloquent\Builder; use Illuminate\Database\Eloquent\Collection; use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\Relations\BelongsTo; use Illuminate\Database\Eloquent\Relations\MorphMany; use Illuminate\Support\Carbon; use Symfony\Component\HttpKernel\Exception\NotFoundHttpException; /** * FireflyIII\Models\TransactionJournalLink * * @property int $id * @property Carbon|null $created_at * @property Carbon|null $updated_at * @property int $link_type_id * @property int $source_id * @property int $destination_id * @property string|null $comment * @property-read TransactionJournal $destination * @property-read LinkType $linkType * @property-read Collection|Note[] $notes * @property-read int|null $notes_count * @property-read TransactionJournal $source * @property-read string $inward * @property-read string $outward * @method static Builder|TransactionJournalLink newModelQuery() * @method static Builder|TransactionJournalLink newQuery() * @method static Builder|TransactionJournalLink query() * @method static Builder|TransactionJournalLink whereComment($value) * @method static Builder|TransactionJournalLink whereCreatedAt($value) * @method static Builder|TransactionJournalLink whereDestinationId($value) * @method static Builder|TransactionJournalLink whereId($value) * @method static Builder|TransactionJournalLink whereLinkTypeId($value) * @method static Builder|TransactionJournalLink whereSourceId($value) * @method static Builder|TransactionJournalLink whereUpdatedAt($value) * @mixin Eloquent */ class TransactionJournalLink extends Model { /** * The attributes that should be casted to native types. * * @var array */ protected $casts = [ 'created_at' => 'datetime', 'updated_at' => 'datetime', ]; /** @var string The table to store the data in */ protected $table = 'journal_links'; /** * Route binder. Converts the key in the URL to the specified object (or throw 404). * * @param string $value * * @return TransactionJournalLink * * @throws NotFoundHttpException */ public static function routeBinder(string $value): TransactionJournalLink { if (auth()->check()) { $linkId = (int)$value; $link = self::where('journal_links.id', $linkId) ->leftJoin('transaction_journals as t_a', 't_a.id', '=', 'source_id') ->leftJoin('transaction_journals as t_b', 't_b.id', '=', 'destination_id') ->where('t_a.user_id', auth()->user()->id) ->where('t_b.user_id', auth()->user()->id) ->first(['journal_links.*']); if (null !== $link) { return $link; } } throw new NotFoundHttpException(); } /** * @return BelongsTo */ public function destination(): BelongsTo { return $this->belongsTo(TransactionJournal::class, 'destination_id'); } /** * @return BelongsTo */ public function linkType(): BelongsTo { return $this->belongsTo(LinkType::class); } /** * Get all of the notes. */ public function notes(): MorphMany { return $this->morphMany(Note::class, 'noteable'); } /** * @return BelongsTo */ public function source(): BelongsTo { return $this->belongsTo(TransactionJournal::class, 'source_id'); } }