From 1745915fc00f3b2bf0720087afbb97415ab2ad92 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EA=A6=8C=EA=A6=AB=EA=A6=B6=EA=A6=8F=EA=A7=80=EA=A6=A6?= =?UTF-8?q?=EA=A6=BF=EA=A6=A7=EA=A6=AE=EA=A6=91=EA=A6=A9=EA=A6=AD=EA=A7=80?= Date: Thu, 3 Nov 2022 17:59:20 +0800 Subject: Reorder status function/method --- midtrans.c | 56 ++++++++++++++++++++++++++++---------------------------- midtrans.dart | 18 +++++++++--------- midtrans.h | 2 +- 3 files changed, 38 insertions(+), 38 deletions(-) diff --git a/midtrans.c b/midtrans.c index a188bd7..bd05fc2 100644 --- a/midtrans.c +++ b/midtrans.c @@ -81,34 +81,6 @@ void midtrans_init(const char *api_key, char *pem) })); } -char *midtrans_status(const char *order_id) -{ - static const char *tmpl = "%s%s/status"; - char url[strlen(tmpl) - strlen("%s") * 2 + strlen(base_url) - + strlen(order_id) + 1]; - sprintf(url, tmpl, base_url, order_id); - curl_easy_setopt(curl, CURLOPT_URL, url); - - struct response res = { 0, NULL }; - curl_easy_setopt(curl, CURLOPT_WRITEDATA, &res); - curl_easy_perform(curl); - - json_tokener *tokener = json_tokener_new(); - json_object *object = json_tokener_parse_ex(tokener, res.data, - res.size); - free(res.data); - - json_object *transaction_status = NULL; - json_object_object_get_ex(object, "transaction_status", - &transaction_status); - const char *string = json_object_get_string(transaction_status); - char *status = malloc(strlen(string) + 1); - strcpy(status, string); - json_tokener_free(tokener); - - return status; -} - struct midtrans_banktransfer midtrans_banktransfer_new(char *bank) { return (struct midtrans_banktransfer){ bank, NULL, NULL, NULL }; @@ -213,6 +185,34 @@ char *midtrans_charge_banktransfer(struct midtrans_banktransfer banktransfer, return virtualaccount_number; } +char *midtrans_status(const char *order_id) +{ + static const char *tmpl = "%s%s/status"; + char url[strlen(tmpl) - strlen("%s") * 2 + strlen(base_url) + + strlen(order_id) + 1]; + sprintf(url, tmpl, base_url, order_id); + curl_easy_setopt(curl, CURLOPT_URL, url); + + struct response res = { 0, NULL }; + curl_easy_setopt(curl, CURLOPT_WRITEDATA, &res); + curl_easy_perform(curl); + + json_tokener *tokener = json_tokener_new(); + json_object *object = json_tokener_parse_ex(tokener, res.data, + res.size); + free(res.data); + + json_object *transaction_status = NULL; + json_object_object_get_ex(object, "transaction_status", + &transaction_status); + const char *string = json_object_get_string(transaction_status); + char *status = malloc(strlen(string) + 1); + strcpy(status, string); + json_tokener_free(tokener); + + return status; +} + void midtrans_cleanup() { free(base_url); diff --git a/midtrans.dart b/midtrans.dart index 8779153..b61b591 100644 --- a/midtrans.dart +++ b/midtrans.dart @@ -36,15 +36,6 @@ class Midtrans { calloc.free(pemUtf8); } - String status(String orderID) { - final order_id = orderID.toNativeUtf8(); - final status = dylib.lookupFunction - - ('midtrans_status')(order_id).toDartString(); - calloc.free(order_id); - return status; - } - String chargeBanktransfer(String bank, String orderID, int grossAmount) { final bankUtf8 = bank.toNativeUtf8(); @@ -65,6 +56,15 @@ class Midtrans { return vaNumber; } + String status(String orderID) { + final order_id = orderID.toNativeUtf8(); + final status = dylib.lookupFunction + + ('midtrans_status')(order_id).toDartString(); + calloc.free(order_id); + return status; + } + void cleanup() { dylib.lookupFunction ('midtrans_cleanup')(); diff --git a/midtrans.h b/midtrans.h index f62b520..2d28e36 100644 --- a/midtrans.h +++ b/midtrans.h @@ -23,13 +23,13 @@ extern "C" { #endif void midtrans_init(const char *api_key, char *pem); -char *midtrans_status(const char *order_id); struct midtrans_banktransfer midtrans_banktransfer_new(char *bank); struct midtrans_transaction midtrans_transaction_new(char *order_id, long gross_amount); char *midtrans_charge_banktransfer(struct midtrans_banktransfer banktransfer, struct midtrans_transaction transaction /*, char *custom_fields[]*/); +char *midtrans_status(const char *order_id); void midtrans_cleanup(); #ifdef __cplusplus -- cgit v1.2.3