PAXSTORE 3rd App Android SDK provides simple and easy-to-use service interfaces for third party developers to develop android apps on PAXSTORE. The services currently include the following features:
By using this SDK, developers can easily integrate with PAXSTORE. Please take care of your AppKey and AppSecret that generated by PAXSTORE system when you create an app.
Refer to the following steps for integration.
Android SDK version
SDK 19 or higher, depending on the terminal's paydroid version.
Gradle's and Gradle plugin's version
Gradle version 4.1 or higher
Gradle plugin version 3.0.0+ or higher
Gradle:
Notice: Jcenter will not provide free download for our old sdks in 2022 , so we moved our latest sdk to Maven center, please update your gradle to integrate with our latest sdk.
Add the dependency
implementation 'com.whatspos.sdk:paxstore-3rd-app-android-sdk:8.4.0'
Tips: For apps that are not used in PAX terminals, you need to make sure you are using PAXSTORE client version at least V8.4.0. Otherwise you should use V8.2.3
PAXSTORE Android SDK need the following permissions, please add them in AndroidManifest.xml.
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
If you are using ProGuard in your project add the following lines to your configuration:
Please check the our proguard-rules.pro
Create a new app in PAXSTORE, and get AppKey and AppSecret from app detail page in developer center.
Configuring the application element, edit AndroidManifest.xml, it will have an application element. You need to configure the android:name attribute to point to your Application class (put the full name with package if the application class package is not the same as manifest root element declared package)
<application
android:name=".BaseApplication"
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme">
Initializing AppKey,AppSecret and SN
Please note, make sure you have put your own app's AppKey and AppSecret correctly
public class BaseApplication extends Application {
private static final String TAG = BaseApplication.class.getSimpleName();
//todo make sure to replace with your own app's appKey and appSecret
private String appkey = "Your APPKEY";
private String appSecret = "Your APPSECRET";
@Override
public void onCreate() {
super.onCreate();
initPaxStoreSdk();
}
private void initPaxStoreSdk() {
//todo Init AppKey,AppSecret, make sure the appKey and appSecret is corret.
StoreSdk.getInstance().init(getApplicationContext(), appkey, appSecret, new BaseApiService.Callback() {
@Override
public void initSuccess() {
//TODO Do your business here
}
@Override
public void initFailed(RemoteException e) {
//TODO Do failed logic here
Toast.makeText(getApplicationContext(), "Cannot get API URL from PAXSTORE, Please install PAXSTORE first.", Toast.LENGTH_LONG).show();
}
});
}
}
Since Android 8.0 has lots of changes that will affect your app's behavior, we recommand you to follow the guide to migrate to Android 8.0. For further information, you can refer to https://developer.android.google.cn/about/versions/oreo/android-8.0-migration
When dependencies conflict occur, the error message may like below:
Program type already present: xxx.xxx.xxx
Solution:
You can use exclude() method to exclude the conflict dependencies by group or module or both.
e.g. To exclude 'com.google.code.gson:gson:2.8.5' in SDK, you can use below:
implementation ('com.whatspos.sdk:paxstore-3rd-app-android-sdk:x.xx.xx'){
exclude group: 'com.google.code.gson', module: 'gson'
}
When attribute conflict occur, the error message may like below:
Manifest merger failed : Attribute application@allowBackup value=(false) from
AndroidManifest.xml...
is also present at [com.whatspos.sdk:paxstore-3rd-app-android-sdk:x.xx.xx]
AndroidManifest.xml...
Suggestion: add 'tools:replace="android:allowBackup"' to <application> element
at AndroidManifest.xml:..
Solution:
Add xmlns:tools="http://schemas.android.com/tools" in your manifest header
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.yourpackage"
xmlns:tools="http://schemas.android.com/tools">
Add tools:replace = "the confilct attribute" to your application tag:
<application
...
tools:replace="allowBackup"/>
More questions, please refer to FAQ
See the Apache 2.0 license file for details.
Copyright 2018 PAX Computer Technology(Shenzhen) CO., LTD ("PAX")
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at following link.
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.