Skip to content

Latest commit

 

History

History
executable file
·
668 lines (441 loc) · 46.7 KB

File metadata and controls

executable file
·
668 lines (441 loc) · 46.7 KB

Integrate Midtrans Snap to 3rd Party Ecommerce Platform


Midtrans Snap can be integrated with third party E-commerce platform or SaaS like Shopify, Sirclo, and Jejualan.

Midtrans is partnered with various platforms to make integration process as easy as possible. This page contains a list of platforms that have partnered with Midtrans. If you are using third party platforms that are not listed here, and would like for Midtrans to integrate with it, please contact us.

Step by step guide to integrate Snap to the platform of your choice, is explained below.

Choose from any platform of your choice:





Shopify

Please complete the pre-requisite below:

  1. Create an online store with Shopify if you haven't.
  2. Register for Midtrans account.
  3. Complete the account registration form. For any help, you can contact Midtrans contact center.

Note:

  • You can try with Shopify Trial plan to test payment integration in Sandbox mode.
  • You may be required by Shopify to have an active paid-plan in order to allow your customer to do checkout on Production mode.

Integrating Midtrans to Shopify Platform

Depending on each situation, please follow one which best fits your situation:

First Time Integration

  1. Login to Midtrans Merchant Administration Portal.

    You will find your online shop name with Sandbox/Production environment. Please make sure that you are in Production environment.

    Login MAP

  2. Select Settings->Configuration.

    Some payment methods such as UOB EZ Pay and Kredivo require a Finish Redirect URL, to be used as a final redirect page, after the customer has completed the payment. If you have activated the payment methods above, you can configure the Finish Redirect URL through the menu Settings > Configuration. Please fill the Finish Redirect URL with your Shopify URL website, then click Update Button.

    Set Finish URL

  3. Select Settings -> Access Keys.

    Copy Midtrans Merchant ID and Server Key (Will be used for the next step).

    you also need Midtrans Merchant ID and Server Key from sandbox environment, please change the environment mode to sandbox, and access the same menu to get Midtrans Merchant ID and Server Key

    access key

  4. Login to your Shopify Store.

  5. Follow this link to find Payments via Midtrans App on Shopify App Store.

    shopify app store

  6. Click Add app button to install.

  7. You will be redirected to installation page, you can review the displayed information, then click Install app Install Midtrans

  8. You will be redirected to the Onboarding page, please fill in your Midtrans Merchant ID and Server Key (from step 2) for each production and sandbox. Then click Register. Register

  9. You will be redirected back to Shopify, and the page will indicates that your Shopify store is connected to Payments via Midtrans. Connected to Midtrans

  10. To activate, click Activate Payments via Midtrans. You can also tick/untick desired payment method icons that will be shown in the payment button on your checkout page.

  11. Done! Now your Shopify online shop is ready to start accepting payments with Midtrans as payment gateway. Your customer will see Payments via Midtrans as payment method on the checkout page. Midtrans show in checkout page

shopify

With this integration, your customer will be redirected to Snap Redirect payment page if they choose Payments via Midtrans on your store. Customer payment data is safely managed by Midtrans hosted payment web page, outside of your Shopify store web domain.

All supported Payment methods that are available on Snap product, are explained here.

Migrating from Previous Payment App Version

?> As announced by Shopify, Shopify planned to deprecate the previous payment integration platform (Hosted Payment SDK) by August 14th 2022 (extended from previously July 31st). Shopify has urged Midtrans (and other payment gateways) to migrate to their new Payment Platform integration. In compliance with it, Midtrans has migrated to the new platform. As a result, you as a Midtrans’ merchants will need to migrate by installing "Payments via Midtrans App" for Shopify. The app will have improved performance, reliability, & security.

If by August 14th 2022 (extended from previously July 31st) you have not done so, Midtrans payment integration (installed using the previous platform) may no longer work for your Shopify store.

Due to the changes introduced by Shopify’s new payment platform, there are some changes and limitations (compared to previous integration version) that should be expected. Visit Known Limitations under Advanced section to see the details.

There will be two parts:

  1. Install New Midtrans Payment App
  2. Uninstall Old Midtrans Payment App

Install New Midtrans Payment App

During the transition period, move from Old Midtrans App to New Midtrans App, you can install New Midtrans App before uninstalling the Old Midtrans App. You can install and test the New Midtrans App to ensure it will work. Once you have install the new App, Shopify recommends uninstalling the Old Midtrans App to ensure smooth transition.

  1. Login to Midtrans Merchant Administration Portal.

    You will find your online shop name with Sandbox/Production environment. Please make sure that you are in Production environment.

    Login MAP

  2. Select Settings->Configuration.

    Some payment methods such as UOB EZ Pay and Kredivo require a Finish Redirect URL, to be used as a final redirect page, after the customer has completed the payment. If you have activated the payment methods above, you can configure the Finish Redirect URL through the menu Settings > Configuration. Please fill the Finish Redirect URL with your Shopify URL website, then click Update Button.

    Set Finish URL

  3. Select Settings -> Access Keys.

    Copy Midtrans Merchant ID and Server Key (Will be used for the next step).

    you also need Midtrans Merchant ID and Server Key from sandbox environment, please change the environment mode to sandbox, and access the same menu to get Midtrans Merchant ID and Server Key

    access key

  4. Login to your Shopify Store.

  5. Follow this link to find Payments via Midtrans App on Shopify App Store.

    shopify app store

  6. Click Add app button to install.

  7. You will be redirected to installation page, you can review the displayed information, then click Install app Install Midtrans

  8. You will be redirected to the Onboarding page, please fill in your Midtrans Merchant ID and Server Key (from step 2) for each production and sandbox. Then click Register. Register

  9. You will be redirected back to Shopify, and the page will indicates that your Shopify store is connected to Payments via Midtrans. Connected to Midtrans

  10. To activate, click Activate Payments via Midtrans. You can also tick/untick desired payment method icons that will be shown in the payment button on your checkout page.

  11. Done! Now your Shopify online shop is ready to start accepting payments with Midtrans as payment gateway. Your customer will see Payments via Midtrans as payment method on the checkout page. Midtrans show in checkout page

Uninstall Old Midtrans Payment App

!> Uninstalling the old Payment App is recommended by Sopify to ensure smooth transition. If you still have both old and new app-enabled, we recommend uninstalling the Old Midtrans Payment App on your store. This is also to avoid confusion from the customer side & inconsistent payment status update behavior. So that only the new Midtrans Payment App is available for your customer to choose from.

Once you choose to uninstall the old one, you will not be able to re-install the old one again.

To uninstall the Old Midtrans Payment App(s), you can proceed to follow steps below.

Before uninstalling, it is recommended to:

  • Please ensure that you have successfully installed the New Midtrans App and it works on your Shopify store.
  • Plan to uninstall around the time that has low payment traffic, e.g: 2 AM. To prevent failure, if there are any customer in the middle of checkout/payment session.

Uninstall steps:

  1. Login to your Shopify admin page. Go to menu Settings > Payments.
  2. Click Manage button on payment app that you want to uninstall. Hint:
    • You should uninstall the old ones named Midtrans & Midtrans - ....
    • But don't uninstall Provider Payments via Midtrans the new one.
  3. Then click Deactivate button in the payment app detail view.
  4. You will be redirected back to Payment Menu, and the app will be removed from Payment List and also removed from your list of available payment methods on checkout page.
  5. If you have installed multiple of Midtrans old payment apps, you can repeat the step from no.2.

Test Transaction with Sandbox Mode

Sandbox/Test Mode can be used to create "testing" transactions. All transaction made within this mode is not "real", and does not require "real payment/fund", you can do a test transaction with New Midtrans App, please follow the steps given below.

  1. On your store admin page, navigate to Settings > Payment.
  2. Click Manage button on payment app that you want to enable test mode. Manage app
  3. In the payment app detail page, enable the test mode by ticking the option Enable Test Mode. Manage app
  4. Click Save button.
  5. Create a transaction as a customer, complete the checkout process, and choose Payments via Midtrans as payment options, until redirected to Midtrans payment page.
  6. You will see Midtrans payment page with a mark "TEST" around top right of the screen. Test page
  7. Select payment method and proceed to Pay.
  8. Use Sandbox payment credentials here, based on payment method that you selected.
  9. Follow the guide to complete the payment.
  10. After payment is completed, on your Shopify admin page, visit the order detail page. You will find the timeline history on the order detail page will show Test = True. Test timeline
  11. That indicates the transaction was made on sandbox/test mode.
  12. After the test is finished and you are ready for real transactions (live on Production mode), please disable the test mode by unticking the option on step 3.

Payment App Account Settings

Optionally, you can further manage/edit your Payments via Midtrans App account settings. Although for most-usecase, you are not required to do this.

  1. On your store admin page, navigate to Settings > Payment, then on the listed payment with Midtrans as the provider, click Manage.

  2. In the displayed Payments via Midtrans page, click Manage. Manage

  3. You will be redirected to the Midtrans account settings, you can update Midtrans Merchant ID, enable specific payment methods, and activate online offline installment.

General Settings

On this section, you can update Midtrans Merchant ID and enable specific payment methods General Settings

  1. Sample if you only enable credit card payment method Enable Payment Method
    Snap UI

  2. Sample if you enable credit card, gopay, and bank transfer payment methods Enable Payment Method
    Snap UI

Card Installment Settings

On this section, you can activate Online or Offline Installment for card payment method, to activate the installment feature, you are required to have an agreement with the bank. Please contact Midtrans for details. General Settings

Previously on Old Midtrans Payment App, when you install/activate Midtrans Card Installment, it will automatically configured by default. But on the New Midtrans Payment App, you will need to Enable Online Card Installment by ticking the option and clicking the Submit button to save the settings. Online Installment

When customer choose to checkout using Payments via Midtrans, they will see the installment options on the card payment page.

Offline Installment, this feature previously was not supported on Old Midtrans Payment App, to activate the installment feature, you are required to have an agreement with the bank. Please contact Midtrans for details.

You can Enable Offline Card Installment by ticking the option and clicking the Submit button to save the settings. Online Installment


Advanced


Matching Order ID Between Shopify and Midtrans

Order ID created on Midtrans Dashboard for each payment transaction is based from Payment ID auto generated by Shopify platform. It can be different with the Order ID shown on Shopify platform.

?> Note: The Shopify Payment ID is auto generated by Shopify's platform, it does not seems to be possible to customize the ID or the format. Hence, the Order ID created on Midtrans side will also follow this limitation. This is a limitation on Shopify side, you can consult with them should you have any feedback.

To find order on Shopify platform, based on Order ID from Midtrans, first find the transaction Order ID from Midtrans Dashboard on Transactions. shopify

Then there will be multiple methods that you can choose:

From General Search Bar
  1. On your Shopify admin area (administration page)
  2. In the general search bar, search using Midtrans order ID
  3. Click on the shown order.

shopify

From Order Menu, Search Using Custom Term
  1. On your Shopify admin area (administration page), go to Orders.
  2. In the search bar, search using the custom term receipt.payment_id: and the order ID value from Midtrans. For example: receipt.payment_id:order_id_from_midtrans
  3. Click on the shown order.

shopify

From Order Menu, Search Using Midtrans Order ID
  1. On your Shopify admin area (administration page), go to Orders.
  2. In the search bar, search using Midtrans order ID
  3. Click on the shown order.

shopify

Order Detail

From the order details' Timeline you can also review the order status history. You can also click one of them to expand to see more details. You will see the Midtrans order ID under Information from the gateway => Payment. shopify

Using Order Transactions API

You can also retrieve Midtrans Order ID from a Shopify Order via API. Useful if you prefer to do it programatically (to avoid manual 1 by 1 works, or to connect it with your system).

  • You can refer to this Shopify API's Order Transaction
  • You will get list of transaction object as API response, you will find receipt object, and payment_id value. That payment_id is being used on Midtrans as Order ID.

Another quick & easy way to test/try this API:

  1. On your Shopify admin area (administration page), go to Orders.
  2. Click on any of the shown order with paid status.
  3. On your browser URL address bar, you will find the order URL e.g. https://midtrans-store.myshopify.com/admin/orders/4129044234449
  4. On that URL, you can add /transactions.json at the end, e.g: resulting url https://midtrans-store.myshopify.com/admin/orders/4129044234449/transactions.json
  5. Open the new URL on your browser. You will be able to see list of transaction object as API response, you will find receipt object, and payment_id value. That payment_id is being used on Midtrans as Order ID.

shopify

From Exported Order

You can also find the order ID on the exported CSV file using Shopify export feature: Export Orders. Then search Payment ID column within the CSV file

shopify

Customize Shopify Order Confirmation Email Template

When customer is proceeding to check out from your Shopify store into Midtrans Snap payment page, order is "confirmed" on Shopify side, and they will send "order confirmation" email notification to customer.

But you may find the wording of the email is confusing for customer, for example:

Hi John, we're getting your order ready to be shipped. We will notify you when it has been sent.

You may notice that email is being sent before customer completes the payment, so it may not be true that the order is ready for shipping, the order needs to be paid first. Unfortunately that's how the default Shopify "order confirmation notification" behavior works. We can try to customize the message to be less confusing.

Shopify explained how to customize notification on their documentation here. We try to summarize it for you.

  1. Login to your Shopify admin page.
  2. Go to Settings > Notifications.
  3. Click Order Confirmation.
  4. Search for {% capture email_body %} text.
  5. Input or copy this sentence just below/after that text:
If you have completed your payment, then you are done. If you have not completed your payment, please complete it soon to avoid auto-cancelation.<br><br>

You can customize the message to your own preference. Or even modify it as "payment reminder". shopify 6. Click Save. You can also Preview the email. 7. Done. shopify

Additional Notes
Cancel and Refund via Shopify admin panel

Within Shopify admin panel's order details view, there are actions of cancel and refund. When triggering cancel or refund, Midtrans order status will try to sync with the Shopify status, if it met the criteria for payment cancel or refund.

For example:

  • Refunding paid order on Shopify, will also make Midtrans order status to be marked as refund/cancel.

Limitations:

  • Not all payment methods support online refund on Midtrans side, capability is mostly limited to Card & e-money/QRIS transaction.
  • Will only works if your Midtrans account is allowed to trigger online refund.
  • Shopify's refund UI/UX can be a little bit confusing, after clicking refund it may not tell you whether the refund is successful or not. It only shows refund processing which should not be confused as an indication of success. You can follow the refund status from the Shopify Order’s timeline. If it is marked as pending or failure, the refund is not successful.
  • It is more recommended to manage payment refund & cancellation from Midtrans Dashboard instead. As it will have a better indication of refund success and failure.
  • cancel or refund action triggered on Midtrans dashboard/API, may or may not be synced to Shopify due to some limitation.

?> The more accurate payment status is the one shown on Midtrans dashboard. You should refer to it in case there are discrepancies on Shopify's side. Because in some rare case payment status syncing to Shopify's system may fail, and Shopify's order details UI can be confusing to read.

Note on Canceling Order

Canceling a paid order will auto trigger attempt to refund/cancel payment on Payment Gateway (Midtrans) side. That is the flow of Shopify that Merchant and Payment Gateway follows. Please avoid canceling a paid order when you mean to edit/customize the item or size.

As per Shopify docs, cancel order are not supposed to be used to change item/size: https://help.shopify.com/en/manual/orders/refund-cancel-order#cancel-an-order

Merchants supposed to edit order if they need to change the item/size: https://help.shopify.com/en/manual/orders/edit-orders

Or archive the order, if they really need to remove it from order list: https://help.shopify.com/en/manual/orders/manage-orders#archive-a-fulfilled-order

Email Notification of SNAP Validation Error

In the scenario of:

  • Your customer proceeds to payment by selecting card payment method (on Snap payment page), and the card payment ends up as rejected or abandoned.

Then after some times (usually 2 hours):

  • You (Merchant) may receive a few emails from Midtrans with subject "Snap - Validation Error" and message: "Transaction can't be canceled after being paid".

Currently, it is safe to ignore/disregard these emails. This email is unintentionally triggered as part of Midtrans' internal integration with Shopify. It will not cause any issue for you and Customer, which should be safe to ignore.

We do understand that this can become an inconvenience, and our team is working to find a solution.

Retry Payment Email on an Order with Expired Payment

In the scenario of:

  • Your customer proceeds to pay for an order to the point that they are redirected to Midtrans' Snap payment page, but then they don't complete the payment.
  • Then after some time, the payment will be considered as unpaid on Midtrans side. On the Shopify admin panel's order details timeline you can also see it marked with Unable to process a payment for Rp ... IDR on Payments via Midtrans.

Then:

  • By Shopify's default behaviour, your customer will receives an email that informs Your payment couldn’t be processed for order #... You have not been charged. Click below to try paying for the order again.. Which will allow your customer to attempt another payment by clicking the provided Pay now link.

When your customer does that, the payment status for that order will be re-started to pending state again. Which your customer has another chance to proceed with payment.

This is a default Shopify behavior (as of the time of this writing) and is outside of Midtrans control. If you want to know whether this is configurable, please consult Shopify's documentation or contact center.

Multiple Payment IDs for One Shopify Order

It is possible for 1 order (on Shopify admin panel) to have more than 1 payment IDs. This is due to Shopify platform's behavior that allows customers to retry their payments for each order they create. For example, customer is able to retry payment via an email received from Shopify.

The detailed history will be displayed on Shopify admin panel's order details timeline. Each one of those payment IDs (payment attempts) will produces a separate Order ID on Midtrans side aswell.

Here is an example of 1 order that has 1 earlier payment id which is unpaid, and then 1 other payment id which is successfully paid, as observed from Shopify admin panel's order details timeline. Timeline 1 Order 2x Payments

Payment Method Icons on Shopify Payment Setting Page

On the Shopify payment setting page, you will find there are payment method icons. But be advised that the icons selection does not directly affect the actual payment methods activated on Midtrans. Payment icons
The selected icons mainly will be shown on the payment button on the Shopify checkout page. Payment icons
If you want to configure active payment methods on the Snap payment page, you should configure it on Midtrans Shopify Payment App Account Settings.

Shopify will not Charge Third-Party Transaction Fees for Test Order by Enabling Test Mode

For real transaction, when you use a third-party payment provider such as "Midtrans", Shopify will charge transaction fee for each transaction, the transaction fee varies depending on your pricing plan.

But if you want to do "Test Order" by enabling Test Mode, Shopify should not charge you any payment processing fee for "Test Order" payments. Performing "Test Order" is helpful for you to make sure that the checkout process and settings for order processing, payment, inventory, shipping, email notifications, etc are all correct. You can place a "Test Order" by transacting using Test Mode. You can also check Shopify docs about Test Order for further details.

In Some Rare Cases, Midtrans Unable to Update the Payment Status to Shopify

In some rare cases, payment status syncing to Shopify's system may fail. If it happens and affect your order on Shopify, then there are some possibilities of:

  • There are issues on the Shopify side. e.g: Shopify service is unavailable to receive and process Midtrans' API request, you can check the Shopify status page for reported service outages.
  • Your store is locked by Shopify. The store may be locked due to your Shopify account performed API requests which exceeds Shopify API request limit, or if there is an issue with the account, such as fraud risk, use of content/product that infringes on the copyright or trademarks of others, payment failure, etc. Some of the impacts of your store being locked are:
    1. Customers are still able to access your store and do the checkout process, but Midtrans unable to update the payment status, this is because Shopify block/reject API request from Midtrans.
    2. The Store is fully unavailable, customers unable to access your store, and you unable to access the Shopify admin page.

If you are facing this issue, we recommend you to Contact Shopify to get further details then you can request to unlock your store.

Item Stock & Status

Few points to understand about order status & item stock management that is managed automatically with this integration:

  • Item stock will be reduced whenever order status become pending on Shopify side.
  • Item stock will be reduced immediately after the customer reaches Snap payment page, regardless of whether he/she will proceed to actual payment or not. This is to prevent "oversell" issue, by reserving the item stock for the duration of this payment.
    • Example of "oversell" issue prevented by this mechanism: This happens when item stock is 1 left, but there are 2 (or more) customers racing to complete the payment, if both complete the payments, and both are accepted by Shopify, then the item stock will be negative. Which will cause issues on its own. So to prevent this, item stock is reserved (and marked as pending on Shopify side) as early as the customer is redirected to the payment page.
  • Card transaction with deny status will be updated as failed on Shopify by Midtrans after two hours if left without any success attempt. If success pay attempt is found, it will be updated as success on Shopify.
  • Abandoned Snap payment page (customer left without proceeding with any payment method) will be updated as expired on Shopify after two hours. Order may not show up in Midtrans Dashboard.
  • When customer reaches Snap payment page (status pending and stock reduced). Shopify may send email to customer which says "order ready to be shipped", although from Shopify side it is still waiting for payment. Refer to section above about this behavior.
  • It is recommended to avoid manual order status changes (manual intervention) from Shopify Admin Panel at least between period of the order first created as pending and it finally become paid/canceled (about 0-26 hours), in order for payment integration with Midtrans to perform smoothly. Which the order status and item stock will be managed automatically based on the flow explained on this page.
    • Manual order status changes may cause unexpected behaviour in terms of order status & item stock management, such as order status stuck at certain state. Do this at your own risk. Midtrans may not be in position to explain/help-with the consequences.
Basic Status Mapping
Condition Midtrans Status Shopify Payment Status
Customer redirected to Snap payment page. - Payment Pending
Customer proceeds with asynchronous payment
For example: Bank Transfer, Gopay.
Pending Payment Pending
Customer proceeds with asynchronous payment
but does not pay until expiry time reached.[1]
Expire Expired
Customer successfully makes payment. Settlement/Capture Paid
Customer abandoned Snap payment page
without proceeding with payment.
- Expired
Customer abandoned or denied card transaction. Deny Expired
Merchant cancels/refunds order via Shopify. Cancel/Refund Canceled/Refunded

[1] The expiry time calculation starts at the moment when the customer proceeds with the payment method (not necessarily from when redirected to Snap payment page). The payment expiry will then follow what is defined on Snap Preference for each payment method, you can customize the Snap Preference to your needs. When the payment expiry time is reached and the customer does not complete the payment, the transaction will be updated to Expired on Shopify side & Expire on Midtrans side.


Known Limitations

Due to the changes introduced by Shopify’s new payment platform, here are some changes (compared to previous integration version) and limitations that should be expected:

Is auto restock items upon abandoned payment still supported?

For context: In previous integration, if a customer left the Snap payment page without proceeding with any payment method, order will be updated as canceled on Shopify after two hours, and will be restocked.

On this Shopify's new platform (at the time of this writing), unfortunately "auto restock items upon abandoned payment" may not be available. Due to Shopify (or Shopify's new payment platform) default behavior does not seem to re-stock unpaid/payment-canceled order. This is was a design-decision from Shopify, which is outside of Midtrans control.

As alternative, you can cancel the order manually from Shopify admin, to release the stock that previously was allocated for customers.

Further details:

When we reached out to Shopify, they answered:

  • "This is an expected behaviour. Once the order is created, even if the payment is pending (as an example), we will hold the inventory for the merchant. Even if they reject the pending payment, the order still exists and the merchant can decide to get paid with another payment method. So as long as the merchant does not explicitly decide to release the inventory or cancel the order, the inventory is held. ... As some context, with the new system once a pending payment is rejected/expired, the customer is sent an email indicating that their original payment was not processed and provides the option to once again try payment. At the current time, we do not have plans to modify this flow. All this being said, I will be sure to pass on your feedback to our development team for potential future API updates." -- Shopify Team.

Which in short: Shopify allows customer to retry payment to the unpaid order, so the item stock will not be auto re-stocked unless Merchant explicitly do so.

There was another option, but seems to be no longer working due to same reason above:

  • There is also 3rd party apps/extensions that may able to automate such task. For example, Mechanic App seems to be able to do that using this automation task. Note: Informational only, Midtrans is not promoting the use of & not responsible for any external-party products.

Is it possible to perform a refund from Shopify order details page for a card payment transaction?

Yes, with some limitations related to the refund amount.

  • In case the merchant performs a refund from Shopify order details page, when transaction status on Midtrans is still capture, the following will happen depending on the amount:
    • Full-Amount Refund: Midtrans will proceed. Refund intend to return the funds back to the customer, due to Midtrans does not support refund if status transaction is still capture, Midtrans will instead automatically perform cancel/void to transaction (to reverse fund back to customer), status on Shopify will be refunded and status on Midtrans will be cancel.
    • Partial-Amount Refund: Midtrans will reject, and return a message to the merchant's Shopify store: to wait until the transaction has reached settlement status. Then after waiting, the refund can be retried. Midtrans will not cancel the transaction, because currently cancel only supports full amount, & performing cancel will return the full amount of the payment. partial refund
  • In case the refund performed when transaction status on Midtrans is already settlement, both full-amount and partial-amount refunds will be supported.

For context:

  • For refund action, Midtrans support both full-amount and partial-amount. But for cancel action, only full-amount is supported.
  • Midtrans only supports refund if transaction status has reached settlement, but not if the status is capture.
  • Usually settlement time is D+1 at 4 PM, which means that successful card transactions captured today will be settled tomorrow at 4 PM.

Is it possible to have each payment method displayed as a separate payment button on my store’s checkout page?

As Midtrans have to follow Shopify's new payment platform guidelines, unfortunately Shopify discourages this approach. Additionally it will cause some technical complications. So Midtrans no longer able to continue providing this approach.

The above also applies to "card installment payment method as a separate payment button".

Is it possible to add more payment method icons to be displayed on the checkout page?

Shopify's platform seems to have limitation on the number of payment icons displayed for 1 payment button. We are trying to communicate with Shopify about this concern.

For now, you can choose which payment icons should be displayed for "Payments via Midtrans" button from:

  • Shopify admin page, go to menu Settings > Payments, click Manage.

Is it possible to change the text-label of the payment button instead of the generic Payment via Midtrans text?

In Shopify's new payment platform, this doesn’t seem to be possible.

Is there anything Midtrans plan to do about the missing features compared to previous integration?

We do understand your concern that you want to bring the best customer experience to your store, Midtrans indeed also share a similar vision. So we are trying to figure out if we can bring back those or similar features. However please note that Midtrans integration is strictly bound to the limitations & behaviors of Shopify's new payment platform, so most of the time we’ll also need to communicate with Shopify and need their support to improve on the limitations. We’ll update our docs when we have any improvements ready.

Is it possible to have card online installment & offline installment feature activated at the same time?

It is not currently possible to have both features activated, as activating both features may result in unexpected behavior regarding the installment acquirer result. Please choose only one of either feature activated. Please note that you should not enable Offline Installment if you are not exactly sure, as it may result in Customer not being able to pay with their card.

As a Shopify store owner who already integrated with Midtrans using the previous integration method, what am I required to do?

According to Shopify’s mandate, you will be required to integrate using the current/new integration method, please follow the steps given in Migrating from Previous Payment App Version section.

What will happen during the end of the transition period where the old integration method is deactivated? Anything else the store owner is required to do?

The old one will be automatically deactivated from Shopify's platform side. We are further clarifying with the Shopify team, we’ll update the docs once we have further details.

How can I integrate my store with the Midtrans Sandbox Environment?

To integrate your store with the Midtrans Sandbox environment, you need to enable test mode on Payments via Midtrans App, you can follow the step here to enable it.


Deactivating Payments via Midtrans

If you decide to not use Payments via Midtrans, then you can deactivate it. When you deactivate the app, it's removed from your list of available payment methods, but it's still available if you need it for cases such as order returns.

  1. In the Supported payment methods section, find the provider in the list.
  2. Click Manage.
  3. Click Deactivate to disable the provider.
  4. Click Deactivate Payments App.



Sirclo

Please complete the following steps:

  1. Create an online store with Sirclo.
  2. Register to Midtrans account.
  3. Complete the account registration form. For any help, you can contact Midtrans contact center.

Integrating Midtrans to Sirclo Platform:

To integrate Midtrans to Sirclo platform, follow the steps given below.

  1. Login to Midtrans Merchant Administration Portal.

    You will find your online shop name with Sandbox/Production environment. Please make sure that you are in Production environment.

    environment switch

  2. Select Settings->Configuration.

    Setting

URL Role Redirect URL
Payment Notification URL [your-site-url]/payment_ipn/veritrans/notify
Finish Redirect URL [your-site-url]/payment_ipn/veritrans/completed
Error Redirect URL [your-site-url]/payment_ipn/veritrans/error
Unfinish Redirect URL [your-site-url]/payment_ipn/veritrans/unfinish

Note:

Please make sure to input http:// or https:// when filling Notification URL and Redirect URL, according to your web-server configuration.

If you are not sure, try opening your web URL in a browser, and check the URL is http or https on the address bar.

  1. Select Settings->Access Keys.

    Copy Midtrans Merchant ID and Server Key (Will be used for the next step).

    access key

  2. Login to Sirclo Admin Panel of your Sirclo store.

    sirclo

  3. Select Settings->Payment Settings.

    sirclo

    Find Midtrans field, then enter Midtrans Production Merchant ID and Server Key.

    sirclo

  4. Select the checkbox, corresponding to payment method, to enable it.

Note:

You can enable all registered payment methods at Midtrans by clearing all payment methods.

  1. You can select installment payment method by filling installment period in Veritrans Installment period for [Bank Name].

Note for installment:

  • You need to agree and negotiate with the Bank regarding interest rate and installment period.
  • Please contact Midtrans for details.
  1. Click Save or Update.



Jejualan

Please complete the following steps:

  1. Create an online store account with Jejualan, and choose Beta, Gamma, or Delta in order to use Midtrans service.
  2. Register to Midtrans account.
  3. Complete the account registration form. For any help, you can contact Midtrans contact center.

Integrating Midtrans to Jejualan Platform:

To integrate Midtrans to Jejualan platform, follow the steps given below.

  1. Login to Midtrans Merchant Administration Portal.

    You will find your online shop name with Sandbox/Production environment. Please make sure that you are in Production environment.

    Login MAP

  2. Select Settings->Configuration.

    Setting

URL Role Redirect URL
Payment Notification URL [your-site-url]
Finish Redirect URL [your-site-url]/store/payment/veritrans/success
Error Redirect URL [your-site-url]/store/payment/veritrans/failed
Unfinish Redirect URL [your-site-url]/store/payment/

Note:

Please make sure to input http:// or https:// when filling Notification URL and Redirect URL, according to your web-server configuration.

If you are not sure, try opening your web URL in a browser, and check the URL is http or https on the address bar.

  1. Select Settings->Access Keys.

    Copy Midtrans Merchant ID dan Server Key (Will be used for the next step).

    access key

  2. Login to Jejualan Admin Panel of your store

    jejualan

  3. Select Konfigurasi->Pembayaran.

    jejualan

    Click Midtrans field, then change mode from Tidak Aktif to Aktif. Ensure that the button is now colored in blue.

  4. Enter Midtrans Production Server Key. Then select the desired payment method.

    jejualan

You can enable only registered payment methods. For Credit Card, 3D Secure mode is recommended.

  1. Click Simpan.