Spamworldpro Mini Shell
Spamworldpro


Server : Apache
System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64
User : corals ( 1002)
PHP Version : 7.4.33
Disable Function : exec,passthru,shell_exec,system
Directory :  /home/corals/job-board.corals.io/Corals/modules/Payment/Common/Policies/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /home/corals/job-board.corals.io/Corals/modules/Payment/Common/Policies/TransactionPolicy.php
<?php

namespace Corals\Modules\Payment\Common\Policies;

use Corals\Foundation\Policies\BasePolicy;
use Corals\Modules\Payment\Common\Models\Transaction;
use Corals\User\Models\User;

class TransactionPolicy extends BasePolicy
{
    protected $administrationPermission = 'Administrations::admin.payment';

    protected $skippedAbilities = ['canReverseTransfer'];

    /**
     * @param User $user
     * @param Transaction|null $transaction
     * @return bool
     */
    public function view(User $user, Transaction $transaction = null)
    {
        if ($user->can('Payment::transaction.view_all')) {
            return true;
        }
        if ($user->can('Payment::transaction.view')) {
            if (isset($transaction->owner) && $transaction->owner->id == $user->id) {
                return true;
            }
        }
        return false;
    }

    /**
     * @param User $user
     * @return bool
     */
    public function create(User $user)
    {
        return $user->can('Payment::transaction.create');
    }

    /**
     * @param User $user
     * @param Transaction $transaction
     * @return bool
     */
    public function update(User $user, Transaction $transaction)
    {
        return $user->can('Payment::transaction.update');
    }

    /**
     * @param User $user
     * @param Transaction $transaction
     * @return bool
     */
    public function destroy(User $user, Transaction $transaction)
    {
        return $user->can('Payment::transaction.delete');
    }

    public function canReverseTransfer(User $user, Transaction $transaction)
    {
        $transactionCanBeReversed = $transaction->type == 'payout' && $transaction->reference && $transaction->status == 'completed';

        if (!$transactionCanBeReversed) {
            return false;
        }

        if ($user->hasPermissionTo($this->administrationPermission) || isSuperUser($user)) {
            return true;
        }

        return $transaction->owner_id == $user->id && $transaction->owner_type == getMorphAlias($user);
    }
}

Spamworldpro Mini