定制 clickpaysa/laravel_package 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

clickpaysa/laravel_package

最新稳定版本:1.4.0

Composer 安装命令:

composer require clickpaysa/laravel_package

包简介

Official laravel package to implement ClickPay integration with laravel apps

README 文档

README

Laravel ClickPay

Description

This Package provides integration with the ClickPay payment gateway.

CONTENTS OF THIS FILE

  • Introduction
  • Requirements
  • Installation
  • Configuration
  • usage

INTRODUCTION

This Package integrates ClickPay online payments into the Laravel Framework starts from version 5.8 - 8.x.

REQUIREMENTS

This Package requires no external dependencies.

INSTALLATION

  • composer require clickpaysa/laravel_package

CONFIGURATION

  • composer dump-autoload

  • Go to config/app.php and in the providers array add

      Clickpaysa\Laravel_package\PaypageServiceProvider::class,
    
  • Create the package config file:

      php artisan vendor:publish --tag=clickpay
    
  • Go to config/logging.php and in the channels array add

    'ClickPay' => [
    'driver' => 'single',
    'path' => storage_path('logs/clickpay.log'),
    'level' => 'info',
    ],
    
  • In config/clickpay.php add your merchant info.

Important Hint: you can pass your merchant info in the environment file with the same key names mentioned in the config/clickpay.php file. This value will be returned if no environment variable exists for the given key.

Usage

  • create pay page

      use Clickpaysa\Laravel_package\Facades\paypage;
    
      $pay= paypage::sendPaymentCode('all')
             ->sendTransaction('sale')
              ->sendCart(10,1000,'test')
             ->sendCustomerDetails('Name', 'email@email.com', '0501111111', 'test', 'Riyadh', 'Riyadh', 'SA', '1234','10.0.0.10')
             ->sendShippingDetails('Name', 'email@email.com', '0501111111', 'test', 'Riyadh', 'Riyadh', 'SA', '1234','10.0.0.10')
             ->sendURLs('return_url', 'callback_url')
             ->sendLanguage('en')
             ->create_pay_page();
      return $pay;
    
  • if you want to pass the shipping address as same as billing address you can use

      ->sendShippingDetails('same as billing')
    
  • if you want to hide the shipping address you can use

      ->sendHideShipping(true);
    
  • if you want to use iframe option instead of redirection you can use

      ->sendFramed(true);
    
  • if you want to pass the payment methods you can use

      ::sendPaymentCode("['creditcard','mada']")
    
  • if you want to pass the Tokenization option you can use

      ->sendTokinse(true)
    
  • if you want to make a payment via token you can use

      ->sendTransaction('transaction_type','recurring')
      ->sendToken('token returned from the first payment page created with Tokenization option','transRef returned to you in the same first payment page')
    
  • if you want to make a payment with user defined you can use

      ->sendUserDefined(["udf1"=>"UDF1 Test", "udf2"=>"UDF2 Test", "udf3"=>"UDF3 Test"])
    
  • refund (you can use this function to both refund and partially refund)

      $refund = Paypage::refund('tran_ref','order_id','amount','refund_reason');
      return $refund;
    
  • Auth

      pay= Paypage::sendPaymentCode('all')
             ->sendTransaction('Auth')
              ->sendCart(10,1000,'test')
             ->sendCustomerDetails('Name', 'email@email.com', '0501111111', 'test', 'Riyadh', 'Riyadh', 'SA', '1234','10.0.0.10')
             ->sendShippingDetails('Name', 'email@email.com', '0501111111', 'test', 'Riyadh', 'Riyadh', 'SA', '1234','10.0.0.10')
             ->sendURLs('return_url', 'callback_url')
             ->sendLanguage('en')
             ->create_pay_page();
      return $pay;
    
  • capture (the tran_ref is the tran_ref of the Auth transaction you need to capture it.

    you can use this function to both capture and partially capture.)

       $capture = Paypage::capture('tran_ref','order_id','amount','capture description'); 
       return $capture;
    
  • void (the tran_ref is the tran_ref of the Auth transaction you need to void it.

    you can use this function to both capture and partially capture)

      $void = Paypage::void('tran_ref','order_id','amount','void description');
      return $void
    
  • transaction details

      $transaction = Paypage::queryTransaction('tran_ref');
      return $transaction;
    
  • if you face any error you will find it logged in: storage/logs/clickpay.log

PAYMENT RESULT NOTIFICATION

ClickPay payment gateway provides means to notify your system with payment result once transaction processing was completed so that your system can update the transaction respective cart.

To get use of this feature do the following:

1- Defining a route (Optional)

Laravel ClickPay package comes with a default route for incoming IPN requests. The route URI is /paymentIPN , if you don't like it this URI just ignore it and define your own. Look at routes/routes.php to get a clue.

2- Implementing a means to receive notification

To receive notification, do one of the following:

  • While creating a pay page, passed this route as a Callback URL to sendURLs method, that URL will receive an HTTP Post request with the payment result. For more about callback check: merchant dashboard > Developers > Transaction API.

  • Second means is to configure IPN notification from merchant dashboard. For more details about how to configure IPN request and its different formats check: merchant dashboard > Developers > Service Types.

3- Configuring a callback method

Now, you need to configure the plugin with the class\method that will grab the payment details and perform your custom logic (updating cart in DB, notifying the customer ...etc ).

  • In your website config/clickpay.php file, add the following:

      'callback' => env('clickpay_ipn_callback', namespace\your_class::class ),
    
  • In your class add new method, it must named: updateCartByIPN

      updateCartByIPN( $requestData){
          $cartId= $requestData->getCartId();
          $status= $requestData->getStatus();
          //your logic .. updating cart in DB, notifying the customer ...etc
      }
    

you can also get transaction reference number. To get the list of available properties check: Clickpaysa\Laravel__clickpay\IpnRequest class.

统计信息

  • 总下载量: 5.63k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 0
  • Forks: 3
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2022-11-02