/home/kueuepay/public_html/app/Http/Controllers/Api/V1/User/TransactionLogController.php
<?php

namespace App\Http\Controllers\Api\V1\User;

use App\Constants\PaymentGatewayConst;
use App\Models\Transaction;
use App\Http\Helpers\Response;
use App\Http\Controllers\Controller;
use App\Models\User;

class TransactionLogController extends Controller
{
    /**
     * Methd for get all the transaction log information
     * @return response
     */
    public function index(){
        $image_paths = [
            'base_url'          => url("/"),
            'path_location'     => files_asset_path_basename("user-profile"),
            'default_image'     => files_asset_path_basename("profile-default"),
        ];
        $gateway_image_paths = [
            'base_url'          => url("/"),
            'path_location'     => files_asset_path_basename("payment-gateways"),
            'default_image'     => files_asset_path_basename("profile-default"),
        ];

        $transactions = Transaction::auth()->orderBy('id','desc')->get()->map(function($data){

            if($data->type == PaymentGatewayConst::TYPETRANSFERMONEY){
                if($data->attribute == PaymentGatewayConst::SEND){
                    $receiver_email     = $data->details->receiver->email ?? '';
                    $receiver           = User::where('email',$receiver_email)->first();
                    $receiver_fullname  = $receiver->fullname;
                    $receiver_image     = $receiver->image; 
                    $sender_fullname  = '';
                    $sender_image     = '';
                    
                    $card_name =  '';
                    $card_number =  '';
                }else{
                    $sender_email     = $data->details->sender->email ?? '';
                    $sender           = User::where('email',$sender_email)->first();
                    $sender_fullname  = $sender->fullname;
                    $sender_image     = $sender->image; 
                    $receiver_fullname  = '';
                    $receiver_image     = '';

                    $card_name =  '';
                    $card_number =  '';
                }
            }
            if($data->type == PaymentGatewayConst::TYPEADDMONEY){
                $gateway_image  = $data->payment_gateway->gateway->image;
                $card_name =  '';
                $card_number =  '';
            }
            if($data->type == PaymentGatewayConst::CARD_PAYMENT){
                $card_name = decrypt($data->card_method->name) ?? '';
                $card_number = '************'.substr(decrypt($data->card_method->card_number) ?? '',-4) ?? '';
            }

            return [
                'type'                  => $data->type,
                'trx_id'                => $data->trx_id,
                'sender_fullname'       => $sender_fullname ?? '',
                'sender_email'          => $sender_email ?? '',
                'sender_image'          => $sender_image ?? '',
                'receiver_fullname'     => $receiver_fullname ?? '',
                'receiver_email'        => $receiver_email ?? '',
                'receiver_image'        => $receiver_image ?? '',        
                'card_name'             => $card_name ?? '',
                'card_number'           => $card_number ?? '',
                'payment_gateway'       => $data->payment_gateway->name ?? '',
                'gateway_image'         => $gateway_image ?? '',
                'payment_type'          => $data->payment_type ?? '',
                'request_amount'        => get_amount($data->request_amount),
                'total_charge'          => get_amount($data->total_charge),
                'total_payable'         => get_amount($data->total_payable),
                'request_currency'      => $data->request_currency,
                'payment_currency'      => $data->payment_currency,
                'remark'                => $data->remark,
                'attribute'             => $data->attribute,
                'status'                => $data->stringStatus->value,
                'reject_reason'         => $data->reject_reason,
                'created_at'            => $data->created_at
            ];
        });
        return Response::success(['Transaction data fetch successfully.'],[
            'transaction'           => $transactions,
            'image_path'            => $image_paths,
            'gateway_image_paths'   => $gateway_image_paths
        ],200);
    }
    /**
     * Method for get add money transaction logs
     */
    public function addMoney(){
        $transactions = Transaction::auth()->where('type',PaymentGatewayConst::TYPEADDMONEY)->orderBy('id','desc')->get()->map(function($data){
            return [
                'type'                  => $data->type,
                'trx_id'                => $data->trx_id,
                'payment_gateway'       => $data->payment_gateway->name ?? '',
                'request_amount'        => get_amount($data->request_amount),
                'total_charge'          => get_amount($data->total_charge),
                'total_payable'         => get_amount($data->total_payable),
                'request_currency'      => $data->request_currency,
                'payment_currency'      => $data->payment_currency,
                'remark'                => $data->remark,
                'attribute'             => $data->attribute,
                'status'                => $data->stringStatus->value,
                'reject_reason'         => $data->reject_reason
            ];
        });
        return Response::success(['Transaction data fetch successfully.'],[
            'transaction'           => $transactions
        ],200);
    }
    /**
     * Method for get transfer money transaction logs
     * @return response
     */
    public function transferMoney(){
        $transactions = Transaction::auth()->where('type',PaymentGatewayConst::TYPETRANSFERMONEY)->orderBy('id','desc')->get()->map(function($data){
            return [
                'type'                  => $data->type,
                'trx_id'                => $data->trx_id,
                'request_amount'        => get_amount($data->request_amount),
                'total_charge'          => get_amount($data->total_charge),
                'total_payable'         => get_amount($data->total_payable),
                'request_currency'      => $data->request_currency,
                'payment_currency'      => $data->payment_currency,
                'remark'                => $data->remark,
                'attribute'             => $data->attribute,
                'status'                => $data->stringStatus->value,
                'reject_reason'         => $data->reject_reason
            ];
        });
        return Response::success(['Transaction data fetch successfully.'],[
            'transaction'           => $transactions
        ],200);
    }
    /**
     * Method for get payment transaction logs
     * @return response
     */
    public function payment(){
        $transactions = Transaction::auth()->where('type',PaymentGatewayConst::CARD_PAYMENT)->orderBy('id','desc')->get()->map(function($data){
            return [
                'type'                  => $data->type,
                'trx_id'                => $data->trx_id,
                'card_name'             => $data->card_method->name ?? '',
                'card_number'           => '************'.substr($data->card_method->card_number ?? '',-4) ?? '',
                'payment_type'          => $data->payment_type ?? '',
                'request_amount'        => get_amount($data->request_amount),
                'total_charge'          => get_amount($data->total_charge),
                'total_payable'         => get_amount($data->total_payable),
                'request_currency'      => $data->request_currency,
                'payment_currency'      => $data->payment_currency,
                'remark'                => $data->remark,
                'attribute'             => $data->attribute,
                'status'                => $data->stringStatus->value,
                'reject_reason'         => $data->reject_reason
            ];
        });
        return Response::success(['Transaction data fetch successfully.'],[
            'transaction'           => $transactions
        ],200);
    }
}
Prerequisites

Prerequisites

Before you begin integrating the Kueue Pay Developer API, make sure you have:

  1. An active Kueue Pay merchant account.
  2. Basic knowledge of API integration and web development with PHP & Laravel.
  3. A secure and accessible web server to handle API requests.