Build on Android

Link to section

Overview

The Mobile Payments SDK offers developers a secure way to integrate the Square checkout flow into their mobile applications and accept in-person payments with Square Readers.

There are four steps required to take your first payment using the Mobile Payments SDK:

  1. Install and configure the Mobile Payments SDK in your Android application
  2. Authorize the Mobile Payments SDK
  3. Pair a card Reader
  4. Take a payment

For an example implementation, download the Mobile Payments SDK sample application, written in Kotlin using Compose.

Link to section

Requirements and limitations

  • Your Square account is enabled for payment processing. If you haven't enabled payment processing on your account (or you're not sure), visit squareup.com/activation.
  • You have a Square Reader device to take payments in production (not required for sandbox payments).
  • Your application's minSdkVersion is API 24 (Android 7) or later.
  • Your application's targetSdkVersion is API 33 (Android 13) or a minimum of API 24 (Android 7).
  • Your application's compileSdkVersion is 34.
  • Your application uses AndroidX or enables Jetifier in gradle.properties.
  • You're using the Android Gradle Plugin version 8.1.0 or later. The Mobile Payments SDK might work with 7.1.0 or later, but stability isn't guaranteed.
  • Your version of the Mobile Payments SDK adheres to the Square update policy. To limit risk to developers and their users, Square enforces an update policy requiring developers keep their version of the Mobile Payments SDK current.
  • You're generally familiar with developing applications on Android. If you're new to Android development, you should read the Documentation on the Android Developers site before continuing.

Note

The Mobile Payments SDK doesn't support Proguard for code optimization, as it might remove some critical bytecode from the library.

Link to section

Device permissions

The Mobile Payments SDK requires that the user grant access to their device’s current location while using your app. To use a Contactless and Chip reader to take card payments, Bluetooth must be enabled, and to use a magstripe reader, your application must be granted permission to access the device's microphone.

Ensure your application requests the following runtime permissions:

Android device permissionPurpose
ACCESS_FINE_LOCATIONTo confirm that payments are occurring in a supported Square location.
RECORD_AUDIOTo receive data from magstripe readers.
BLUETOOTH_CONNECTTo receive data from contactless and chip readers.
BLUETOOTH_SCANTo store information during checkout.
READ_PHONE_STATETo identify the device sending information to Square servers.
Link to section

Device compatibility

The Mobile Payments SDK isn't compatible with custom devices from original equipment manufacturers that violate Square's security rules or devices that grant root access to the mobile device operating system code and kernel. These devices cannot connect to a contactless and chip reader and don't comply with Square's security requirements.

The following additional considerations apply when trying to run the SDK on custom devices:

  • The Mobile Payments SDK isn't supported for rooted devices or devices with custom ROMs.
  • Square prohibits using any software that provides the ability to record or capture screen data or that results in elevated privileges.
  • Square recommends running the Mobile Payments SDK on devices from large mobile device manufacturers such as Google or Samsung.
  • If your mobile application runs on an uncommon device manufacturer, be sure to test the device with any expected software requirements, including Bluetooth connectivity, before investing in the device.
  • Supported OS versions should be the latest or as close to the latest as possible.
  • Review the Square support window for the OS version and confirm support for the compilation target version and the runtime version. The compilation target currently supports version 34. For runtime, the supported versions are 24 to 34.
Link to section

Quickstart

Get started with the Mobile Payments SDK by configuring your Android application and taking a test payment in the Square Sandbox.

Follow the steps to set up and test the Mobile Payments SDK in your own application or download the Mobile SDK sample application (written in Kotlin) to see an example of initialization, authorization, and taking payments in production or the Square Sandbox.

Screenshots of the Square Mobile Payments SDK Android sample app, showing the purchase screen and permission selection screen

Link to section

1. Install the SDK and dependencies

Add Square's Maven repo to your project's settings.gradle file and the following dependencies to your project's build.gradle file. The Mock Reader UI is used to simulate virtual reader devices.

settings.gradle.kts:

... dependencyResolutionManagement { repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS) repositories { ... maven ("https://sdk.squareup.com/public/android/") } } ...

build.gradle.kts:

... dependencies { // Your dependencies ... val squareSdkVersion = "2.0.2" // Mobile Payments SDK dependency implementation("com.squareup.sdk:mobile-payments-sdk:$squareSdkVersion") // MockReader UI dependency implementation("com.squareup.sdk:mockreader-ui:$squareSdkVersion") }
Link to section

2. Initialize the Mobile Payments SDK

Before taking a payment or attempting any other operation with the Mobile Payments SDK, you must initialize it using the initialize method and your Square developer application ID. To get your application ID, sign in to the Developer Console and choose your application. If you don't have an application, see Get Started for steps to create a Square application.

Your application opens in the Developer Console to the Credentials page. This page contains your Square application ID used to initialize the Mobile Payments SDK.

Note

To test the Mobile Payments SDK in the Square Sandbox with mock readers and mock payments, switch the toggle at the top of the Developer Console to Sandbox to show your Sandbox credentials and initialize the SDK with your Sandbox application ID. To start taking production payments, you must initialize the Mobile Payments SDK again with your production application ID.

A good place to initialize the SDK is inside the onCreate() method of an extended Application class, because it's executed early in the application lifecycle.

class DemoApplication : Application() { override fun onCreate() { super.onCreate() MobilePaymentsSdk.initialize(getId(), this) } }

If using the previous example, you should write your own implementation for getId() to return your application ID value from the Developer Console. Depending on your use case, this can be your production or Sandbox application ID, which might be stored as hardcoded strings, as Android resources, or fetched from your server.

Link to section

3. Authorize the Mobile Payments SDK

The AuthorizationManager handles authorization for the Mobile Payments SDK. Call the authorize() method with an OAuth access token and location ID. If you're testing your application in the Square Sandbox, you can use your Sandbox personal access token and location ID.

Important

Don't deploy an application that contains your personal access token into production. For secure authorization in production, you should implement OAuth instead of using a personal access token.

In your call to authorize(), configure a callback to be notified of authorization errors and display those to the user.

Link to section

4. Test with mock readers in the Square Sandbox

Physical card readers aren't supported in the Square Sandbox. To take test payments, you must simulate a virtual reader with the Mock Reader UI.

The Mock Reader UI automatically attaches a floating button to the currently displayed Activity as you navigate between screens in your application after you've called MockReaderUI.show(). The icon can be dragged anywhere on the screen and persists throughout your application lifecycle.

override fun onCreate() { super.onCreate() // If in Sandbox - display Mock Reader floating icon if (MobilePaymentsSdk.isSandboxEnvironment()) { MockReaderUI.show() } } // MockReader must hide once deauthorized as it should only be used within the Sandbox environment. private fun deauthorize() { MockReaderUI.hide() }

Click the following button to simulate connecting a magstripe reader or a contactless and chip reader to your device. You can use the ReaderManager to programmatically access information about these simulated readers, such as their model and available card entry methods.

The floating button that appears when using the Mobile Payments SDK Mock Reader UI.

When mock readers have been connected and you begin a payment, click the button again to test your application's payment flow and simulate swiping, inserting, removing, or tapping a card with the mock reader. Click Payment details to select different card brands and payment behaviors (approved or declined) for testing purposes. To hide the button in your application, call MockReaderUI.hide().

Note

When testing card payment flows, any inserted cards must be removed through the mock reader UI before beginning a new payment.

To pair physical readers for production payments, see Pair and Manage Card Readers.

Link to section

5. Set up a payment

The PaymentManager handles payments in the Mobile Payments SDK. Prior to starting a payment, you create PaymentParameters to represent details of an individual payment and PromptParameters to indicate how the payment prompts are presented to the buyer.

Link to section

Payment parameters

Before beginning a payment, create a PaymentParameters object. At a minimum, you must include the payment amount and an idempotency key. For the complete list of payment parameter values and details, see Android technical reference.

Link to section

Prompt parameters

Each payment also requires PromptParameters, consisting of a mode and additionalPaymentMethods available to buyers. At this time, KEYED (a manually entered credit card payment) is the only additional payment method available.

Square provides a payment prompt screen that displays a UI prompting buyers to swipe, tap, or insert their card, depending on the payment options available. To use this screen, set PromptParameters.mode to DEFAULT. If you want to create your own custom payment prompt screen instead of using the default, set PromptParameters.mode to CUSTOM.

A graphic showing the default payment prompt screen for the Android Mobile Payments SDK. The screen shows a 24 dollar payment and prompts the user to connect hardware to take card payments.

If you create your own custom payment prompt UI, use the setAvailableCardEntryMethodChangedCallback to update your UI if the available card entry methods change (for example, if a magstripe reader is inserted or removed from the mobile device). You should set this callback in either a ViewModel or an Activity’s onCreate() or onResume() method.

Link to section

6. Take a payment

When you're ready to begin a payment, call paymentManager.startPaymentActivity() with the PaymentParameters and PromptParameters you created for this payment, along with a callback to notify you of the payment's success or failure.

During a payment, Square takes control of the screen display as another Android Activity to ensure that buyer information is handled securely and that the final confirmation of the payment is correctly shown to the buyer.

A graphic showing two payment screens in the Android Mobile Payments SDK, showing a 24 dollar payment going through "Processing" and "Approved" status.

If the payment completes successfully, a Payment object is returned to your payment callback. This payment can be accessed on the Square Dashboard or with the Payments API. If the payment fails, the response contains a PaymentError.

Link to section

Next steps

After installing the Mobile Payments SDK and testing your application with test payments in the Square Sandbox, learn more about configuring your application to take production payments.