unionpei 1.1.0 → 1.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/.gitignore +17 -0
- data/Gemfile +6 -0
- data/Rakefile +11 -0
- data/certs/acp_test_enc.cer +25 -0
- data/certs/acp_test_middle.cer +23 -0
- data/certs/acp_test_root.cer +22 -0
- data/certs/acp_test_sign.pfx +0 -0
- data/install.sh +2 -0
- data/lib/unionpei/acp_service.rb +37 -42
- data/lib/unionpei/cert_util.rb +61 -82
- data/lib/unionpei/log_util.rb +24 -30
- data/lib/unionpei/payment.rb +50 -51
- data/lib/unionpei/sdk_config.rb +47 -47
- data/lib/unionpei/sdk_util.rb +164 -186
- data/lib/unionpei/version.rb +2 -6
- data/lib/unionpei.rb +5 -2
- data/readme.txt +25 -0
- data/unionpei.gemspec +31 -0
- metadata +84 -3
data/lib/unionpei/payment.rb
CHANGED
@@ -1,31 +1,31 @@
|
|
1
|
-
#
|
1
|
+
# frozen_string_literal: true
|
2
2
|
|
3
|
-
require
|
3
|
+
require 'date'
|
4
4
|
require_relative 'sdk_config'
|
5
5
|
require_relative 'acp_service'
|
6
6
|
module UnionPei
|
7
7
|
class Payment
|
8
8
|
class << self
|
9
9
|
@@default_b2c_req = {
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
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
25
|
}
|
26
26
|
|
27
27
|
# 【默认大于配置】哲学
|
28
|
-
def b2c(req
|
28
|
+
def b2c(req = @@default_b2c_req)
|
29
29
|
req = @@default_b2c_req.merge(req)
|
30
30
|
UnionPei::AcpService.sign(req)
|
31
31
|
url = UnionPei::SDKConfig.instance.frontTransUrl
|
@@ -33,29 +33,29 @@ module UnionPei
|
|
33
33
|
end
|
34
34
|
|
35
35
|
@@default_b2b_req = {
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
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
56
|
}
|
57
57
|
|
58
|
-
def b2b(req
|
58
|
+
def b2b(req = @@default_b2b_req)
|
59
59
|
req = @@default_b2b_req.merge(req)
|
60
60
|
UnionPei::AcpService.sign(req)
|
61
61
|
url = UnionPei::SDKConfig.instance.frontTransUrl
|
@@ -63,21 +63,21 @@ module UnionPei
|
|
63
63
|
end
|
64
64
|
|
65
65
|
@@default_trans_req = {
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
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
76
|
}
|
77
77
|
|
78
78
|
# query single transaction info
|
79
79
|
# doc https://open.unionpay.com/tjweb/acproduct/APIList?acpAPIId=757&apiservId=448&version=V2.2&bussType=0
|
80
|
-
def query_trans(req
|
80
|
+
def query_trans(req = @@default_trans_req)
|
81
81
|
req = @@default_trans_req.merge(req)
|
82
82
|
UnionPei::AcpService.sign(req)
|
83
83
|
url = UnionPei::SDKConfig.instance.singleQueryUrl
|
@@ -86,4 +86,3 @@ module UnionPei
|
|
86
86
|
end
|
87
87
|
end
|
88
88
|
end
|
89
|
-
|
data/lib/unionpei/sdk_config.rb
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
#
|
1
|
+
# frozen_string_literal: true
|
2
2
|
|
3
3
|
require 'iniparse'
|
4
4
|
require 'singleton'
|
@@ -14,62 +14,62 @@ module UnionPei
|
|
14
14
|
:encoding, :secureKey, :logFilePath, :logLevel
|
15
15
|
|
16
16
|
def initialize
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
@
|
22
|
-
@
|
23
|
-
@
|
24
|
-
@
|
25
|
-
@
|
26
|
-
@
|
27
|
-
|
28
|
-
|
29
|
-
@
|
30
|
-
@
|
31
|
-
@
|
32
|
-
@
|
33
|
-
|
34
|
-
|
35
|
-
@
|
36
|
-
@
|
37
|
-
|
38
|
-
|
39
|
-
@signMethod =
|
40
|
-
@
|
41
|
-
@version =
|
42
|
-
|
43
|
-
|
44
|
-
@ifValidateCNName = ini["acpsdk"]["acpsdk.ifValidateCNName"]
|
17
|
+
ini = parse_acpsdk
|
18
|
+
acpsdk = ini['acpsdk']
|
19
|
+
|
20
|
+
@frontTransUrl = acpsdk['acpsdk.frontTransUrl']
|
21
|
+
@singleQueryUrl = acpsdk['acpsdk.singleQueryUrl']
|
22
|
+
@backTransUrl = acpsdk['acpsdk.backTransUrl']
|
23
|
+
@batchTransUrl = acpsdk['acpsdk.batchTransUrl']
|
24
|
+
@fileTransUrl = acpsdk['acpsdk.fileTransUrl']
|
25
|
+
@appTransUrl = acpsdk['acpsdk.appTransUrl']
|
26
|
+
@cardTransUrl = acpsdk['acpsdk.cardTransUrl']
|
27
|
+
|
28
|
+
@jfFrontTransUrl = acpsdk['acpsdk.jfFrontTransUrl']
|
29
|
+
@jfSingleQueryUrl = acpsdk['acpsdk.jfSingleQueryUrl']
|
30
|
+
@jfBackTransUrl = acpsdk['acpsdk.jfBackTransUrl']
|
31
|
+
@jfCardTransUrl = acpsdk['acpsdk.jfCardTransUrl']
|
32
|
+
@jfAppTransUrl = acpsdk['acpsdk.jfAppTransUrl']
|
33
|
+
|
34
|
+
@qrcBackTransUrl = acpsdk['acpsdk.qrcBackTransUrl']
|
35
|
+
@qrcB2cIssBackTransUrl = acpsdk['acpsdk.qrcB2cIssBackTransUrl']
|
36
|
+
@qrcB2cMerBackTransUrl = acpsdk['acpsdk.qrcB2cMerBackTransUrl']
|
37
|
+
|
38
|
+
@signMethod = acpsdk['acpsdk.signMethod']
|
39
|
+
@signMethod = @signMethod.to_s unless @signMethod.nil?
|
40
|
+
@version = acpsdk['acpsdk.version']
|
41
|
+
@version = '5.0.0' if @version.nil?
|
42
|
+
|
43
|
+
@ifValidateCNName = acpsdk['acpsdk.ifValidateCNName']
|
45
44
|
@ifValidateCNName = true if @ifValidateCNName.nil?
|
46
|
-
@ifValidateRemoteCert =
|
45
|
+
@ifValidateRemoteCert = acpsdk['acpsdk.ifValidateRemoteCert']
|
47
46
|
@ifValidateRemoteCert = false if @ifValidateRemoteCert.nil?
|
48
47
|
|
49
|
-
@signCertPath =
|
50
|
-
@signCertPwd =
|
51
|
-
@signCertPwd = @signCertPwd.to_s
|
48
|
+
@signCertPath = acpsdk['acpsdk.signCert.path']
|
49
|
+
@signCertPwd = acpsdk['acpsdk.signCert.pwd']
|
50
|
+
@signCertPwd = @signCertPwd.to_s unless @signCertPwd.nil?
|
52
51
|
|
53
|
-
@validateCertDir =
|
54
|
-
@encryptCertPath =
|
55
|
-
@rootCertPath =
|
56
|
-
@middleCertPath =
|
52
|
+
@validateCertDir = acpsdk['acpsdk.validateCert.dir']
|
53
|
+
@encryptCertPath = acpsdk['acpsdk.encryptCert.path']
|
54
|
+
@rootCertPath = acpsdk['acpsdk.rootCert.path']
|
55
|
+
@middleCertPath = acpsdk['acpsdk.middleCert.path']
|
57
56
|
|
58
|
-
@frontUrl =
|
59
|
-
@backUrl =
|
57
|
+
@frontUrl = acpsdk['acpsdk.frontUrl']
|
58
|
+
@backUrl = acpsdk['acpsdk.backUrl']
|
60
59
|
|
61
|
-
@encoding =
|
62
|
-
@secureKey =
|
63
|
-
@secureKey = @secureKey.to_s
|
60
|
+
@encoding = acpsdk['acpsdk.encoding']
|
61
|
+
@secureKey = acpsdk['acpsdk.secureKey']
|
62
|
+
@secureKey = @secureKey.to_s unless @secureKey.nil?
|
64
63
|
|
65
|
-
@logFilePath =
|
66
|
-
@logLevel =
|
64
|
+
@logFilePath = acpsdk['acpsdk.log.file.path']
|
65
|
+
@logLevel = acpsdk['acpsdk.log.level']
|
67
66
|
|
68
67
|
@encoding = 'UTF-8'
|
68
|
+
end
|
69
69
|
|
70
|
+
def parse_acpsdk
|
71
|
+
path = File.dirname(__FILE__)
|
72
|
+
@ini ||= IniParse.parse(File.read("#{path}/acp_sdk.ini").force_encoding('UTF-8'))
|
70
73
|
end
|
71
74
|
end
|
72
75
|
end
|
73
|
-
|
74
|
-
|
75
|
-
|