diegonella/laravel-mp-etiquetas

Laravel 的 Mercado Pago SDK v0.5.2

v1.0.0 2016-03-22 09:44 UTC

This package is auto-updated.

Last update: 2024-09-21 20:31:00 UTC


README

通过 kikemarto 成功测试了与 Laravel 5.3 的兼容性

安装

composer require santigraviano/laravel-mercadopago

config/app.php 中添加以下 Provider 和 Alias

Provider

'providers' => [
  // Otros Providers...
  SantiGraviano\LaravelMercadoPago\Providers\MercadoPagoServiceProvider::class,
  /*
   * Application Service Providers...
   */
],

Alias

'aliases' => [
  // Otros Aliases
  'MP' => SantiGraviano\LaravelMercadoPago\Facades\MP::class,
],

配置

在配置 APP ID 和 APP SECRET 之前,执行以下命令

php artisan vendor:publish

执行完命令后,前往 .env 文件,添加 MP_APP_IDMP_APP_SECRET 字段,并用你的 Mercado Pago 应用程序的 CLIENT_IDCLIENT_SECRET 对应值替换。

要了解你的 CLIENT_IDCLIENT_SECRET 数据,请访问以下链接,根据您的国家/地区而定

如果您不想使用 .env 文件,请前往 config/mercadopago.php 并添加相应的应用程序数据。

return [
	'app_id'     => env('MP_APP_ID', 'TU CLIENT ID AQUI'),
	'app_secret' => env('MP_APP_SECRET', 'TU CLIENT SECRET AQUI')
];

如何使用

在这个例子中,我们将创建一个支付偏好,使用 Facade MP

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;

use MP;
use App\Http\Requests;
use App\Http\Controllers\Controller;

class MercadoPagoController extends Controller
{
  public function getCreatePreference()
  {
  	$preferenceData = [
  		'items' => [
  			[
  				'id' => 12,
  				'category_id' => 'phones',
  				'title' => 'iPhone 6',
  				'description' => 'iPhone 6 de 64gb nuevo',
  				'picture_url' => 'http://d243u7pon29hni.cloudfront.net/images/products/iphone-6-dorado-128-gb-red-4g-8-mpx-1256254%20(1)_m.png',
  				'quantity' => 1,
  				'currency_id' => 'ARS',
  				'unit_price' => 14999
  			]
  		],
  	];

  	$preference = MP::create_preference($preferenceData);

  	return dd($preference);

  }

在这个例子中,我们将创建一个订阅(自动扣款),使用 Facade MP

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;

use MP;
use App\Http\Requests;
use App\Http\Controllers\Controller;

class MercadoPagoController extends Controller
{
  public function getCreatePreapproval()
  {
    $preapproval_data = [
      'payer_email' => 'agariobadcell@gmail.com',
      'back_url' => 'http://labhor.com.ar/laravel/public/preapproval',
      'reason' => 'Subscripción a paquete premium',
      'external_reference' => $subscription->id,
      'auto_recurring' => [
        'frequency' => 1,
        'frequency_type' => 'months',
        'transaction_amount' => 99,
        'currency_id' => 'ARS',
        'start_date' => Carbon::now()->addHour()->format('Y-m-d\TH:i:s.BP'),
        'end_date' => Carbon::now()->addMonth()->format('Y-m-d\TH:i:s.BP'),
      ],
    ];

    MP::create_preapproval_payment($preapproval_data);

    return dd($preapproval);
  }

在这个例子中,可以看到使用 Carbon 库来指定订阅的开始日期和结束日期,这是一个月度频率。

到目前的位置,通过 Carbon 添加了一个小时,因为如果不这样做,Mercado Pago 可能会给出一个过期的日期。