veritrans 2.3.0 → 2.4.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.gitignore +4 -0
- data/.idea/.gitignore +8 -0
- data/.rubocop.yml +1 -1
- data/.travis.yml +2 -1
- data/CHANGELOG.md +13 -0
- data/Gemfile +2 -11
- data/Gemfile.lock +116 -145
- data/Maintaining.MD +8 -0
- data/README.md +247 -278
- data/api_reference.md +482 -173
- data/example/coreapi/core_api_credit_card_example.rb +66 -0
- data/example/coreapi/readme.md +4 -0
- data/example/sinatra/Gemfile +7 -0
- data/example/sinatra/README.md +4 -6
- data/example/sinatra/index.erb +180 -192
- data/example/sinatra/response.erb +1 -40
- data/example/sinatra/snap.erb +33 -0
- data/example/sinatra/snap_redirect.erb +10 -0
- data/example/sinatra/webapp.rb +113 -0
- data/example/snap/readme.md +4 -0
- data/example/snap/snap_example.rb +39 -0
- data/lib/test/all.rb +1 -0
- data/lib/test/api_test.rb +319 -0
- data/lib/test/config_test.rb +26 -0
- data/lib/test/gopay_tokenization_test.rb +80 -0
- data/lib/test/snap_test.rb +79 -0
- data/lib/test/subscription_test.rb +116 -0
- data/lib/test/transaction_test.rb +160 -0
- data/lib/veritrans/api.rb +105 -8
- data/lib/veritrans/client.rb +40 -7
- data/lib/veritrans/config.rb +26 -3
- data/lib/veritrans/midtrans_error.rb +15 -0
- data/lib/veritrans/version.rb +1 -1
- data/lib/veritrans.rb +5 -6
- data/veritrans.gemspec +1 -2
- metadata +25 -248
- data/.rspec +0 -2
- data/Procfile +0 -1
- data/Rakefile +0 -16
- data/bin/midtrans +0 -3
- data/bin/veritrans +0 -68
- data/example/rails/cable/Gemfile +0 -48
- data/example/rails/cable/Gemfile.lock +0 -184
- data/example/rails/cable/README.md +0 -29
- data/example/rails/cable/Rakefile +0 -6
- data/example/rails/cable/app/assets/config/manifest.js +0 -3
- data/example/rails/cable/app/assets/images/.keep +0 -0
- data/example/rails/cable/app/assets/javascripts/application.js +0 -15
- data/example/rails/cable/app/assets/javascripts/cable.js +0 -13
- data/example/rails/cable/app/assets/javascripts/channels/.keep +0 -0
- data/example/rails/cable/app/assets/javascripts/chats.js +0 -39
- data/example/rails/cable/app/assets/javascripts/rooms.js +0 -55
- data/example/rails/cable/app/assets/stylesheets/application.css +0 -16
- data/example/rails/cable/app/assets/stylesheets/chatbox.scss +0 -31
- data/example/rails/cable/app/assets/stylesheets/peoplebox.scss +0 -6
- data/example/rails/cable/app/channels/application_cable/channel.rb +0 -4
- data/example/rails/cable/app/channels/application_cable/connection.rb +0 -4
- data/example/rails/cable/app/channels/rooms_texting_channel.rb +0 -13
- data/example/rails/cable/app/controllers/application_controller.rb +0 -3
- data/example/rails/cable/app/controllers/chats_controller.rb +0 -18
- data/example/rails/cable/app/controllers/concerns/.keep +0 -0
- data/example/rails/cable/app/controllers/pays_controller.rb +0 -28
- data/example/rails/cable/app/controllers/rooms_controller.rb +0 -4
- data/example/rails/cable/app/helpers/application_helper.rb +0 -2
- data/example/rails/cable/app/helpers/chats_helper.rb +0 -2
- data/example/rails/cable/app/helpers/rooms_helper.rb +0 -5
- data/example/rails/cable/app/jobs/application_job.rb +0 -2
- data/example/rails/cable/app/jobs/chat_broadcaster_job.rb +0 -15
- data/example/rails/cable/app/mailers/application_mailer.rb +0 -4
- data/example/rails/cable/app/models/application_record.rb +0 -3
- data/example/rails/cable/app/models/chat.rb +0 -41
- data/example/rails/cable/app/models/concerns/.keep +0 -0
- data/example/rails/cable/app/models/order.rb +0 -2
- data/example/rails/cable/app/models/user.rb +0 -2
- data/example/rails/cable/app/views/chats/_chat.html.erb +0 -18
- data/example/rails/cable/app/views/layouts/application.html.erb +0 -19
- data/example/rails/cable/app/views/layouts/mailer.html.erb +0 -13
- data/example/rails/cable/app/views/layouts/mailer.text.erb +0 -1
- data/example/rails/cable/app/views/rooms/_chatbox.html.erb +0 -13
- data/example/rails/cable/app/views/rooms/_online_people.html.erb +0 -53
- data/example/rails/cable/app/views/rooms/index.html.erb +0 -9
- data/example/rails/cable/bin/bundle +0 -3
- data/example/rails/cable/bin/rails +0 -9
- data/example/rails/cable/bin/rake +0 -9
- data/example/rails/cable/bin/setup +0 -34
- data/example/rails/cable/bin/spring +0 -16
- data/example/rails/cable/bin/update +0 -29
- data/example/rails/cable/config/application.rb +0 -16
- data/example/rails/cable/config/boot.rb +0 -3
- data/example/rails/cable/config/cable.yml +0 -9
- data/example/rails/cable/config/database.yml +0 -20
- data/example/rails/cable/config/environment.rb +0 -5
- data/example/rails/cable/config/environments/development.rb +0 -57
- data/example/rails/cable/config/environments/production.rb +0 -86
- data/example/rails/cable/config/environments/test.rb +0 -42
- data/example/rails/cable/config/initializers/application_controller_renderer.rb +0 -6
- data/example/rails/cable/config/initializers/assets.rb +0 -11
- data/example/rails/cable/config/initializers/backtrace_silencers.rb +0 -7
- data/example/rails/cable/config/initializers/cookies_serializer.rb +0 -5
- data/example/rails/cable/config/initializers/filter_parameter_logging.rb +0 -4
- data/example/rails/cable/config/initializers/inflections.rb +0 -16
- data/example/rails/cable/config/initializers/mime_types.rb +0 -4
- data/example/rails/cable/config/initializers/new_framework_defaults.rb +0 -24
- data/example/rails/cable/config/initializers/session_store.rb +0 -3
- data/example/rails/cable/config/initializers/sidekiq.rb +0 -2
- data/example/rails/cable/config/initializers/veritrans.rb +0 -46
- data/example/rails/cable/config/initializers/wrap_parameters.rb +0 -14
- data/example/rails/cable/config/locales/en.yml +0 -23
- data/example/rails/cable/config/puma.rb +0 -47
- data/example/rails/cable/config/routes.rb +0 -18
- data/example/rails/cable/config/secrets.yml +0 -22
- data/example/rails/cable/config/spring.rb +0 -6
- data/example/rails/cable/config/veritrans.yml +0 -13
- data/example/rails/cable/config.ru +0 -5
- data/example/rails/cable/db/development.sqlite3 +0 -0
- data/example/rails/cable/db/migrate/20161215070044_create_chats.rb +0 -10
- data/example/rails/cable/db/migrate/20161215072021_create_users.rb +0 -10
- data/example/rails/cable/db/migrate/20161219110219_create_orders.rb +0 -11
- data/example/rails/cable/db/schema.rb +0 -37
- data/example/rails/cable/db/seeds.rb +0 -41
- data/example/rails/cable/db/test.sqlite3 +0 -0
- data/example/rails/cable/lib/assets/.keep +0 -0
- data/example/rails/cable/lib/tasks/.keep +0 -0
- data/example/rails/cable/log/.keep +0 -0
- data/example/rails/cable/public/404.html +0 -67
- data/example/rails/cable/public/422.html +0 -67
- data/example/rails/cable/public/500.html +0 -66
- data/example/rails/cable/public/apple-touch-icon-precomposed.png +0 -0
- data/example/rails/cable/public/apple-touch-icon.png +0 -0
- data/example/rails/cable/public/favicon.ico +0 -0
- data/example/rails/cable/public/images/avatar1.jpg +0 -0
- data/example/rails/cable/public/images/avatar2.jpg +0 -0
- data/example/rails/cable/public/images/avatar3.jpg +0 -0
- data/example/rails/cable/public/images/avatar4.jpg +0 -0
- data/example/rails/cable/public/images/avatar5.jpg +0 -0
- data/example/rails/cable/public/images/avatar6.jpg +0 -0
- data/example/rails/cable/public/robots.txt +0 -5
- data/example/rails/cable/vendor/assets/javascripts/.keep +0 -0
- data/example/rails/cable/vendor/assets/stylesheets/.keep +0 -0
- data/example/rails/cable/vendor/assets/stylesheets/photon.css +0 -2333
- data/example/rails/simplepay/Gemfile +0 -54
- data/example/rails/simplepay/Gemfile.lock +0 -178
- data/example/rails/simplepay/README.md +0 -30
- data/example/rails/simplepay/Rakefile +0 -6
- data/example/rails/simplepay/app/assets/config/manifest.js +0 -3
- data/example/rails/simplepay/app/assets/images/.keep +0 -0
- data/example/rails/simplepay/app/assets/javascripts/application.js +0 -16
- data/example/rails/simplepay/app/assets/javascripts/cable.js +0 -13
- data/example/rails/simplepay/app/assets/javascripts/channels/.keep +0 -0
- data/example/rails/simplepay/app/assets/javascripts/pay.js +0 -18
- data/example/rails/simplepay/app/assets/stylesheets/application.css +0 -15
- data/example/rails/simplepay/app/assets/stylesheets/style.css +0 -254
- data/example/rails/simplepay/app/channels/application_cable/channel.rb +0 -4
- data/example/rails/simplepay/app/channels/application_cable/connection.rb +0 -4
- data/example/rails/simplepay/app/controllers/application_controller.rb +0 -3
- data/example/rails/simplepay/app/controllers/concerns/.keep +0 -0
- data/example/rails/simplepay/app/controllers/home_controller.rb +0 -16
- data/example/rails/simplepay/app/controllers/pay_controller.rb +0 -10
- data/example/rails/simplepay/app/helpers/application_helper.rb +0 -2
- data/example/rails/simplepay/app/helpers/pay_helper.rb +0 -2
- data/example/rails/simplepay/app/jobs/application_job.rb +0 -2
- data/example/rails/simplepay/app/mailers/application_mailer.rb +0 -4
- data/example/rails/simplepay/app/models/application_record.rb +0 -3
- data/example/rails/simplepay/app/models/concerns/.keep +0 -0
- data/example/rails/simplepay/app/models/order.rb +0 -2
- data/example/rails/simplepay/app/views/home/index.html.erb +0 -19
- data/example/rails/simplepay/app/views/layouts/application.html.erb +0 -15
- data/example/rails/simplepay/app/views/layouts/mailer.html.erb +0 -13
- data/example/rails/simplepay/app/views/layouts/mailer.text.erb +0 -1
- data/example/rails/simplepay/app/views/pay/notify.html.erb +0 -2
- data/example/rails/simplepay/bin/bundle +0 -3
- data/example/rails/simplepay/bin/rails +0 -9
- data/example/rails/simplepay/bin/rake +0 -9
- data/example/rails/simplepay/bin/setup +0 -34
- data/example/rails/simplepay/bin/spring +0 -16
- data/example/rails/simplepay/bin/update +0 -29
- data/example/rails/simplepay/config/application.rb +0 -15
- data/example/rails/simplepay/config/boot.rb +0 -3
- data/example/rails/simplepay/config/cable.yml +0 -9
- data/example/rails/simplepay/config/database.yml +0 -25
- data/example/rails/simplepay/config/environment.rb +0 -5
- data/example/rails/simplepay/config/environments/development.rb +0 -57
- data/example/rails/simplepay/config/environments/production.rb +0 -86
- data/example/rails/simplepay/config/environments/test.rb +0 -42
- data/example/rails/simplepay/config/initializers/application_controller_renderer.rb +0 -6
- data/example/rails/simplepay/config/initializers/assets.rb +0 -11
- data/example/rails/simplepay/config/initializers/backtrace_silencers.rb +0 -7
- data/example/rails/simplepay/config/initializers/cookies_serializer.rb +0 -5
- data/example/rails/simplepay/config/initializers/filter_parameter_logging.rb +0 -4
- data/example/rails/simplepay/config/initializers/inflections.rb +0 -16
- data/example/rails/simplepay/config/initializers/mime_types.rb +0 -4
- data/example/rails/simplepay/config/initializers/new_framework_defaults.rb +0 -24
- data/example/rails/simplepay/config/initializers/session_store.rb +0 -3
- data/example/rails/simplepay/config/initializers/veritrans.rb +0 -46
- data/example/rails/simplepay/config/initializers/wrap_parameters.rb +0 -14
- data/example/rails/simplepay/config/locales/en.yml +0 -23
- data/example/rails/simplepay/config/puma.rb +0 -47
- data/example/rails/simplepay/config/routes.rb +0 -5
- data/example/rails/simplepay/config/secrets.yml +0 -22
- data/example/rails/simplepay/config/spring.rb +0 -6
- data/example/rails/simplepay/config/veritrans.yml +0 -18
- data/example/rails/simplepay/config.ru +0 -5
- data/example/rails/simplepay/db/development.sqlite3 +0 -0
- data/example/rails/simplepay/db/migrate/20161221090855_create_orders.rb +0 -10
- data/example/rails/simplepay/db/schema.rb +0 -22
- data/example/rails/simplepay/db/seeds.rb +0 -7
- data/example/rails/simplepay/db/test.sqlite3 +0 -0
- data/example/rails/simplepay/lib/assets/.keep +0 -0
- data/example/rails/simplepay/lib/tasks/.keep +0 -0
- data/example/rails/simplepay/log/.keep +0 -0
- data/example/rails/simplepay/public/404.html +0 -67
- data/example/rails/simplepay/public/422.html +0 -67
- data/example/rails/simplepay/public/500.html +0 -66
- data/example/rails/simplepay/public/apple-touch-icon-precomposed.png +0 -0
- data/example/rails/simplepay/public/apple-touch-icon.png +0 -0
- data/example/rails/simplepay/public/favicon.ico +0 -0
- data/example/rails/simplepay/public/robots.txt +0 -5
- data/example/rails/simplepay/vendor/assets/javascripts/.keep +0 -0
- data/example/rails/simplepay/vendor/assets/stylesheets/.keep +0 -0
- data/example/sinatra/config.ru +0 -9
- data/example/sinatra/localization.erb +0 -249
- data/example/sinatra/points.erb +0 -188
- data/example/sinatra/recurring.erb +0 -201
- data/example/sinatra/sinatra.rb +0 -194
- data/example/sinatra/style.css +0 -137
- data/example/sinatra/veritrans.yml +0 -11
- data/example/sinatra/widget.erb +0 -63
- data/lib/generators/templates/assets/credit_card_form.js +0 -57
- data/lib/generators/templates/payments_controller.rb +0 -85
- data/lib/generators/templates/veritrans.rb +0 -46
- data/lib/generators/templates/veritrans.yml +0 -18
- data/lib/generators/templates/views/_credit_card_form.erb +0 -42
- data/lib/generators/templates/views/_veritrans_include.erb +0 -10
- data/lib/generators/templates/views/payments/create.erb +0 -15
- data/lib/generators/templates/views/payments/new.erb +0 -6
- data/lib/generators/veritrans/install_generator.rb +0 -32
- data/lib/generators/veritrans/payment_form_generator.rb +0 -45
- data/lib/veritrans/cli.rb +0 -161
- data/lib/veritrans/testing.rb +0 -156
- data/spec/cli_spec.rb +0 -83
- data/spec/configs/real_key.yml +0 -4
- data/spec/configs/veritrans.yml +0 -7
- data/spec/configs/veritrans_flat.yml +0 -2
- data/spec/configs/veritrans_with_erb.yml +0 -2
- data/spec/fixtures/approve_failed.yml +0 -48
- data/spec/fixtures/cancel_failed.yml +0 -48
- data/spec/fixtures/cancel_success.yml +0 -126
- data/spec/fixtures/capture_failed.yml +0 -48
- data/spec/fixtures/charge.yml +0 -50
- data/spec/fixtures/charge_direct.yml +0 -56
- data/spec/fixtures/charge_vtweb.yml +0 -50
- data/spec/fixtures/cli_test_1111-not-exists.yml +0 -45
- data/spec/fixtures/cli_test_not_exists.yml +0 -45
- data/spec/fixtures/cli_test_real_txn.yml +0 -55
- data/spec/fixtures/cli_test_unauthorized.yml +0 -47
- data/spec/fixtures/deny_failed.yml +0 -144
- data/spec/fixtures/events_test_real_txn.yml +0 -55
- data/spec/fixtures/expire_failed.yml +0 -50
- data/spec/fixtures/expire_success.yml +0 -56
- data/spec/fixtures/midtrans_status.yml +0 -117
- data/spec/fixtures/refund_failed.yml +0 -54
- data/spec/fixtures/status_fail.yml +0 -48
- data/spec/fixtures/status_success.yml +0 -128
- data/spec/fixtures/test_token.yml +0 -49
- data/spec/midtrans_rename_spec.rb +0 -27
- data/spec/rails_plugin_spec.rb +0 -317
- data/spec/spec_helper.rb +0 -71
- data/spec/veritrans_client_spec.rb +0 -235
- data/spec/veritrans_config_spec.rb +0 -70
- data/spec/veritrans_events_spec.rb +0 -72
- data/spec/veritrans_logger_spec.rb +0 -46
- data/spec/veritrans_snap_spec.rb +0 -54
- data/spec/veritrans_testing_spec.rb +0 -184
- data/testing_webhooks.md +0 -78
@@ -0,0 +1,66 @@
|
|
1
|
+
require 'veritrans'
|
2
|
+
|
3
|
+
# This is just for very basic implementation reference, in production, you should validate the incoming requests and implement your backend more securely.
|
4
|
+
|
5
|
+
# Set Midtrans config
|
6
|
+
# You can find it in Merchant Portal -> Settings -> Access keys
|
7
|
+
Midtrans.config.server_key = "SB-Mid-server-uQmMImQMeo0Ky3Svl90QTUj2"
|
8
|
+
Midtrans.config.client_key = "SB-Mid-client-ArNfhrh7st9bQKmz"
|
9
|
+
Midtrans.config.api_host = "https://api.sandbox.midtrans.com"
|
10
|
+
|
11
|
+
# IMPORTANT NOTE: You should do credit card get token via frontend using `midtrans-new-3ds.min.js`, to avoid card data breach risks on your backend
|
12
|
+
# ( refer to: https://docs.midtrans.com/en/core-api/credit-card?id=_1-getting-the-card-token )
|
13
|
+
# For full example on Credit Card 3DS transaction refer to:
|
14
|
+
# (/example/sinatra) that implement Snap & Core Api
|
15
|
+
|
16
|
+
# prepare CORE API parameter to get credit card token
|
17
|
+
# another sample of card number can refer to https://docs.midtrans.com/en/technical-reference/sandbox-test?id=card-payments
|
18
|
+
begin
|
19
|
+
card = {
|
20
|
+
card_number: 5211111111111117,
|
21
|
+
card_cvv: 123,
|
22
|
+
card_exp_month: 12,
|
23
|
+
card_exp_year: 2025
|
24
|
+
}
|
25
|
+
get_token = Midtrans.create_card_token(card)
|
26
|
+
|
27
|
+
# prepare CORE API parameter to charge credit card ( refer to: https://docs.midtrans.com/en/core-api/credit-card?id=_2-sending-transaction-data-to-charge-api )
|
28
|
+
result = Midtrans.charge(
|
29
|
+
{
|
30
|
+
"payment_type": "credit_card",
|
31
|
+
"transaction_details": {
|
32
|
+
"gross_amount": 10000,
|
33
|
+
"order_id": "ruby-example-coreapi-creditcard-#{Time.now.to_i}"
|
34
|
+
},
|
35
|
+
"credit_card": {
|
36
|
+
"token_id": "#{get_token.token_id}"
|
37
|
+
}
|
38
|
+
}
|
39
|
+
)
|
40
|
+
puts "charge result : #{result.data}"
|
41
|
+
rescue MidtransError => e
|
42
|
+
puts e.message # Basic message error
|
43
|
+
puts e.http_status_code # HTTP status code e.g: 400, 401, etc.
|
44
|
+
puts e.api_response # API response body in String
|
45
|
+
puts e.raw_http_client_data # Raw HTTP client response
|
46
|
+
end
|
47
|
+
|
48
|
+
# result.data this will be Hash representation of the API JSON response, of example:
|
49
|
+
# {
|
50
|
+
# : status_code => "200",
|
51
|
+
# : status_message => "Success, Credit Card transaction is successful",
|
52
|
+
# : channel_response_code => "00",
|
53
|
+
# : channel_response_message => "Approved",
|
54
|
+
# : bank => "bni",
|
55
|
+
# : transaction_id => "21386a6e-6e26-4191-9d05-877aa6063c08",
|
56
|
+
# : order_id => "ruby-example-coreapi-creditcard-1634014338",
|
57
|
+
# : merchant_id => "G686051436",: gross_amount => "10000.00",
|
58
|
+
# : currency => "IDR",
|
59
|
+
# : payment_type => "credit_card",
|
60
|
+
# : transaction_time => "2021-10-12 11:52:18",
|
61
|
+
# : transaction_status => "capture",
|
62
|
+
# : fraud_status => "accept",
|
63
|
+
# : approval_code => "1634014339258",
|
64
|
+
# : masked_card => "521111-1117",
|
65
|
+
# : card_type => "debit"
|
66
|
+
# }
|
@@ -0,0 +1,7 @@
|
|
1
|
+
source 'https://rubygems.org'
|
2
|
+
gem 'sinatra'
|
3
|
+
gem 'veritrans', path: "./../../" # install from local path, for testing purpose
|
4
|
+
|
5
|
+
# @NOTE: in real usage scenario, for your project dependency you should only require
|
6
|
+
# gem 'veritrans'
|
7
|
+
# so the gem will be installed directly from rubygem repo. No need the `, path: "./../../"`
|
data/example/sinatra/README.md
CHANGED
@@ -1,8 +1,6 @@
|
|
1
|
-
|
1
|
+
How to run sinatra example:
|
2
2
|
|
3
|
-
|
4
|
-
|
5
|
-
ruby sinatra.rb
|
6
|
-
```
|
3
|
+
1. Install dependencies: `bundle install`
|
4
|
+
2. Run the sinatra app: `bundle exec ruby webapp.rb`
|
7
5
|
|
8
|
-
|
6
|
+
The app will run at port 4567. Open `localhost:4567` from your browser.
|
data/example/sinatra/index.erb
CHANGED
@@ -1,214 +1,202 @@
|
|
1
1
|
<!doctype html>
|
2
2
|
<html>
|
3
3
|
<head>
|
4
|
-
<title>
|
5
|
-
<link rel="
|
6
|
-
<link rel="stylesheet" href="/style.css">
|
4
|
+
<title>Midtrans-Ruby simple demo</title>
|
5
|
+
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/featherlight/1.7.12/featherlight.min.css">
|
7
6
|
</head>
|
8
7
|
<body>
|
9
8
|
|
10
9
|
<header>
|
11
|
-
<h3>Midtrans sinatra app</h3>
|
10
|
+
<h3>Midtrans sample demo sinatra app</h3>
|
12
11
|
<a href="https://github.com/veritrans/veritrans-ruby" class="github">Source Code</a>
|
13
12
|
</header>
|
14
13
|
|
15
14
|
<section>
|
16
|
-
<h4>
|
17
|
-
<
|
18
|
-
<fieldset>
|
19
|
-
<p>
|
20
|
-
<label>Language</label>
|
21
|
-
<select name="locale">
|
22
|
-
<option></option>
|
23
|
-
<option value="id">Indonesian</option>
|
24
|
-
<option value="en">English</option>
|
25
|
-
</select>
|
26
|
-
</p>
|
27
|
-
|
28
|
-
<div class="form-row">
|
29
|
-
<label>Payment Types</label>
|
30
|
-
<ul>
|
31
|
-
<% @payment_types = %w{CREDIT_CARD MANDIRI_CLICKPAY MANDIRI_BILL CIMB_CLICKS INDOMARET BANK_TRANSFER MANDIRI_BILL} %>
|
32
|
-
<% for type in @payment_types %>
|
33
|
-
<li>
|
34
|
-
<label>
|
35
|
-
<input type="checkbox" name="enabled_payments[]" value="<%= type %>">
|
36
|
-
<%= type.split("_").map(&:capitalize).join(' ') %>
|
37
|
-
</label>
|
38
|
-
</li>
|
39
|
-
<% end %>
|
40
|
-
</ul>
|
41
|
-
<br/>
|
42
|
-
<small class="types-hint">By default Veritrans will show all available types</small>
|
43
|
-
</div>
|
44
|
-
|
45
|
-
<p>
|
46
|
-
<label>Credit Card BIN promo</label>
|
47
|
-
<input type="text" name="bin_promo" placeholder="411111, 500000, bni, mandiri, 3111">
|
48
|
-
<br/>
|
49
|
-
<small class="bins-hint">
|
50
|
-
<a href="https://api-docs.midtrans.com/#card-features-bin-promo">See documentation</a>
|
51
|
-
</small>
|
52
|
-
</p>
|
53
|
-
|
54
|
-
<p>
|
55
|
-
<label>Credit Card 3D Secure</label>
|
56
|
-
<select name="credit_card_3d_secure">
|
57
|
-
<option></option>
|
58
|
-
<option value="true">Yes</option>
|
59
|
-
<option value="false">No</option>
|
60
|
-
</select>
|
61
|
-
</p>
|
62
|
-
|
63
|
-
<div class="form-row">
|
64
|
-
<label>Credit Card Installment</label>
|
65
|
-
<ul>
|
66
|
-
<li>
|
67
|
-
<label><input type="checkbox" name="installment[bni]">BNI</label>
|
68
|
-
</li>
|
69
|
-
<li>
|
70
|
-
<label><input type="checkbox" name="installment[mandiri]">Mandiri</label>
|
71
|
-
</li>
|
72
|
-
<li>
|
73
|
-
<label><input type="checkbox" name="installment[bca]">BCA</label>
|
74
|
-
</li>
|
75
|
-
</ul>
|
76
|
-
</div>
|
77
|
-
|
78
|
-
</fieldset>
|
79
|
-
|
80
|
-
<p>
|
81
|
-
<input type="submit" value="Create payment page">
|
82
|
-
<p>
|
83
|
-
</form>
|
15
|
+
<h4>Snap Popup</h4>
|
16
|
+
<a href="/snap">Click here</a>
|
84
17
|
</section>
|
85
18
|
|
86
19
|
<section>
|
87
|
-
<h4>
|
88
|
-
|
89
|
-
<form action="/charge_vtdirect" method="post" id="card_form">
|
90
|
-
<input type="hidden" name="token_id" id="card_token">
|
91
|
-
<fieldset>
|
92
|
-
<legend>Credit card</legend>
|
93
|
-
<p>
|
94
|
-
<label for="gross_amount">Amount, Rp.</label>
|
95
|
-
<input type="text" name="gross_amount" id="gross_amount" value="30000">
|
96
|
-
</p>
|
97
|
-
<p>
|
98
|
-
<label for="card_number">Card number</label>
|
99
|
-
<input type="text" id="card_number" style="width: 150px" value="4811 1111 1111 1114">
|
100
|
-
<br>
|
101
|
-
<small style="margin-left: 100px" class="card-numbers">
|
102
|
-
<a onclick="$('#card_number').val('4811 1111 1111 1114')">success Visa</a>
|
103
|
-
<a onclick="$('#card_number').val('5810 1111 1111 1112')">success MasterCard</a>
|
104
|
-
<a onclick="$('#card_number').val('4511 1111 1111 1117')">challenge</a>
|
105
|
-
<a onclick="$('#card_number').val('4611 1111 1111 1116')">Deny by FDS</a>
|
106
|
-
<a onclick="$('#card_number').val('4911 1111 1111 1113')">Deny by bank</a>
|
107
|
-
<a href="https://docs.midtrans.com/en/reference/test.html" target="_blank">documentation</a>
|
108
|
-
</small>
|
109
|
-
</p>
|
110
|
-
<p>
|
111
|
-
<label for="card_cvc">Security Code</label>
|
112
|
-
<input type="text" id="card_cvc" style="width: 30px" placeholder="cvc" value="123">
|
113
|
-
</p>
|
114
|
-
<p>
|
115
|
-
<label for="card_exp">Expiration date</label>
|
116
|
-
<input type="text" id="card_exp" placeholder="MM / YY" value="12 / 18">
|
117
|
-
</p>
|
118
|
-
|
119
|
-
<p>
|
120
|
-
<label for="card_secure">3D-secure</label>
|
121
|
-
<input type="checkbox" id="card_secure">
|
122
|
-
</p>
|
123
|
-
|
124
|
-
</fieldset>
|
125
|
-
|
126
|
-
<input id="submit_btn" type="submit">
|
127
|
-
</form>
|
20
|
+
<h4>Snap Redirect</h4>
|
21
|
+
<a href="/snap_redirect">Click here</a>
|
128
22
|
</section>
|
23
|
+
<br>
|
24
|
+
<h3>Core API Credit Card</h3>
|
25
|
+
<script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/picomodal/3.0.0/picoModal.js"></script>
|
26
|
+
|
27
|
+
<h1>Checkout</h1>
|
28
|
+
<form action="/coreapi_card_charge_ajax_handler" method="POST" id="payment-form">
|
29
|
+
<fieldset>
|
30
|
+
<legend>Checkout</legend>
|
31
|
+
<small><strong>Field that may be presented to customer:</strong></small>
|
32
|
+
<p>
|
33
|
+
<label>Card Number</label>
|
34
|
+
<input class="card-number" value="4811 1111 1111 1114" size="23" type="text" autocomplete="off" />
|
35
|
+
</p>
|
36
|
+
<p>
|
37
|
+
<label>Expiration (MM/YYYY)</label>
|
38
|
+
<input class="card-expiry-month" value="12" placeholder="MM" size="2" type="text" />
|
39
|
+
<span> / </span>
|
40
|
+
<input class="card-expiry-year" value="2025" placeholder="YYYY" size="4" type="text" />
|
41
|
+
</p>
|
42
|
+
<p>
|
43
|
+
<label>CVV</label>
|
44
|
+
<input class="card-cvv" value="123" size="4" type="password" autocomplete="off" />
|
45
|
+
</p>
|
129
46
|
|
130
|
-
<
|
131
|
-
|
132
|
-
|
133
|
-
|
134
|
-
</
|
135
|
-
|
136
|
-
<
|
137
|
-
|
138
|
-
|
139
|
-
</
|
140
|
-
|
141
|
-
<
|
142
|
-
<
|
143
|
-
<
|
144
|
-
|
145
|
-
|
146
|
-
<
|
147
|
-
<
|
148
|
-
|
149
|
-
|
150
|
-
|
151
|
-
|
152
|
-
|
153
|
-
|
154
|
-
|
155
|
-
|
156
|
-
|
47
|
+
<small><strong>Fields that shouldn't be presented to the customer:</strong></small>
|
48
|
+
<p>
|
49
|
+
<label>3D Secure</label>
|
50
|
+
<input class="authenticate_3ds" type="checkbox" name="authenticate_3ds" value="true" checked>
|
51
|
+
</p>
|
52
|
+
|
53
|
+
<input id="token_id" name="token_id" type="hidden" />
|
54
|
+
<button class="submit-button" type="submit">Submit Payment</button>
|
55
|
+
</fieldset>
|
56
|
+
</form>
|
57
|
+
|
58
|
+
<code>
|
59
|
+
<b>Transaction Result:</b>
|
60
|
+
<pre id="result"> Awaiting transactions... </pre>
|
61
|
+
<b>Transaction verified status result:</b>
|
62
|
+
<pre id="status-result"> Awaiting transactions... </pre>
|
63
|
+
<pre>
|
64
|
+
<b>Testing cards:</b>
|
65
|
+
|
66
|
+
<b>For 3D Secure:</b>
|
67
|
+
Visa success 4811 1111 1111 1114
|
68
|
+
Visa deny by bank 4711 1111 1111 1115
|
69
|
+
Visa deny by FDS 4611 1111 1111 1116
|
70
|
+
|
71
|
+
MasterCard success 5211 1111 1111 1117
|
72
|
+
MasterCard deny by bank 5111 1111 1111 1118
|
73
|
+
MasterCard deny by FDS 5411 1111 1111 1115
|
74
|
+
|
75
|
+
Challenge by FDS 4511 1111 1111 1117
|
76
|
+
</pre>
|
77
|
+
</code>
|
78
|
+
|
79
|
+
<!-- Import MidtransNew3ds library -->
|
80
|
+
<!-- TODO change data-environment to `production` for Production mode -->
|
81
|
+
<!-- TODO change data-client-key to your production client key for Production mode -->
|
82
|
+
<script id= "midtrans-script" src="https://api.midtrans.com/v2/assets/js/midtrans-new-3ds.min.js" data-environment="sandbox" data-client-key=<%= Midtrans.config.client_key %> type="text/javascript"></script>
|
83
|
+
|
84
|
+
<!-- Javascript for token generation -->
|
157
85
|
<script type="text/javascript">
|
158
|
-
|
159
|
-
|
160
|
-
|
161
|
-
|
162
|
-
|
163
|
-
|
164
|
-
|
165
|
-
|
166
|
-
|
167
|
-
|
168
|
-
|
169
|
-
|
170
|
-
|
171
|
-
|
172
|
-
gross_amount: $('#gross_amount').val(),
|
173
|
-
secure: $('#card_secure')[0].checked
|
86
|
+
// On Submit button clicked
|
87
|
+
document.querySelector(".submit-button").onclick = function (event) {
|
88
|
+
console.log("SUBMIT button clicked");
|
89
|
+
// prepare cardData
|
90
|
+
var cardData = {
|
91
|
+
"card_number": document.querySelector(".card-number").value,
|
92
|
+
"card_exp_month": document.querySelector(".card-expiry-month").value,
|
93
|
+
"card_exp_year": document.querySelector(".card-expiry-year").value,
|
94
|
+
"card_cvv": document.querySelector(".card-cvv").value,
|
95
|
+
};
|
96
|
+
// [1] Use card data to get card token on the callback
|
97
|
+
MidtransNew3ds.getCardToken(cardData, getCardTokenCallback);
|
98
|
+
|
99
|
+
event.preventDefault(); return false;
|
174
100
|
};
|
175
|
-
|
176
|
-
|
177
|
-
|
178
|
-
|
179
|
-
|
180
|
-
|
181
|
-
|
182
|
-
|
183
|
-
|
184
|
-
|
185
|
-
|
186
|
-
|
187
|
-
|
188
|
-
|
189
|
-
|
190
|
-
|
191
|
-
|
192
|
-
|
193
|
-
|
194
|
-
|
195
|
-
|
196
|
-
|
197
|
-
|
198
|
-
|
199
|
-
|
200
|
-
|
201
|
-
|
202
|
-
|
203
|
-
|
204
|
-
}
|
205
|
-
|
206
|
-
|
101
|
+
|
102
|
+
// getCardTokenCallback triggered when `MidtransNew3ds.getCardToken` completed.
|
103
|
+
var getCardTokenCallback = {
|
104
|
+
onSuccess: function(response){
|
105
|
+
// success to get card token
|
106
|
+
// [2] Send AJAX to let backend charge the card using the card token_id
|
107
|
+
fetch("/coreapi_card_charge_ajax_handler", {
|
108
|
+
method : "POST",
|
109
|
+
body: JSON.stringify({
|
110
|
+
"token_id" : response.token_id,
|
111
|
+
"authenticate_3ds" : document.querySelector('.authenticate_3ds').checked
|
112
|
+
}),
|
113
|
+
headers: {'Content-Type': 'application/json'},
|
114
|
+
})
|
115
|
+
.then(function(response) { return response.json(); })
|
116
|
+
.then(function(responseObj) {
|
117
|
+
console.log("Charge response:",responseObj);
|
118
|
+
if (responseObj.status_code == "201"){
|
119
|
+
// [3.1] Transaction need 3DS authentication
|
120
|
+
MidtransNew3ds.authenticate(responseObj.redirect_url, callback3dsAuthentication);
|
121
|
+
} else {
|
122
|
+
// Transaction do not need 3DS Authentication, transaction is complete with result
|
123
|
+
transactionComplete(responseObj);
|
124
|
+
}
|
125
|
+
})
|
126
|
+
},
|
127
|
+
onFailure: function(response){
|
128
|
+
// fail to get card token
|
129
|
+
transactionComplete(response);
|
130
|
+
}
|
131
|
+
}
|
132
|
+
|
133
|
+
var callback3dsAuthentication = {
|
134
|
+
performAuthentication: function(redirect_url){
|
135
|
+
// [3.2] 3ds authentication redirect_url received, open iframe to display to customer
|
136
|
+
popupModal.openPopup(redirect_url);
|
137
|
+
},
|
138
|
+
// [3.3] When 3DS authentication result received, which contains transaction result
|
139
|
+
// it will trigger one of function below, according to status: success/failure/pending
|
140
|
+
onSuccess: function(response){
|
141
|
+
transactionComplete(response);
|
142
|
+
},
|
143
|
+
onFailure: function(response){
|
144
|
+
transactionComplete(response);
|
145
|
+
},
|
146
|
+
onPending: function(response){
|
147
|
+
transactionComplete(response);
|
148
|
+
|
149
|
+
}
|
150
|
+
}
|
151
|
+
|
152
|
+
function transactionComplete(responseObj){
|
153
|
+
// Close 3DS popup, then display the result (for example)
|
154
|
+
console.log("transactionComplete with status: ",responseObj);
|
155
|
+
popupModal.closePopup();
|
156
|
+
|
157
|
+
document.querySelector("#result").innerText = JSON.stringify(responseObj, null, 2);
|
158
|
+
document.querySelector("#result").scrollIntoView();
|
159
|
+
|
160
|
+
if (responseObj.transaction_id){
|
161
|
+
// [4] Inform the result to backend update DB status and verify to Midtrans
|
162
|
+
fetch('/check_transaction_status', {
|
163
|
+
method : "POST",
|
164
|
+
body: JSON.stringify({ "transaction_id" : responseObj.transaction_id }),
|
165
|
+
headers: {'Content-Type': 'application/json'},
|
166
|
+
})
|
167
|
+
.then(function(statusResponse) { return statusResponse.json(); } )
|
168
|
+
.then(function(statusResponseObj) {
|
169
|
+
// Transaction status received after being verified
|
170
|
+
console.log("Check transaction response:",statusResponseObj);
|
171
|
+
// transactionComplete(statusResponseObj);
|
172
|
+
document.querySelector("#status-result").innerText =
|
173
|
+
JSON.stringify(statusResponseObj, null, 2);
|
174
|
+
|
175
|
+
})
|
176
|
+
}
|
177
|
+
}
|
178
|
+
|
179
|
+
// helper functions below
|
180
|
+
let popupModal = (function(){
|
181
|
+
let modal = null;
|
182
|
+
return {
|
183
|
+
openPopup(url){
|
184
|
+
modal = picoModal({
|
185
|
+
content:'<iframe frameborder="0" style="height:90vh; width:100%;" src="'+url+'"></iframe>',
|
186
|
+
width: "75%",
|
187
|
+
closeButton: false,
|
188
|
+
overlayClose: false,
|
189
|
+
escCloses: false
|
190
|
+
}).show();
|
191
|
+
},
|
192
|
+
closePopup(){
|
193
|
+
try{
|
194
|
+
modal.close();
|
195
|
+
} catch(e) {}
|
196
|
+
}
|
207
197
|
}
|
208
|
-
|
209
|
-
});
|
210
|
-
});
|
198
|
+
}());
|
211
199
|
</script>
|
212
200
|
|
213
201
|
</body>
|
214
|
-
</html>
|
202
|
+
</html>
|
@@ -1,40 +1 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
<header>
|
4
|
-
<h3>
|
5
|
-
<a href="/">Midtrans sinatra app</a>
|
6
|
-
</h3>
|
7
|
-
<a href="https://github.com/veritrans/veritrans-ruby" class="github">Source Code</a>
|
8
|
-
</header>
|
9
|
-
|
10
|
-
<% if @result.redirect_url %>
|
11
|
-
<section>
|
12
|
-
<p>Here's redirect url <a href='<%= @vtweb_url %>'><%= @vtweb_url %></a> </p>
|
13
|
-
</section>
|
14
|
-
<% end %>
|
15
|
-
|
16
|
-
<section>
|
17
|
-
<strong>
|
18
|
-
Veritrans response:
|
19
|
-
<% if @result.success? %>
|
20
|
-
<span style="color: green">success</span>
|
21
|
-
<% end %>
|
22
|
-
</strong>
|
23
|
-
|
24
|
-
<code>
|
25
|
-
<pre>
|
26
|
-
<%= JSON.pretty_generate(JSON.parse(@result.response.body)) %>
|
27
|
-
</pre>
|
28
|
-
</code>
|
29
|
-
|
30
|
-
<% if @cahrge_params %>
|
31
|
-
<strong>Request Body</strong>
|
32
|
-
<code>
|
33
|
-
<pre>
|
34
|
-
<%= JSON.pretty_generate(@cahrge_params) %>
|
35
|
-
</pre>
|
36
|
-
</code>
|
37
|
-
<% end %>
|
38
|
-
|
39
|
-
<a href="/">Go back</a>
|
40
|
-
</section>
|
1
|
+
<%= @result.response.body %>
|
@@ -0,0 +1,33 @@
|
|
1
|
+
<!doctype html>
|
2
|
+
<html>
|
3
|
+
|
4
|
+
<body>
|
5
|
+
<p>
|
6
|
+
<label>Snap Token</label>
|
7
|
+
<input type="text" id="token" value="<%= @token %>" readonly size="50">
|
8
|
+
</p>
|
9
|
+
<button id="pay-button">Pay</button>
|
10
|
+
<pre><div id="result-json">JSON result will appear here after payment:<br></div></pre>
|
11
|
+
|
12
|
+
<!-- TODO: Remove ".sandbox" from script src URL for production environment. Also input your client key in "data-client-key" -->
|
13
|
+
<script src="https://app.sandbox.midtrans.com/snap/snap.js" data-client-key=<%= Midtrans.config.client_key %>></script>
|
14
|
+
<script type="text/javascript">
|
15
|
+
document.getElementById('pay-button').onclick = function(){
|
16
|
+
// SnapToken acquired from previous step
|
17
|
+
snap.pay('<%= @token %>', {
|
18
|
+
// Optional
|
19
|
+
onSuccess: function(result){
|
20
|
+
/* You may add your own js here, this is just example */ document.getElementById('result-json').innerHTML += JSON.stringify(result, null, 2);
|
21
|
+
},
|
22
|
+
// Optional
|
23
|
+
onPending: function(result){
|
24
|
+
/* You may add your own js here, this is just example */ document.getElementById('result-json').innerHTML += JSON.stringify(result, null, 2);
|
25
|
+
},
|
26
|
+
// Optional
|
27
|
+
onError: function(result){
|
28
|
+
/* You may add your own js here, this is just example */ document.getElementById('result-json').innerHTML += JSON.stringify(result, null, 2);
|
29
|
+
}
|
30
|
+
});
|
31
|
+
};
|
32
|
+
</script>
|
33
|
+
</body>
|
@@ -0,0 +1,10 @@
|
|
1
|
+
<!doctype html>
|
2
|
+
<html>
|
3
|
+
|
4
|
+
<body>
|
5
|
+
<p>
|
6
|
+
<label>Snap Redirect URL</label>
|
7
|
+
<input type="text" id="Redirect URL" value="<%= @redirecturl %>" readonly size="50"><br><br>
|
8
|
+
<button onclick="location.href='<%= @redirecturl %>'">Open Snap Redirect URL</button></p>
|
9
|
+
</body>
|
10
|
+
</html>
|