Simple Merchant Server Implementation Reference for Mobile SDK (Python version).
This is a example mobile SDK server for Midtrans's iOS and Android SDK, as an implementation reference to use the mobile sdk. Please read more in Documentation of Midtrans mobile SDK.
The main idea why this server implementation needed is: To securely add HTTP Authorization Header from server side. This auth header is generated from server key (from your Midtrans account), this server key is secret, and should only be kept in server side, not client side (mobile app can be easily reverse engineered to extract any secret).
Additionally, it allows you to tweak JSON request parameter as needed from server side.
You need these to run the app:
$ pip install -r requirements.txt
$ export FLASK_ENV=development
$ python app.py / flask run
There is only one endpoint that are required to use Midtrans mobile SDK:
POST /charge
This endpoint will proxy (forward) client request to Midtrans Snap API 'https://app.midtrans.com/snap/v1/transactions'
(or 'https://app.sandbox.midtrans.com/snap/v1/transactions'
for sandbox) with HTTP Authorization Header generated based on your Midtrans Server Key
.
The response of API will be printed/returned to client as is. Example response that will be printed
{
"token": "413ae932-471d-4c41-bfb4-e558cc271dcc",
"redirect_url": "https://app.sandbox.midtrans.com/snap/v2/vtweb/413ae932-471d-4c41-bfb4-e558cc271dcc"
}
Edit file config.yml
, insert your Midtrans Account Server Key to sandbox_server_key
and production_server_key
.
Set is_production
to True
when you use env production.
Set <url where you host this>/charge
as merchant base url
in mobile SDK. (refer to Midtrans mobile SDK doc)
You can mock client's request by executing this CURL command to the /charge
endpoint:
curl -X POST \
http://<your url>/charge \
-H 'Accept: application/json' \
-H 'Content-Type: application/json' \
-d '{
"transaction_details": {
"order_id": "mobile-12345",
"gross_amount": 280000
},
"item_details": [
{
"id": "A01",
"price": 280000,
"quantity": 1,
"name": "Mie Ayam Komplit"
}
],
"customer_details": [
{
"email": "tester@example.com",
"first_name": "Budi",
"last_name": "Khannedy",
"phone": "628112341234"
}
]
}'
Note: dont forget to change "http://<your url>/charge"
to your url where you hosted the /charge
.
You can also import that curl command to Postman.
This is just for very basic implementation reference, in production, you should implement your backend more securely.
For sample reference please refer to this example as it has a different specification.
- Midtrans
- Midtrans registration
- Midtrans documentation
- Can't find answer you looking for? email to support@midtrans.com