| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 | <?php
namespace App\Models\Banking;
use Illuminate\Database\Eloquent\Casts\Attribute;
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 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;
        });
    }
}
 |