- Create a SumUp account and get an affiliate key here
- From your app
- From your mobile website Payment API - Web
The sample app provided in this repository can be used as a reference.
allprojects {
repositories {
maven { url 'https://maven.sumup.com/releases' }
}
}
compile 'com.sumup:merchant-api:1.4.0'
SumUpPayment payment = SumUpPayment.builder()
//mandatory parameters
// Please go to https://me.sumup.com/developers to get your Affiliate Key by entering the application ID of your app. (e.g. com.sumup.sdksampleapp)
.affiliateKey("YOUR_AFFILIATE_KEY")
.total(new BigDecimal("1.23"))
.currency(SumUpPayment.Currency.EUR)
// optional: add details
.title("Taxi Ride")
.receiptEmail("customer@mail.com")
.receiptSMS("+3531234567890")
// optional: Add metadata
.addAdditionalInfo("AccountId", "taxi0334")
.addAdditionalInfo("From", "Paris")
.addAdditionalInfo("To", "Berlin")
//optional: foreign transaction ID, must be unique!
.foreignTransactionId(UUID.randomUUID().toString()) // can not exceed 128 chars
// optional: skip the success screen
.skipSuccessScreen()
.build();
SumUpAPI.checkout(MainActivity.this, payment, 1);
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
if (requestCode == 1 && data != null) {
// Handle the response here
}
}
<activity
android:name="com.example.URLResponseActivity"
android:label="Payment Result">
<intent-filter>
<action android:name="android.intent.action.VIEW"/>
<action android:name="com.example.URLResponseActivity"/>
<category android:name="android.intent.category.DEFAULT"/>
<category android:name="android.intent.category.BROWSABLE"/>
<!-- Provide your own scheme here and reference it when you make a payment -->
<data
android:scheme="mycallbackscheme"
android:host="result"/>
</intent-filter>
</activity>
Intent payIntent = new Intent(Intent.ACTION_VIEW, Uri.parse(
"sumupmerchant://pay/1.0"
+ "?affiliate-key="YOUR_AFFILIATE_KEY""
+ "&app-id=com.example.myapp"
+ "&total=1.23" // field available from App version 1.88.0 and above. Otherwise keep deprecated field "amount".
+ "¤cy=EUR"
+ "&title=Taxi Ride"
+ "&receipt-mobilephone=+3531234567890"
+ "&receipt-email=customer@mail.com"
+ "&foreign-tx-id=" + UUID.randomUUID().toString()
// optional: skip the success screen
+ "&skip-screen-success=true"
+ "&callback=mycallbackscheme://result"));
startActivity(payIntent);
The result is received as a URI in the callback activity intent:
Uri result = getIntent().getData()
Success:
mycallbackscheme://result?smp-status=success&smp-message=Transaction%20successful.&smp-receipt-sent=false&smp-tx-code=123ABC&foreign-tx-id=0558637a-b73c-43ad-b358-f93cb909251x
Failure:
mycallbackscheme://result?smp-status=failed&smp-failure-cause=transaction-failed&smp-message=Transaction%20failed.&smp-receipt-sent=false&smp-tx-code=123ABC&foreign-tx-id=05c14c86-a7a0-49c5-a1ec-acb168f5198x
Put a link onto your website
<a href="sumupmerchant://pay/1.0?affiliate-key=7ca84f17-84a5-4140-8df6-6ebeed8540fc&app-id=com.example.myapp&total=1.23¤cy=EUR&title=Taxi Ride&receipt-mobilephone=+3531234567890&receipt-email=customer@mail.com&callback=http://example.com/myapp/mycallback">Start SumUp Payment</a>
Note that field total
is available from App version 1.88.0 and above. Keep deprecated field amount
if still supporting older versions of the SumUp App.
Make sure that the callback URL you provide is correct and controlled by you.
Success:
?smp-status=success&smp-message=Transaction%20successful.&smp-receipt-sent=false&smp-tx-code=123ABC
Failure:
?smp-status=failed&smp-failure-cause=transaction-failed&smp-message=Transaction%20failed.&smp-receipt-sent=false&smp-tx-code=123ABC
Several response flags are available when the callback activity is called :
- SumUpAPI.Response.RESULT_CODE
- Type : int
- Possible Values :
- SumUpAPI.Response.ResultCode.TRANSACTION_SUCCESSFUL = 1
- SumUpAPI.Response.ResultCode.ERROR_TRANSACTION_FAILED = 2
- SumUpAPI.Response.ResultCode.ERROR_GEOLOCATION_REQUIRED = 3
- SumUpAPI.Response.ResultCode.ERROR_INVALID_PARAM = 4
- SumUpAPI.Response.ResultCode.ERROR_NO_CONNECTIVITY = 6
- SumUpAPI.Response.ResultCode.ERROR_DUPLICATE_FOREIGN_TX_ID = 9;
- SumUpAPI.Response.ResultCode.ERROR_INVALID_AFFILIATE_KEY = 10;
- SumUpAPI.Response.MESSAGE
- Type : String
- Description : A human readable message describing the result of the payment
- SumUpAPI.Response.TX_CODE
- Type : String
- Description : The transaction code associated with the payment
- SumUpAPI.Response.RECEIPT_SENT
- Type : boolean
- Description : true if a receipt was issued to the customer, false otherwise
The response flags are provided within the Bundle that is passed back to the callback activity.
int resultCode = getIntent().getExtras()getInt(SumUpAPI.Response.RESULT_CODE);
- smp-status:
success/failed
- smp-failure-cause (send it smp-status is
failed
):transaction-failed/geolocation-required/invalid-param/invalid-token
The foreignTransactionID
identifier will be associated with the transaction and can be used to retrieve details related to the transaction. See API documentation for details. Please make sure that this ID is unique within the scope of the SumUp merchant account and sub-accounts. It must not be longer than 128 characters.
The foreignTransactionID is available when the callback activity is called: SumUpAPI.Param.FOREIGN_TRANSACTION_ID
To skip the screen shown at the end of a successful transaction, the skipSuccessScreen
parameter can be used. When using the parameter your application is responsible for displaying the transaction result to the customer. In combination with the Receipts API your application can also send your own receipts, see API documentation for details. Please note success screens will still be shown when using the SumUp Air Lite readers.
- Questions? Get in contact with our integration team by sending an email to integration@sumup.com.
- Found a bug? Open an issue. Please provide as much information as possible.