File "PaymentConfiguration.php"
Full Path: /home/trinadezambia/public_html/admin_panel/app/Models/PaymentConfiguration.php
File size: 1.94 KB
MIME-type: text/x-php
Charset: utf-8
<?php
namespace App\Models;
use Illuminate\Support\Facades\Auth;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use App\Traits\DateFormatTrait;
class PaymentConfiguration extends Model
{
use HasFactory, DateFormatTrait;
protected $fillable = [
'payment_method',
'api_key',
'secret_key',
'webhook_secret_key',
'status',
'currency_code',
'currency_symbol',
'school_id',
'bank_name',
'account_name',
'account_no',
];
public function getConnectionName()
{
// Replace this with your logic to determine the connection name
// For example, you might get it from session or config
return session('db_connection_name') ?? config('database.default');
}
public function scopeOwner($query)
{
if(Auth::user()){
if (Auth::user()->hasRole('Super Admin')) {
return $query->where('school_id',null);
}
if (Auth::user()->hasRole('School Admin')) {
return $query->where('school_id', Auth::user()->school_id);
}
if (Auth::user()->hasRole('Student')) {
return $query->where('school_id', Auth::user()->school_id);
}
if (Auth::user()->hasRole('Guardian')) {
if(request('child_id')){
$childId = request('child_id');
$studentAuth = Students::where('id',$childId)->first();
return $query->where('school_id', $studentAuth->school_id);
}
return $query;
}
}
return $query;
}
public function getCreatedAtAttribute()
{
return $this->formatDateValue($this->getRawOriginal('created_at'));
}
public function getUpdatedAtAttribute()
{
return $this->formatDateValue($this->getRawOriginal('updated_at'));
}
}