创建Paymill回调

时间:2013-08-02 23:07:10

标签: ruby-on-rails-3 paymill

我正在使用rails 3.2开发一个webapp。 我正在尝试为Paymill构建一个回调方法,用于捕获事务成功事件。

这是我的控制器。它很简单,当我使用CURL或Firefox插件创建模拟POST请求并使用Paymill文档声明的JSON正文时,它工作正常。

不幸的是,当使用Paymills自己的测试脚本(用PHP制作)时,它就会失败。

class Admin::TransactionsController < ActionController::Base

  def create
    transaction = Transaction.new
    transaction.client_id = params[:event][:event_resource][:client][:id]
    transaction.trans_id = params[:event][:event_resource][:id]
    transaction.amount = params[:event][:event_resource][:amount] 
    transaction.currency = params[:event][:event_resource][:currency] 
    transaction.save
    render :nothing => true
  end

end

这是文档说它将附加到回调事件的JSON主体:

{
    "event": {
        "event_type": "transaction.succeeded",
        "event_resource": {
            "id": "tran_d06aae1df72af329c39367cde9ed19",
            "amount": "12345",
            "origin_amount": 12345,
            "status": "closed",
            "description": "test paymill",
            "livemode": false,
            "refunds": null,
            "currency": "USD",
            "created_at": 1375457696,
            "updated_at": 1375457696,
            "response_code": 20000,
            "short_id": null,
            "is_fraud": false,
            "invoices": [],
            "app_id": null,
            "fees": [],
            "payment": {
                "id": "pay_46ee3be859eedb72d325adcb6",
                "type": "creditcard",
                "client": "client_d94e1e3efbc59073629df",
                "card_type": "visa",
                "country": null,
                "expire_month": "1",
                "expire_year": "2014",
                "card_holder": null,
                "last4": "1111",
                "created_at": 1375457695,
                "updated_at": 1375457696,
                "app_id": null
            },
            "client": {
                "id": "client_d941e3efbc59e073629df",
                "email": null,
                "description": null,
                "created_at": 1375457696,
                "updated_at": 1375457696,
                "app_id": null,
                "payment": [],
                "subscription": null
            },
            "preauthorization": null
        }
    }
}

使用PHP测试脚本发出请求时,正文将以此形状到达 和Rails通过错误:

string(1712) ""{\n \"event\": {\n \"event_type\": \"transaction.succeeded\",\n \"event_resource\": {\n \"id\": \"tran_d06aae1f72af329c39367cde9ed19\",\n \"amount\": \"12345\",\n \"origin_amount\": 12345,\n \"status\": \"closed\",\n \"description\": \"test paymill\",\n \"livemode\": false,\n \"refunds\": null,\n \"currency\": \"USD\",\n \"created_at\": 1375457696,\n \"updated_at\": 1375457696,\n \"response_code\": 20000,\n \"short_id\": null,\n \"is_fraud\": false,\n \"invoices\": [],\n \"app_id\": null,\n \"fees\": [],\n \"payment\": {\n \"id\": \"pay_46ee3b85f9eedb72d325adcb6\",\n \"type\": \"creditcard\",\n \"client\": \"client_d941e3effbc59073629df\",\n \"card_type\": \"visa\",\n \"country\": null,\n \"expire_month\": \"1\",\n \"expire_year\": \"2014\",\n \"card_holder\": null,\n \"last4\": \"1111\",\n \"created_at\": 1375457695,\n \"updated_at\": 1375457696,\n \"app_id\": null\n },\n \"client\": {\n \"id\": \"client_d941e3efbc59073629df\",\n \"email\": null,\n \"description\": null,\n \"created_at\": 1375457696,\n \"updated_at\": 1375457696,\n \"app_id\": null,\n \"payment\": [],\n \"subscription\": null\n },\n \"preauthorization\": null\n }\n }\n}""

我从Rails得到的错误就是这个:

Error occurred while parsing request parameters

NoMethodError - undefined method `each' for #<String:0x007fc820a1fc08>:

发生了什么事?这就像Rails将这个身体视为错误的文本?如果我从PHP中删除这一行(因此在发送之前没有JSON编码主体)它工作正常,我没有错误。如果我的create方法是空的并不重要。在调用此方法之前会发生什么事情?

json_encode($http_body);

感谢所有帮助!我很快就会哭。

1 个答案:

答案 0 :(得分:0)

你从哪里获得测试脚本?我在这里的那个,确实包含了纯文本的正文,所以它不再需要json编码,这应该有效(用你的URL替换&lt; YOUR_TARGET_URL &gt;):

<?php
    $http_body = '{
        "event" : {
            "event_type" : "transaction.succeeded",
            "event_resource" :
                {"id":"__TRANSACTION_ID__","amount":"12345","origin_amount":12345,"status":"closed","description":"test paymill","livemode":false,"refunds":null,"currency":"SEK","created_at":1375457696,"updated_at":1375457696,"response_code":20000,"short_id":null,"is_fraud":false,"invoices":[],"app_id":null,"fees":[],"payment":{"id":"__PAYMNET_ID__","type":"creditcard","client":"__CLIENT_ID__","card_type":"visa","country":null,"expire_month":"1","expire_year":"2014","card_holder":null,"last4":"1111","created_at":1375457695,"updated_at":1375457696,"app_id":null},"client":{"id":"__CLIENT_ID__","email":null,"description":null,"created_at":1375457696,"updated_at":1375457696,"app_id":null,"payment":[],"subscription":null},"preauthorization":null}
        }
    }';

    $curl           = curl_init();

    $curlOpts = array(
        CURLOPT_URL => '',
        CURLOPT_RETURNTRANSFER  => true,
        CURLOPT_CUSTOMREQUEST   => 'POST',
        CURLOPT_SSL_VERIFYPEER  => false,
        CURLOPT_SSLVERSION      => 3,
        CURLOPT_TIMEOUT         => 60,
        CURLOPT_CONNECTTIMEOUT  => 60,
        CURLOPT_HTTPHEADER      => array('Content-type: application/json'),
        CURLOPT_PROTOCOLS       => CURLPROTO_HTTP | CURLPROTO_HTTPS,
        CURLOPT_MAXREDIRS       => 5
    );

    $curlOpts[CURLOPT_URL] = '<__YOUR_TARGET_URL__>';
    $curlOpts[CURLOPT_POSTFIELDS] = $http_body;
    curl_setopt_array($curl, $curlOpts);
    $result = curl_exec($curl);
    $responseInfo = curl_getinfo( $curl );

    var_dump($responseInfo);
    var_dump($result);
    curl_close($curl);

    exit;