tbk 1.0.1 → 1.0.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.gitignore +19 -0
- data/.travis.yml +12 -0
- data/.yardopts +5 -0
- data/Gemfile +18 -0
- data/LICENSE +20 -0
- data/README.md +115 -0
- data/Rakefile +6 -0
- data/lib/tbk.rb +12 -0
- data/lib/tbk/commerce.rb +69 -0
- data/lib/tbk/config.rb +43 -0
- data/lib/tbk/errors.rb +16 -0
- data/lib/tbk/keys.rb +5 -0
- data/lib/tbk/keys/test_commerce.pem +27 -0
- data/lib/tbk/keys/webpay.101.pem +14 -0
- data/lib/tbk/keys/webpay_test.101.pem +14 -0
- data/lib/tbk/version.rb +7 -0
- data/lib/tbk/webpay.rb +4 -0
- data/lib/tbk/webpay/confirmation.rb +122 -0
- data/lib/tbk/webpay/encryption.rb +75 -0
- data/lib/tbk/webpay/logger.rb +41 -0
- data/lib/tbk/webpay/logger/base_logger.rb +34 -0
- data/lib/tbk/webpay/logger/null_logger.rb +15 -0
- data/lib/tbk/webpay/logger/official_logger.rb +193 -0
- data/lib/tbk/webpay/payment.rb +169 -0
- data/spec/commerce_spec.rb +46 -0
- data/spec/config_spec.rb +54 -0
- data/spec/spec_helper.rb +8 -0
- data/spec/support/syntax.rb +5 -0
- data/spec/support/test_commerce.rb +12 -0
- data/spec/webpay/confirmation_spec.rb +4 -0
- data/spec/webpay/encryption_spec.rb +4 -0
- data/spec/webpay/payment_spec.rb +1 -0
- data/tbk.gemspec +23 -0
- metadata +45 -4
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 23651dab425128f9a304cfc75827c22133accc87
|
4
|
+
data.tar.gz: cccbb98ef6fc50bf809e57e02fa8a018c96aa30b
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: ec0da50f8c95611d8c9eff7badd39551848dd4b45bb20c545549d6d31e6deded37309badc69ee3cb15a1b5f72bcace893a707acb6374725c97462219a817d72d
|
7
|
+
data.tar.gz: 35783d42fec9ac1bade1ccd4016a223d2bf602481dd66cf1843e2422eb6124927727a492944760d6b45bb8d4c43ddfdd8c2fd9589da2de9907edf6569e8d45ee
|
data/.gitignore
ADDED
data/.travis.yml
ADDED
data/.yardopts
ADDED
data/Gemfile
ADDED
@@ -0,0 +1,18 @@
|
|
1
|
+
source 'https://rubygems.org'
|
2
|
+
|
3
|
+
# Specify your gem's dependencies in tbk.gemspec
|
4
|
+
gemspec
|
5
|
+
|
6
|
+
platforms :jruby do
|
7
|
+
gem "jruby-openssl"
|
8
|
+
end
|
9
|
+
|
10
|
+
group :docs do
|
11
|
+
gem 'yard'
|
12
|
+
gem 'redcarpet'
|
13
|
+
end
|
14
|
+
|
15
|
+
group :test do
|
16
|
+
gem "codeclimate-test-reporter", require: false
|
17
|
+
end
|
18
|
+
|
data/LICENSE
ADDED
@@ -0,0 +1,20 @@
|
|
1
|
+
Copyright (c) 2013 Seba Gamboa
|
2
|
+
|
3
|
+
Permission is hereby granted, free of charge, to any person obtaining
|
4
|
+
a copy of this software and associated documentation files (the
|
5
|
+
"Software"), to deal in the Software without restriction, including
|
6
|
+
without limitation the rights to use, copy, modify, merge, publish,
|
7
|
+
distribute, sublicense, and/or sell copies of the Software, and to
|
8
|
+
permit persons to whom the Software is furnished to do so, subject to
|
9
|
+
the following conditions:
|
10
|
+
|
11
|
+
The above copyright notice and this permission notice shall be
|
12
|
+
included in all copies or substantial portions of the Software.
|
13
|
+
|
14
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
15
|
+
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
16
|
+
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
17
|
+
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
18
|
+
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
19
|
+
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
20
|
+
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
data/README.md
ADDED
@@ -0,0 +1,115 @@
|
|
1
|
+
### About
|
2
|
+
[![Gem Version](https://badge.fury.io/rb/tbk.png)](http://badge.fury.io/rb/tbk)
|
3
|
+
[![Build Status](https://travis-ci.org/sagmor/tbk.png)](https://travis-ci.org/sagmor/tbk)
|
4
|
+
[![Code Climate](https://codeclimate.com/github/sagmor/tbk.png)](https://codeclimate.com/github/sagmor/tbk)
|
5
|
+
|
6
|
+
This is a pure ruby replacement of Transbank's Binary Integration Kit (aka. KCC)
|
7
|
+
developed to simplify the integration with it's payment gateway Webpay.
|
8
|
+
|
9
|
+
|
10
|
+
### Disclaimer
|
11
|
+
|
12
|
+
This library is not developed, supported nor endorsed in any way by Transbank S.A.
|
13
|
+
and is the result of reverse engineering Transbank's Integration Kit (aka. KCC)
|
14
|
+
for interoperability purposes as allowed by
|
15
|
+
[Chilean Law 20.435 Article 71 Ñ Section b](http://www.leychile.cl/Navegar?idNorma=1012827)
|
16
|
+
|
17
|
+
### Usage
|
18
|
+
|
19
|
+
Add this line to your application's Gemfile:
|
20
|
+
|
21
|
+
```ruby
|
22
|
+
gem 'tbk'
|
23
|
+
```
|
24
|
+
|
25
|
+
Configure your commerce
|
26
|
+
|
27
|
+
```ruby
|
28
|
+
TBK.configure do |config|
|
29
|
+
config.commerce_id YOUR_COMMERCE_ID
|
30
|
+
config.commerce_key YOUR_RSA_KEY
|
31
|
+
|
32
|
+
# When certifying with Transbank you'll need to use the official logger
|
33
|
+
config.webpay_logger :official do |logger|
|
34
|
+
# On this path will be the config file and logs in the KCC format.
|
35
|
+
logger.directory Rails.root.join('log/webpay')
|
36
|
+
end
|
37
|
+
end
|
38
|
+
```
|
39
|
+
|
40
|
+
To start a payment from your application
|
41
|
+
|
42
|
+
```ruby
|
43
|
+
class WebpayController < ApplicationController
|
44
|
+
|
45
|
+
# ...
|
46
|
+
|
47
|
+
# Start a payment
|
48
|
+
def pay
|
49
|
+
# Setup the payment
|
50
|
+
@payment = TBK::Webpay::Payment.new({
|
51
|
+
request_ip: request.ip,
|
52
|
+
amount: ORDER_AMOUNT,
|
53
|
+
order_id: ORDER_ID,
|
54
|
+
success_url: webpay_success_url,
|
55
|
+
# Webpay can only access the HTTP protocol to a direct IP address (keep that in mind)
|
56
|
+
confirmation_url: webpay_confirmation_url(host: SERVER_IP_ADDRESS, protocol: 'http'),
|
57
|
+
|
58
|
+
# Optionaly supply:
|
59
|
+
session_id: SOME_SESSION_VALUE,
|
60
|
+
failure_url: webpay_failure_url # success_url is used by default
|
61
|
+
})
|
62
|
+
|
63
|
+
# Redirect the user to Webpay
|
64
|
+
redirect_to @payment.redirect_url
|
65
|
+
end
|
66
|
+
|
67
|
+
# ...
|
68
|
+
end
|
69
|
+
```
|
70
|
+
|
71
|
+
And to process a payment
|
72
|
+
|
73
|
+
```ruby
|
74
|
+
class WebpayController < ApplicationController
|
75
|
+
|
76
|
+
# ...
|
77
|
+
|
78
|
+
# Confirmation callback executed from Webpay servers
|
79
|
+
def confirmation
|
80
|
+
# Read the confirmation data from the request
|
81
|
+
@confirmation = TBK::Webpay::Confirmation.new({
|
82
|
+
request_ip: request.ip,
|
83
|
+
body: request.raw_post
|
84
|
+
})
|
85
|
+
|
86
|
+
if # confirmation is invalid for some reason (wrong order_id or amount, double payment, etc...)
|
87
|
+
render text: @confirmation.reject
|
88
|
+
return # reject and stop execution
|
89
|
+
end
|
90
|
+
|
91
|
+
if @confirmation.success?
|
92
|
+
# EXITO!
|
93
|
+
# perform everything you have to do here.
|
94
|
+
end
|
95
|
+
|
96
|
+
# Acknowledge payment
|
97
|
+
render text: @confirmation.acknowledge
|
98
|
+
end
|
99
|
+
|
100
|
+
# ...
|
101
|
+
|
102
|
+
end
|
103
|
+
```
|
104
|
+
|
105
|
+
### Contributing
|
106
|
+
|
107
|
+
1. Fork it
|
108
|
+
2. Create your feature branch (`git checkout -b my-new-feature`)
|
109
|
+
3. Commit your changes (`git commit -am 'Add some feature'`)
|
110
|
+
4. Push to the branch (`git push origin my-new-feature`)
|
111
|
+
5. Create new Pull Request
|
112
|
+
|
113
|
+
|
114
|
+
[![Bitdeli Badge](https://d2weczhvl823v0.cloudfront.net/sagmor/tbk/trend.png)](https://bitdeli.com/free "Bitdeli Badge")
|
115
|
+
|
data/Rakefile
ADDED
data/lib/tbk.rb
ADDED
data/lib/tbk/commerce.rb
ADDED
@@ -0,0 +1,69 @@
|
|
1
|
+
|
2
|
+
module TBK
|
3
|
+
# Represents a commerce registered with Transbank
|
4
|
+
class Commerce
|
5
|
+
|
6
|
+
# The registered commerce id
|
7
|
+
# @return [Integer] the commerce id
|
8
|
+
attr_reader :id
|
9
|
+
|
10
|
+
# The commerce secret RSA key
|
11
|
+
# @return [OpenSSL::PKey::RSA] the commerce key
|
12
|
+
attr_reader :key
|
13
|
+
|
14
|
+
# The commerce environment
|
15
|
+
# @return [Symbol] the commerce environment
|
16
|
+
attr_reader :environment
|
17
|
+
|
18
|
+
# Initializes a new commerce
|
19
|
+
# @param [Hash] attributes The commerce attributes
|
20
|
+
# @option attributes [Integer] :id The commerce ID
|
21
|
+
# @option attributes [String|OpenSSL::PKey::RSA] :key The commerce RSA private key
|
22
|
+
# @option attributes [Boolean] :test flag to set commerce in test mode
|
23
|
+
def initialize(attributes)
|
24
|
+
@environment = (attributes[:environment] || :production).to_sym
|
25
|
+
raise TBK::CommerceError, "Invalid commerce environment" unless [:production,:test].include? @environment
|
26
|
+
|
27
|
+
@id = attributes[:id]
|
28
|
+
raise TBK::CommerceError, "Missing commerce id" if self.id.nil?
|
29
|
+
|
30
|
+
@key = case attributes[:key]
|
31
|
+
when String
|
32
|
+
OpenSSL::PKey::RSA.new(attributes[:key])
|
33
|
+
when OpenSSL::PKey::RSA
|
34
|
+
attributes[:key]
|
35
|
+
when nil
|
36
|
+
TEST_COMMERCE_KEY if self.test?
|
37
|
+
end
|
38
|
+
|
39
|
+
raise TBK::CommerceError, "Missing commerce key" if self.key.nil?
|
40
|
+
raise TBK::CommerceError, "Commerce key must be a RSA private key" unless self.key.private?
|
41
|
+
end
|
42
|
+
|
43
|
+
# @return [Boolean] whether or not the commerce is in test mode
|
44
|
+
def test?
|
45
|
+
self.environment == :test
|
46
|
+
end
|
47
|
+
|
48
|
+
# @return [Boolean] whether or not the commerce is in production mode
|
49
|
+
def production?
|
50
|
+
self.environment == :production
|
51
|
+
end
|
52
|
+
|
53
|
+
# @return [Integer] RSA key bytes
|
54
|
+
def key_bytes
|
55
|
+
self.key.n.num_bytes
|
56
|
+
end
|
57
|
+
|
58
|
+
# @return [TBK::Commerce] The default commerce
|
59
|
+
def self.default_commerce
|
60
|
+
@default_commerce ||= Commerce.new({
|
61
|
+
:id => TBK.config.commerce_id,
|
62
|
+
:key => TBK.config.commerce_key,
|
63
|
+
:environment => TBK.config.environment
|
64
|
+
}) unless TBK.config.commerce_id.nil?
|
65
|
+
end
|
66
|
+
|
67
|
+
TEST_COMMERCE_KEY = TBK.parse_key('test_commerce')
|
68
|
+
end
|
69
|
+
end
|
data/lib/tbk/config.rb
ADDED
@@ -0,0 +1,43 @@
|
|
1
|
+
module TBK
|
2
|
+
class Config
|
3
|
+
|
4
|
+
# Set and gets the default commerce id
|
5
|
+
def commerce_id(id = nil)
|
6
|
+
@id = id if id
|
7
|
+
@id || ENV['TBK_COMMERCE_ID']
|
8
|
+
end
|
9
|
+
|
10
|
+
# Sets and gets the default commerce key
|
11
|
+
def commerce_key(key = nil)
|
12
|
+
@key = key if key
|
13
|
+
@key || ENV['TBK_COMMERCE_KEY']
|
14
|
+
end
|
15
|
+
|
16
|
+
# Sets the default commerce environment
|
17
|
+
# @return [Symbol] the default commerce environment
|
18
|
+
def environment(environment = nil)
|
19
|
+
@environment = environment if environment
|
20
|
+
(@environment || ENV['TBK_COMMERCE_ENVIRONMENT'] || :production).to_sym
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
# Returns the configuration object
|
25
|
+
# @return [TBK::Config] the configuration object
|
26
|
+
def self.config
|
27
|
+
@config ||= Config.new
|
28
|
+
end
|
29
|
+
|
30
|
+
# Configure the app defaults simply by doing
|
31
|
+
#
|
32
|
+
# TBK.configure do |config|
|
33
|
+
# config.commerce_id 123456
|
34
|
+
# config.commerce_key File.read(COMMERCE_KEY_PATH)
|
35
|
+
# end
|
36
|
+
#
|
37
|
+
# @yield [TBK::Config] The config object
|
38
|
+
def self.configure(&block)
|
39
|
+
yield(self.config)
|
40
|
+
nil
|
41
|
+
end
|
42
|
+
|
43
|
+
end
|
data/lib/tbk/errors.rb
ADDED
@@ -0,0 +1,16 @@
|
|
1
|
+
module TBK
|
2
|
+
class Error < StandardError
|
3
|
+
attr_reader :origin
|
4
|
+
def initialize(msg, origin=nil)
|
5
|
+
super(msg)
|
6
|
+
@origin = origin
|
7
|
+
end
|
8
|
+
end
|
9
|
+
|
10
|
+
class CommerceError < Error; end
|
11
|
+
|
12
|
+
module Webpay
|
13
|
+
class PaymentError < Error; end
|
14
|
+
class EncryptionError < Error; end
|
15
|
+
end
|
16
|
+
end
|
data/lib/tbk/keys.rb
ADDED
@@ -0,0 +1,27 @@
|
|
1
|
+
-----BEGIN RSA PRIVATE KEY-----
|
2
|
+
MIIEowIBAAKCAQEAn3HzPC1ZBzCO3edUCf/XJiwj3bzJpjjTi/zBO9O+DDzZCaMp
|
3
|
+
14aspxQryvJhv8644E19Q+NHfxtz1cxd2wnSYKvay1gJx30ZlTOAkzUj4QMimR16
|
4
|
+
vomLlQ3T2MAz1znt/PVPVU7T/JOG9R+EbiHNVKa/hUjwJEFVXLQNME97nHoLjb3v
|
5
|
+
V5yV2aVhmox7b54n6F3UVPHvCsHKbJpXpE+vnLpVmdETbNpFVrDygXyG+mnEvyiO
|
6
|
+
BLIwEY3XTMrgXvS069groLi5Gg8C5LDaYOWjE9084T4fiWGrHhn2781R1rykunTu
|
7
|
+
77wiWPuQHMS0+YC7mhnsk8Z/ilD+aWz/vhsgHwIDAQABAoIBAQCM+Nrt4cpNKQmn
|
8
|
+
+Ne8348CGRS9ACXp6WRg6OCQXO4zM7lRZAminVgZgSQXE6aJR+T9rIWMeG7GWydX
|
9
|
+
aJGzEEQJZOjV0MkUr+7mk9qiTOGkGHmGlyHnRQU8jDU59vXe3UEl3l5+NmwHbQht
|
10
|
+
waf9F7XLmoLK/WoVJA6tICRpCl1oQrpziqN+gjdmMpz9i8I1sMFE7+Y7xf+7S2u7
|
11
|
+
c1MRPUWqgdS9yViQVh3vZi25m5CyKRVnOB0hpNuZ7nrJymtADYSWt9wV2W1fX+MX
|
12
|
+
UUoYfxyQQvWryHhGdedU7GGAnoEdblUcDkBuAaFmsm1P8K4HQZLWP4v6pYlW2JLa
|
13
|
+
Zoaerb3BAoGBANCRevl0CLB0HBU7sCs0eN9fTkIEsh3OVIxPSBqDnKsynJrIWovK
|
14
|
+
cs37Vb6phzdQO3ADoFJvR9ck8+v6Cv0KR8IOFl9wfC4ZoxkKBBeq94ZLN+YhE2PW
|
15
|
+
KiRFybqcgCtzxKS3MyWgpIcT9xFtHVjlorZ8Jk51fgLZbGzamtLhderVAoGBAMO0
|
16
|
+
mIiiV4l2vXzu4tFfkpu/GOx/D9/vAic3X9FOky09BNCyuMXMQgI8e3wWsGEZghls
|
17
|
+
Vg9KDV5EPxAmpumcdPFK2IMACaH41ac7vys3ZD8kMK0INQkuDAcG4YsxMaTwEPo0
|
18
|
+
p1i3zwwEWwknw1yJkOyozz0EcIzS9NrZZEjnBHEjAoGAQ81XdeqzvHEyg/CQd6sq
|
19
|
+
NCtubGXMZYYi1C4d2Yi5kKn2YRcK4HDi23V+TWodK+0oNWToZIQKjbVUmn0Bv3rt
|
20
|
+
EvezbDlMFUx+SfCIng0VRJIFTQmpnQYNUxdg2gpwXC/ZWFa6CNxtQABMjFy1cqXM
|
21
|
+
PJild1IYseJurgBu3mkvBTUCgYBqA/T1X2woLUis2wPIBAv5juXDh3lkB6eU8uxX
|
22
|
+
CEe2I+3t2EM781B2wajrKadWkmjluMhN9AGV5UZ8S1P0DStUYwUywdx1/8RNmZIP
|
23
|
+
qSwHAGXV9jI0zNr7G4Em0/leriWkRM26w6fHjLx8EyxDfsohSbkqBrOptcWqoEUx
|
24
|
+
MOQ5HQKBgAS4sbddOas2MapuhKU2surEb3Kz3RCIpta4bXgTQMt9wawcZSSpvnfT
|
25
|
+
zs5sehYvBFszL3MV98Uc50HXMf7gykRCmPRmB9S+f+kiVRvQDHfc9nRNg2XgcotU
|
26
|
+
KAE16PQM8GihQ0C+EcXHouyud5CRJGfyurokRlH/jY3BiRAG5c+6
|
27
|
+
-----END RSA PRIVATE KEY-----
|
@@ -0,0 +1,14 @@
|
|
1
|
+
-----BEGIN PUBLIC KEY-----
|
2
|
+
MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAxKKjroxE7X44TQovh9A9
|
3
|
+
ZpntP7LrdoyFsnJbDKjOOCoiid92FydN5qemyQCeXhsc7QHUXwGdth22fB8xJr3a
|
4
|
+
MZBEUJ+BKFrL+W6yE5V+F5Bj0Uq3lL0QMAIftGhLpgqw0ZMtU89kyd9Q4Rclq4r8
|
5
|
+
p2m/ZD7Pn5EmTOFSeyoWTMZQDl7OEoCKh/cZH5NJdWL08lCI+sGLOghRmFzkve4h
|
6
|
+
F9JCwKA7NYG7j3BWh39Oj2NIXEY/TO1Y3Y2WfNv9nvTpr46SpFlyp0KOhSiqgvXX
|
7
|
+
DgeXlebyqS82ch2DzOV9fjDAw7t71WXJBAev8Gd6HXwIXE/JP6AnLCa2Y+b6Wv8K
|
8
|
+
GWBCMIBXWL0m7WHeCaJ9Hx2yXZmHJh8FgeKffFKCwn3X90JiMocOSGsOE+Sfo85S
|
9
|
+
h/39Vc7vZS3i7kJDDoz9ab9/vFy30RuJf4p8Erh7kWtERVoG6/EhR+j4N3mgIOBZ
|
10
|
+
SHfzDAoOnqP5l7t2RXYcEbRLVN6o+XgUtalX33EJxJRsXoz9a6PxYlesIwPbKteD
|
11
|
+
BZ/xyJDwTc2gU2YzSH8G9anKrcvITBDULSAuxQUkYOiLbkb7vSKWDYKe0do6ibO3
|
12
|
+
RY/KXI63Q7bGKYaI2aa/8GnqVJ2G1U2s59NpqX0aaWjn59gsA8trA0YKOZP4xJIh
|
13
|
+
CvLM94G4V7lxe2IHKPqLscMCAwEAAQ==
|
14
|
+
-----END PUBLIC KEY-----
|
@@ -0,0 +1,14 @@
|
|
1
|
+
-----BEGIN PUBLIC KEY-----
|
2
|
+
MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAtKe3HHWwRcizAfkbS92V
|
3
|
+
fQr8cUb94TRjQPzNTqBduvvj65AD5J98Cn1htE3NzOz+PjPRcnfVe53V4f3+YlIb
|
4
|
+
6nnxyeuYLByiwoPkCmpOFBxNp04/Yh3dxN4xgOANXA37rNbDeO4WIEMG6zbdQMNJ
|
5
|
+
7RqQUlJSmui8gt3YxtqWBhBVW79qDCYVzxFrv3SH7pRuYEr+cxDvzRylxnJgr6ee
|
6
|
+
N7gmjoSMqF16f9aGdQ12obzV0A35BqpN6pRFoS/NvICbEeedS9g5gyUHf54a+juB
|
7
|
+
OV2HH5VJsCCgcb7I7Sio/xXTyP+QjIGJfpukkE8F+ohwRiChZ9jMXofPtuZYZiFQ
|
8
|
+
/gX08s5Qdpaph65UINP7crYbzpVJdrT2J0etyMcZbEanEkoX8YakLEBpPhyyR7mC
|
9
|
+
73fWd9sTuBEkG6kzCuG2JAyo6V8eyISnlKDEVd+/6G/Zpb5cUdBCERTYz5gvNoZN
|
10
|
+
zkuq4isiXh5MOLGs91H8ermuhdQe/lqvXf8Op/EYrAuxcdrZK0orI4LbPdUrC0Jc
|
11
|
+
Fl02qgXRrSpXo72anOlFc9P0blD4CMevW2+1wvIPA0DaJPsTnwBWOUqcfa7GAFH5
|
12
|
+
KGs3zCiZ5YTLDlnaps8koSssTVRi7LVT8HhiC5mjBklxmZjBv6ckgQeFWgp18kuU
|
13
|
+
ve5Elj5HSV7x2PCz8RKB4XcCAwEAAQ==
|
14
|
+
-----END PUBLIC KEY-----
|
data/lib/tbk/version.rb
ADDED
data/lib/tbk/webpay.rb
ADDED