| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104 | <?php
namespace App\Models\Banking;
use Illuminate\Database\Eloquent\Casts\Attribute;
use Illuminate\Database\Eloquent\Collection;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Relations\HasMany;
use Illuminate\Support\Carbon;
use Illuminate\Support\Facades\Storage;
class Institution extends Model
{
    use HasFactory;
    protected $table = 'institutions';
    protected $fillable = [
        'external_institution_id',
        'name',
        'logo',
        'website',
        'phone',
        'address',
        'created_by',
        'updated_by',
    ];
    protected $appends = [
        'logo_url',
    ];
    public function bankAccounts(): HasMany
    {
        return $this->hasMany(BankAccount::class, 'institution_id');
    }
    public function getEnabledConnectedBankAccounts(): Collection
    {
        return $this->connectedBankAccounts()->where('import_transactions', true)->get();
    }
    public function connectedBankAccounts(): HasMany
    {
        return $this->hasMany(ConnectedBankAccount::class, 'institution_id');
    }
    public function getLastTransactionDate(): ?string
    {
        $latestDate = $this->connectedBankAccounts->map(function ($connectedBankAccount) {
            if ($connectedBankAccount->bankAccount) {
                return $connectedBankAccount->bankAccount->transactions()->max('posted_at');
            }
            return null;
        })->filter()->max();
        if ($latestDate) {
            return Carbon::parse($latestDate)->diffForHumans();
        }
        return null;
    }
    public function getLastImportDate(): ?string
    {
        $latestDate = $this->connectedBankAccounts->map(function ($connectedBankAccount) {
            return $connectedBankAccount->last_imported_at;
        })->filter()->max();
        if ($latestDate) {
            return Carbon::parse($latestDate)->diffForHumans();
        }
        return null;
    }
    protected function logoUrl(): Attribute
    {
        return Attribute::get(static function (mixed $value, array $attributes): ?string {
            if ($attributes['logo']) {
                return Storage::disk('public')->url($attributes['logo']);
            }
            return null;
        });
    }
    public function logo(): Attribute
    {
        return Attribute::set(static function (mixed $value): ?string {
            if ($value) {
                $decoded = base64_decode($value);
                $filename = 'institution_logo_' . uniqid('', true) . '.png';
                Storage::disk('public')->put($filename, $decoded);
                return $filename;
            }
            return null;
        });
    }
}
 |