unionpei 0.0.4 → 1.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/unionpei/acp_sdk.ini +1 -1
- data/lib/unionpei/log_util.rb +1 -2
- data/lib/unionpei/payment.rb +71 -64
- data/lib/unionpei/sdk_config.rb +0 -1
- data/lib/unionpei/version.rb +1 -1
- metadata +3 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 98b28f654f4ca48e64be757fc3d5fd74f523acd18388affdfcaca5f1125fcd31
|
4
|
+
data.tar.gz: 53d6ed97a4de7a451024c31ef9737f0e9eeb8d83fbf4898b22964d7288325b43
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: c170604ec476c96c0fbf3ec661ac1fedb2bc57a9952b3f8e8a6092aefe7e55bfc01f9e86fe7fd7eac88a0bc0df6a43ebee279cb97ebfcaa40dd2ef4e23aac2e8
|
7
|
+
data.tar.gz: 822b695d4549dbdcdb4b39a989f04ae842012684ea01b4ea69a85526be564286c7933edff124963e054b5389d2465e0a34a07a70d894add087186e631edeb558
|
data/lib/unionpei/acp_sdk.ini
CHANGED
@@ -42,7 +42,7 @@ acpsdk.ifValidateRemoteCert=false
|
|
42
42
|
acpsdk.backUrl=http://222.222.222.222:8080/backRcvResponse
|
43
43
|
|
44
44
|
;前台通知地址,填写后台接收银联后台通知的地址,必须外网能访问
|
45
|
-
acpsdk.frontUrl=
|
45
|
+
acpsdk.frontUrl=localhost:3000/subscriptions
|
46
46
|
|
47
47
|
;;;;;;;;;;;;;;;;;;;;;;;;;入网测试环境签名证书配置 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
48
48
|
; 多证书的情况证书路径为代码指定,可不对此块做配置。
|
data/lib/unionpei/log_util.rb
CHANGED
@@ -17,7 +17,6 @@ module UnionPei
|
|
17
17
|
|
18
18
|
def LogUtil.getLogger
|
19
19
|
if !@@logger
|
20
|
-
puts "init LogUtil"
|
21
20
|
if SDKConfig.instance.logFilePath.nil?
|
22
21
|
@@logger = Logger.new(STDOUT)
|
23
22
|
else
|
@@ -42,7 +41,7 @@ module UnionPei
|
|
42
41
|
Logger::UNKNOWN
|
43
42
|
end
|
44
43
|
end
|
45
|
-
p = LogUtil.parse_caller(caller(0)[2])
|
44
|
+
p = LogUtil.parse_caller(caller(0)[2])
|
46
45
|
@@logger.progname = p[0].to_s + ":" + p[1].to_s
|
47
46
|
@@logger
|
48
47
|
end
|
data/lib/unionpei/payment.rb
CHANGED
@@ -3,78 +3,85 @@
|
|
3
3
|
require "date"
|
4
4
|
require_relative 'sdk_config'
|
5
5
|
require_relative 'acp_service'
|
6
|
-
|
7
6
|
module UnionPei
|
8
7
|
class Payment
|
9
8
|
class << self
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
req
|
31
|
-
|
32
|
-
#签名示例
|
9
|
+
@@default_b2c_req = {
|
10
|
+
"version"=>UnionPei::SDKConfig.instance.version,
|
11
|
+
"encoding"=>UnionPei::SDKConfig.instance.encoding,
|
12
|
+
"signMethod"=>UnionPei::SDKConfig.instance.signMethod,
|
13
|
+
"frontUrl"=>UnionPei::SDKConfig.instance.frontUrl,
|
14
|
+
"backUrl"=>UnionPei::SDKConfig.instance.backUrl,
|
15
|
+
"txnType"=>"01",
|
16
|
+
"txnSubType"=>"01",
|
17
|
+
"bizType"=>"000201", # 000201 是b2c / 000202 是 b2b
|
18
|
+
"channelType"=>"07",
|
19
|
+
"currencyCode"=>"156",
|
20
|
+
"txnAmt"=>"881000",
|
21
|
+
"merId"=>"777290058189920",
|
22
|
+
"orderId"=>DateTime.parse(Time.now.to_s).strftime("%Y%m%d%H%M%S").to_s,
|
23
|
+
"txnTime"=>DateTime.parse(Time.now.to_s).strftime("%Y%m%d%H%M%S").to_s,
|
24
|
+
"accessType"=>"0"
|
25
|
+
}
|
26
|
+
|
27
|
+
# 【默认大于配置】哲学
|
28
|
+
def b2c(req=@@default_b2c_req)
|
29
|
+
req = @@default_b2c_req.merge(req)
|
33
30
|
UnionPei::AcpService.sign(req)
|
34
31
|
url = UnionPei::SDKConfig.instance.frontTransUrl
|
35
|
-
|
36
|
-
#前台自提交表单示例
|
37
|
-
resp = UnionPei::AcpService.createAutoFormHtml(req, url)
|
38
|
-
resp
|
32
|
+
UnionPei::AcpService.createAutoFormHtml(req, url)
|
39
33
|
end
|
40
34
|
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
req
|
66
|
-
req
|
67
|
-
|
68
|
-
req
|
69
|
-
|
70
|
-
|
71
|
-
#签名示例
|
72
|
-
Com::UnionPay::Acp::Sdk::AcpService.sign(req)
|
73
|
-
url = Com::UnionPay::Acp::Sdk::SDKConfig.instance.frontTransUrl
|
35
|
+
@@default_b2b_req = {
|
36
|
+
"version"=>UnionPei::SDKConfig.instance.version,
|
37
|
+
"encoding"=>UnionPei::SDKConfig.instance.encoding,
|
38
|
+
"signMethod"=>UnionPei::SDKConfig.instance.signMethod,
|
39
|
+
"frontUrl"=>UnionPei::SDKConfig.instance.frontUrl,
|
40
|
+
"backUrl"=>UnionPei::SDKConfig.instance.backUrl,
|
41
|
+
"txnType"=>"01",
|
42
|
+
"txnSubType"=>"01",
|
43
|
+
"bizType"=>"000202", # 000201 是b2c / 000202 是 b2b,
|
44
|
+
"channelType"=>"07",
|
45
|
+
"currencyCode"=>"156",
|
46
|
+
"txnAmt"=>"881000",
|
47
|
+
"merId"=>"777290058189920",
|
48
|
+
"orderId"=>DateTime.parse(Time.now.to_s).strftime("%Y%m%d%H%M%S").to_s,
|
49
|
+
"txnTime"=>DateTime.parse(Time.now.to_s).strftime("%Y%m%d%H%M%S").to_s,
|
50
|
+
"accessType"=>"0",
|
51
|
+
"payTimeout"=>DateTime.parse((Time.now + 15 * 60 * 1000).to_s).strftime("%Y%m%d%H%M%S").to_s,
|
52
|
+
"bizScene"=> "110001",
|
53
|
+
"payeeAcctNm"=> "xx商户",
|
54
|
+
"payeeAcctNo"=> "12345678",
|
55
|
+
"payeeBankName"=> "xx行"
|
56
|
+
}
|
57
|
+
|
58
|
+
def b2b(req=@@default_b2b_req)
|
59
|
+
req = @@default_b2b_req.merge(req)
|
60
|
+
UnionPei::AcpService.sign(req)
|
61
|
+
url = UnionPei::SDKConfig.instance.frontTransUrl
|
62
|
+
UnionPei::AcpService.createAutoFormHtml(req, url)
|
63
|
+
end
|
74
64
|
|
75
|
-
|
76
|
-
|
77
|
-
|
65
|
+
@@default_trans_req = {
|
66
|
+
"version"=>UnionPei::SDKConfig.instance.version,
|
67
|
+
"encoding"=>UnionPei::SDKConfig.instance.encoding,
|
68
|
+
"bizType"=>"000000",
|
69
|
+
"txnTime"=>DateTime.parse(Time.now.to_s).strftime("%Y%m%d%H%M%S").to_s,
|
70
|
+
"txnType"=>"00",
|
71
|
+
"txnSubType"=>"00",
|
72
|
+
"accessType"=>"0",
|
73
|
+
"signMethod"=>UnionPei::SDKConfig.instance.signMethod,
|
74
|
+
"merId"=>"777290058189920",
|
75
|
+
"orderId"=>DateTime.parse(Time.now.to_s).strftime("%Y%m%d%H%M%S").to_s,
|
76
|
+
}
|
77
|
+
|
78
|
+
# query single transaction info
|
79
|
+
# doc https://open.unionpay.com/tjweb/acproduct/APIList?acpAPIId=757&apiservId=448&version=V2.2&bussType=0
|
80
|
+
def query_trans(req=@@default_trans_req)
|
81
|
+
req = @@default_trans_req.merge(req)
|
82
|
+
UnionPei::AcpService.sign(req)
|
83
|
+
url = UnionPei::SDKConfig.instance.singleQueryUrl
|
84
|
+
UnionPei::AcpService.post(req, url)
|
78
85
|
end
|
79
86
|
end
|
80
87
|
end
|
data/lib/unionpei/sdk_config.rb
CHANGED
@@ -17,7 +17,6 @@ module UnionPei
|
|
17
17
|
|
18
18
|
path = File.dirname(__FILE__)
|
19
19
|
ini = IniParse.parse(File.read("#{path}/acp_sdk.ini").force_encoding("UTF-8"))
|
20
|
-
puts 'load config: ' + "#{path}/acp_sdk.ini"
|
21
20
|
|
22
21
|
@frontTransUrl = ini["acpsdk"]["acpsdk.frontTransUrl"]
|
23
22
|
@singleQueryUrl = ini["acpsdk"]["acpsdk.singleQueryUrl"]
|
data/lib/unionpei/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: unionpei
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version:
|
4
|
+
version: 1.1.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Shuang
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2022-08-25 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: iniparse
|
@@ -58,7 +58,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
58
58
|
- !ruby/object:Gem::Version
|
59
59
|
version: '0'
|
60
60
|
requirements: []
|
61
|
-
rubygems_version: 3.
|
61
|
+
rubygems_version: 3.3.5
|
62
62
|
signing_key:
|
63
63
|
specification_version: 4
|
64
64
|
summary: An unofficial unionpay gem
|