By integrating with this function, developers can upload bizdata to our GoInsight platform.
Refer to the SetUp
<!-- Add below meta-data to support GoInsight -->
<meta-data android:name="PAXVAS_Insight"
android:value="true"/>
// You have to create dataSet in GoInsight, and each key you uploaded should exists in dataSet.
// You will find how to create dataSet in our GoInsight document.
// Four kinds of value supported, including Text, Number, Date, and Image.
// Image needed to be converted into BASE64-Encoded content and should be smaller than 30Kb.
public void uploadToGoInsight() {
List<Map<String, Object>> list = new ArrayList<>();
for (int i = 0; i < 3; i++) {
Map<String, Object> map = new HashMap<>();
map.put("name", "Demo");
map.put("versionname", "com.pax.demo");
map.put("versionCode", i);
map.put("icon", "");
map.put("tradeTime", System.currentTimeMillis());
list.add(map);
}
try {
SdkObject sdkObject = StoreSdk.getInstance().goInsightApi().syncTerminalBizData(list);
Log.e("GoInsightSample", "message: " + sdkObject.getMessage() + " code: " + sdkObject.getBusinessCode());
} catch (NotInitException e) {
Log.e("MainActivity", "e:" + e);
}
}
}
The search app bizData API allow the third party system search data.
Note: This result of this API depends on the API query settings in GoInsight. Paging needs to be set when the query result set type is a details data.
API
"findTemrinalData" can search only this terminal's BizData, "findMerchantData" can search all BizData belongs to this merchant.
public DataQueryResultObject findTemrinalData(String queryCode)
public DataQueryResultObject findTemrinalData(String queryCode, TimestampRangeType rangeType)
public DataQueryResultObject findTemrinalData(String queryCode, Integer pageNo, Integer pageSize)
public DataQueryResultObject findMerchantData(String queryCode)
public DataQueryResultObject findMerchantData(String queryCode, TimestampRangeType rangeType)
public DataQueryResultObject findMerchantData(String queryCode, Integer pageNo, Integer pageSize)
public DataQueryResultObject findDataFromInsight(String queryCode, TimestampRangeType rangeType, Integer pageNo, Integer pageSize, boolean isMerchantAll)
Input parameter(s) description
Name | Type | Nullable | Description |
---|---|---|---|
queryCode | String | false | search by GoInsight api query code |
rangeType | TimestampRangeType | true | you can choose the range of data results for search |
pageNo | int | true | page number, value must >= 1 |
pageSize | int | true | the record number per page, range is 1 to 100 for details data query, range is 1 to 1000 for statistics data query |
isMerchantAll | boolean | true | search single terminal bizdata or all bizdata belongs to this merchant |
Note: The pageNo param will be ignore when your query result set type is statistics chart.
Value of enum TimestampRangeType
Value | Description |
---|---|
LAST_HOUR | Last Hour |
YESTERDAY | Yesterday |
LAST_WEEK | Last Week |
LAST_MONTH | Last Month |
LAST_QUARTER | Last Quarter |
LAST_YEAR | Last Year |
LAST_YEAR_BY_QUARTER | Last Year (by quarter) |
RECENT_5_MIN | Recent 5 Minute: Past 5m |
RECENT_30_MIN | Recent 30 Minute: Past 30m |
RECENT_HOUR | Recent Hour: Past 1h |
RECENT_3_HOUR | Recent 3 Hour: Past 3h |
RECENT_DAY | Recent Day: Past 24h |
RECENT_2_DAY | Recent 2 Day: Past 48h |
RECENT_5_DAY | Recent 5 Day: Past 120h |
RECENT_WEEK | Recent Week |
RECENT_MONTH | Recent Month |
RECENT_3_MONTH | Recent 3 Month |
RECENT_6_MONTH | Recent 6 Month |
RECENT_YEAR | Recent Year |
RECENT_YEAR_BY_QUARTER | Recent Year (by quarter) |
THIS_HOUR | This Hour |
TODAY | Today |
THIS_WEEK | This Week |
THIS_MONTH | This Month |
THIS_QUARTER | This Quarter |
THIS_QUARTER_BY_WEEK | This Quarter (by week) |
THIS_YEAR | This Year |
THIS_YEAR_BY_QUARTER | This Year (by quarter) |
Sample codes
try {
SdkObject sdkObject = StoreSdk.getInstance().goInsightApi().syncTerminalBizData(list);
} catch (NotInitException e) {
Log.e("MainActivity", "e:" + e);
}
Client side validation failed sample result(JSON formatted)
{
"businessCode": 36000,
"message": ["The query code is not found"]
}
Succssful sample result(JSON formatted)
{
"businessCode": 0,
"data": {
"worksheetName": "Merchant transaction amount trend (This Year)",
"columns": [{
"colName": "acquirer_type",
"displayName": "Acquirer Type"
}, {
"colName": "currency",
"displayName": "Currency"
}, {
"colName": "purchase_id",
"displayName": "Purchase ID"
}, {
"colName": "amount",
"displayName": "Amount"
}, {
"colName": "tax",
"displayName": "Tax"
}, {
"colName": "_sys_marketid",
"displayName": "Marketplace"
}, {
"colName": "_sys_merchantid",
"displayName": "Merchant"
}, {
"colName": "_sys_terminalid",
"displayName": "Terminal"
}],
"rows": [
[{
"colName": "acquirer_type",
"value": "ZTO"
}, {
"colName": "currency",
"value": "USD"
}, {
"colName": "purchase_id",
"value": "15851195134847"
}, {
"colName": "amount",
"value": "169.15"
}, {
"colName": "tax",
"value": "64.38"
}, {
"colName": "_sys_marketid",
"value": "demo"
}, {
"colName": "_sys_merchantid",
"value": "Macy’s"
}, {
"colName": "_sys_terminalid",
"value": "0820087295"
}],
[{
"colName": "acquirer_type",
"value": "ZTO"
}, {
"colName": "currency",
"value": "USD"
}, {
"colName": "purchase_id",
"value": "15851135975100"
}, {
"colName": "amount",
"value": "2990.09"
}, {
"colName": "tax",
"value": "64.12"
}, {
"colName": "_sys_marketid",
"value": "demo"
}, {
"colName": "_sys_merchantid",
"value": "Macy’s"
}, {
"colName": "_sys_terminalid",
"value": "0820087295"
}]
],
"offset": 10,
"limit": 10,
"hasNext": true,
},
"rateLimitRemain": ""
}
The type in dataSet of result is DataQueryResultObject. The structure shows below.
Structure of class TerminalDTO
Property Name | Type | Description |
---|---|---|
worksheetName | String | The result set worksheet name. |
columns | List | The result set column. |
rows | List<List> | The result set. |
hasNext | Boolean | Is there any data. |
offset | int | Rows offset if exit page info. |
limit | int | Rows page size if exit page info. |
Structure of class Column
Property Name | Type | Description |
---|---|---|
colName | String | The dataset filed name in GoInsight |
displayName | String | The dataset filed's display name |
Structure of class Row
Property Name | Type | Description |
---|---|---|
colName | String | The dataset filed name in GoInsight |
value | Object | The dataset filed's value |
Possible client validation errors
Parameter queryCode cannot be null
Parameter queryCode length must is 8
Parameter pageSize must be range is 1 to 1000
Possible business codes
Business Code | Message | Description |
---|---|---|
36000 | The query code is not found | |
36001 | The query code is not active | |
36002 | Query failed, please try again | |
36003 | The query is timeout, please try again | |
36004 | Insufficient permissions | |
36005 | Invalid pageNo | |
36006 | Invalid pageSize | |
36008 | Query failed, please contact administrator | |
36009 | Too many request, please try again later |
Possible abnormal http codes
Http Code | Message | Description |
---|---|---|
429 | Too many request, please try again in one minute, two minutes or whatever |