# Alipay
A unofficial alipay ruby gem.
Alipay official document: https://b.alipay.com/order/techService.htm .
## Installation
Add this line to your application's Gemfile:
```ruby
gem 'alipay', '~> 0.6.0'
```
And then execute:
```console
$ bundle
```
## Configuration
```ruby
Alipay.pid = 'YOUR_PID'
Alipay.key = 'YOUR_KEY'
Alipay.seller_email = 'YOUR_SELLER_EMAIL'
#Alipay.sign_type = 'MD5' # Available values: MD5, RSA. Default is MD5
#Alipay.debug_mode = true # Enable parameter check. Default is true.
```
You can set default key, or pass a key directly to service method:
```ruby
Service.create_partner_trade_by_buyer_url({
out_trade_no: 'OUT_TRADE_NO',
# Order params...
}, {
pid: 'ANOTHER_PID',
key: 'ANOTHER_KEY',
seller_email: 'ANOTHER_SELLER_EMAIL'
})
```
## Service
### 担保交易收款接口
#### Name
```ruby
create_partner_trade_by_buyer
```
#### Definition
```ruby
Alipay::Service.create_partner_trade_by_buyer_url({ARGUMENTS}, {OPTIONS})
```
#### Example
```ruby
Alipay::Service.create_partner_trade_by_buyer_url(
out_trade_no: '20150401000-0001',
subject: 'Order Name',
price: '10.00',
quantity: 12,
logistics_type: 'DIRECT',
logistics_fee: '0',
logistics_payment: 'SELLER_PAY',
return_url: 'https://example.com/orders/20150401000-0001',
notify_url: 'https://example.com/orders/20150401000-0001/notify'
)
# => 'https://mapi.alipay.com/gateway.do?service=create_partner_trade_by_buyer&...'
```
Guide consumer to this address to complete payment
#### Arguments
| Key | Requirement | Description |
| --- | ----------- | ----------- |
| out_order_no | required | Order id in your application. |
| subject | required | Order subject. |
| price | required | Order item's price. |
| quantity | required | Order item's quantity, total price is price * quantity. |
| logistics_type | required | Logistics type. Available values: POST, EXPRESS, EMS, DIRECT. |
| logistics_fee | required | Logistics fee. |
| logistics_payment | required | Who pay the logistics fee. Available values: BUYER_PAY, SELLER_PAY, BUYER_PAY_AFTER_RECEIVE. |
| return_url | optional | Redirect customer to this url after payment. |
| notify_url | optional | Alipay asyn notify url. |
This is not a complete list of arguments, please read official document: http://download.alipay.com/public/api/base/alipayescow.zip .
### 确认发货接口
#### Name
```ruby
send_goods_confirm_by_platform
```
#### Definition
```ruby
Alipay::Service.send_goods_confirm_by_platform({ARGUMENTS}, {OPTIONS})
```
#### Example
```ruby
Alipay::Service.send_goods_confirm_by_platform(
trade_no: '201504010000001',
logistics_name: 'example.com'
)
# => 'T'
```
#### Arguments
| Key | Requirement | Description |
| --- | ----------- | ----------- |
| trade_no | required | Trade number in Alipay system, should get from notify message. |
| logistics_name | required | Logistics Name. |
This is not a complete list of arguments, please read official document: http://download.alipay.com/public/api/base/alipayescow.zip .
### 即时到账收款接口
#### Name
```ruby
create_direct_pay_by_user
```
#### Definition
```ruby
Alipay::Service.create_direct_pay_by_user_url({ARGUMENTS}, {OPTIONS})
```
#### Example
```ruby
Alipay::Service.create_direct_pay_by_user_url(
out_trade_no: '20150401000-0001',
subject: 'Order Name',
price: '10.00',
quantity: 12,
return_url: 'https://example.com/orders/20150401000-0001',
notify_url: 'https://example.com/orders/20150401000-0001/notify'
)
```
#### Arguments
| Key | Requirement | Description |
| --- | ----------- | ----------- |
| out_order_no | required | Order id in your application. |
| subject | required | Order subject. |
| price | required * | Order item's price. |
| quantity | required * | Order item's quantity, total price is price * quantity. |
| return_url | optional | Redirect customer to this url after payment. |
| notify_url | optional | Alipay asyn notify url. |
\* Can be replaced by total_fee. When total_fee is set, price and quantity could not be set.
This is not a complete list of arguments, please read official document: http://download.alipay.com/public/api/base/alipaydirect.zip .
### 即时到账批量退款有密接口
#### Name
```ruby
refund_fastpay_by_platform_pwd
```
#### Definition
```ruby
Alipay::Service.refund_fastpay_by_platform_pwd_url
```
#### Example
```ruby
batch_no = Alipay::Utils.generate_batch_no # refund batch no, you SHOULD store it to db to avoid alipay duplicate refund
Alipay::Service.refund_fastpay_by_platform_pwd_url(
batch_no: batch_no,
data: [{
trade_no: '201504010000001',
amount: '10.0',
reason: 'REFUND_REASON'
}],
notify_url: 'https://example.com/orders/20150401000-0001/refund_notify'
)
# => https://mapi.alipay.com/gateway.do?service=refund_fastpay_by_platform_pwd&...
```
#### Arguments
| Key | Requirement | Description |
| --- | ----------- | ----------- |
| batch_no | required | Refund batch no, you should store it to db to avoid alipay duplicate refund. |
| data | required | Refund data, a hash array. |
| notify_url | required | Alipay notify url. |
##### Data Item
| Key | Requirement | Description |
| --- | ----------- | ----------- |
| trade_no | required | Trade number in alipay system. |
| amount | required | Refund amount. |
| reason | required | Refund reason. Less than 256 bytes, could not contain special characters: ^ $ | #. |
This is not a complete list of arguments, please read official document: http://download.alipay.com/public/api/base/alipaydirect.zip .
### 关闭交易接口
#### Name
```ruby
close_trade
```
#### Definition
```ruby
Alipay::Service.close_trade({ARGUMENTS}, {OPTIONS})
```
#### Example
```ruby
Alipay::Service.close_trade(
trade_no: '201504010000001'
)
# => 'T'
# When fail
# => 'F TRADE_STATUS_NOT_AVAILD'
```
#### ARGUMENTS
| Key | Requirement | Description |
| --- | ----------- | ----------- |
| out_order_no | optional * | Order number in your application. |
| trade_no | optional * | Trade number in alipay system. |
\* out_order_no and trade_no must have one.
### 单笔交易查询接口
#### Name
```ruby
single_trade_query
```
#### Definition
```ruby
Alipay::Service.single_trade_query({ARGUMENTS}, {OPTIONS})
```
#### Example
```ruby
Alipay::Service.single_trade_query(
trade_no: '201504010000001'
)
# => 'T...
```
#### ARGUMENTS
| Key | Requirement | Description |
| --- | ----------- | ----------- |
| out_trade_no | optional * | Order number in your application. |
| trade_no | optional * | Trade number in alipay system. |
\* out_trade_no and trade_no must have one.
### 境外收单接口
#### Name
```ruby
create_forex_trade
```
#### Definition
```ruby
Alipay::Service.create_forex_trade_url({ARGUMENTS}, {OPTIONS})
```
#### Example
```ruby
Alipay::Service.create_forex_trade_url(
out_trade_no: '20150401000-0001',
subject: 'Subject',
currency: 'USD',
total_fee: '10.00',
notify_url: 'https://example.com/orders/20150401000-0001/notify'
)
# => 'https://mapi.alipay.com/gateway.do?service=create_forex_trade...'
```
#### ARGUMENTS
| Key | Requirement | Description |
| --- | ----------- | ----------- |
| out_trade_no | required | Order number in your application. |
| subject | required | Order subject. |
| currency | required | Abbreviated currency name. |
| total_fee | required | Order total price. |
| notify_url | optional | Alipay asyn notify url. |
### 境外收单单笔退款接口
#### Name
```ruby
forex_refund
```
#### Definition
```ruby
Alipay::Service.forex_refund_url({ARGUMENTS}, {OPTIONS})
```
#### Example
```ruby
Alipay::Service.forex_refund_url(
out_return_no: '20150401000-0001',
out_trade_no: '201504010000001',
return_amount: '10.00',
currency: 'USD',
reason: 'Reason',
gmt_return: '20150401000000'
)
```
#### ARGUMENTS
| Key | Requirement | Description |
| --- | ----------- | ----------- |
| out_return_no | required | Refund no, you should store it to db to avoid alipay duplicate refund. |
| out_trade_no | required | Order number in your application. |
| return_amount | required | Refund amount. |
| currency | required | Abbreviated currency name. |
| reason | required | Refun reason. |
| gmt_return | required * | YYYYMMDDHHMMSS Beijing Time. |
\* Auto set Time.now if not set.
### 快捷支付(无线)
#### Name
```ruby
mobile.securitypay.pay
```
#### Definition
```ruby
Alipay::Service.mobile_security_pay_url({ARGUMENTS}, {OPTIONS})
```
#### Example
```ruby
Alipay::Service.mobile_security_pay_url(
out_trade_no: '20150401000-0001',
notify_url: 'https://example.com/orders/20150401000-0001/notify'
subject: 'subject',
total_fee: '10.00',
body: 'text'
)
```
#### ARGUMENTS
| Key | Requirement | Description |
| --- | ----------- | ----------- |
| out_trade_no | required | Order number in your application. |
| notify_url | required | Alipay asyn notify url. |
| subject | required | Order subject. |
| total_fee | required | Order total price. |
| body | required | Order body, less than 512 bytes. |
\* This service only support RSA sign_type.
This is not a complete list of arguments, please read official document: http://download.alipay.com/public/api/base/WS_MOBILE_PAY_SDK_BASE.zip .
### 验证通知
#### Name
```ruby
notify_verify
```
#### Definition
```ruby
Alipay::Notify.verify?({PARAMS}, {OPTIONS})
```
#### Example
```ruby
# Rails
# params except :controller_name, :action_name, :host, etc.
notify_params = params.except(*request.path_parameters.keys)
Alipay::Notify.verify?(notify_params)
```
## Wap::Service
### 授权接口
#### Name
```ruby
alipay.wap.trade.create.direct
```
#### Definition
```ruby
Alipay::Wap::Service.trade_create_direct_token({ARGUMENTS}, {OPTIONS}}
```
#### Example
```ruby
token = Alipay::Wap::Service.trade_create_direct_token(
req_data: {
out_trade_no: '20150401000-0001',
subject: 'Subject',
total_fee: '10.0',
call_back_url: 'https://example.com/orders/20150401000-0001',
notify_url: 'https://example.com/orders/20150401000-0001/notify'
}
)
```
#### ARGUMENTS
| Key | Requirement | Description |
| --- | ----------- | ----------- |
| req_data | required | See req_data ARGUMENTS |
##### req_data ARGUMENTS
| Key | Requirement | Description |
| --- | ----------- | ----------- |
| out_order_no | required | Order id in your application. |
| subject | required | Order subject. |
| total_fee | required | Order total price. |
| return_url | optional | Redirect customer to this url after payment. |
| notify_url | optional | Alipay asyn notify url. |
This is not a complete list of arguments, please read official document: http://download.alipay.com/public/api/base/WS_WAP_PAYWAP.zip .
### 交易接口
#### Name
```ruby
alipay.wap.auth.authAndExecute
```
#### Definition
```ruby
Alipay::Wap::Service.auth_and_execute({ARGUMENTS}, {OPTIONS})
```
#### Example
```ruby
Alipay::Wap::Service.auth_and_execute(request_token: token)
```
#### ARGUMENTS
| Key | Requirement | Description |
| --- | ----------- | ----------- |
| request_token | required | Get from trade_create_direct_token |
### 验证通知
#### Name
```ruby
notify_verify
```
#### Definition
```ruby
Alipay::Wap::Notify.verify?({PARAMS}, {OPTIONS})
```
#### Example
```ruby
# Rails
# params except :controller_name, :action_name, :host, etc.
notify_params = params.except(*request.path_parameters.keys)
Alipay::Wap::Notify.verify?(notify_params)
```
## Contributing
Bug report or pull request are welcome.
### Make a pull request
1. Fork it
2. Create your feature branch (`git checkout -b my-new-feature`)
3. Commit your changes (`git commit -am 'Add some feature'`)
4. Push to the branch (`git push origin my-new-feature`)
5. Create new Pull Request
Please write unit test with your code if necessary.
## Donate
Donate to maintainer let him make this gem better.
Alipay donate link: http://chloerei.com/donate/ .