Skip to content

Latest commit

 

History

History
270 lines (231 loc) · 25.9 KB

GoInsightIntegration.md

File metadata and controls

270 lines (231 loc) · 25.9 KB

PAXSTORE GoInsight Integration

By integrating with this function, developers can upload bizdata to our GoInsight platform.

1:Initialization of Sdk

Refer to the SetUp

2.Add meta-data to AndroidManifest

   <!-- Add below meta-data to support GoInsight -->
   <meta-data android:name="PAXVAS_Insight"
              android:value="true"/>

3.Upload BizData Sample

    // 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);
            }
        }
    }

4. Search APP BizData

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