Terminal Gateway SDK for iOS (Swift)
The Terminal Gateway SDK for iOS enables you to integrate secure payment processing directly into your iOS applications. Connect to physical payment terminals and process transactions seamlessly using our comprehensive Swift SDK.This SDK works alongside the Terminal API to provide a complete in-person payment solution. You’ll use the Terminal API to create payment sessions and the Terminal Gateway SDK to interact with physical payment devices.
Version information
v0.7.0 — 5-Dec-2025
v0.7.0 — 5-Dec-2025
What’s new:
- Fixed NTT payment method value mapping to ensure correct provider selection
- Updated BRI payment flow to validate transaction data before executing terminal actions
- Added timeout configuration for card and QR transactions to auto-cancel and retry stalled requests
- Added retry logic via Terminal API for more resilient recovery after timeouts
v0.6.0 — 20-Nov-2025
v0.6.0 — 20-Nov-2025
What’s new:
- Added support for multiple concurrent device connections, enabling simultaneous transactions across different terminals
- [BRI] Fixed status value handling in void and cancel API responses for improved transaction status accuracy
v0.5.0 — 30-Oct-2025
v0.5.0 — 30-Oct-2025
What’s new:
- Introduced command ID handling for settlement operations
- Enhanced retry logic with configurable attempt counts
- Improved error handling and logging throughout the gateway service
v0.4.1 — 7-Oct-2025
v0.4.1 — 7-Oct-2025
Bug fixes and improvements:
- Fix data mapping for terminal responses
- [BRI] Enhanced status verification after transaction timeout for improved reliability
v0.4.0 — 13-May-2025
v0.4.0 — 13-May-2025
XenTerminal is the companion SDK to In-Person Payment Sessions API. This version provides core functionality for connecting to payment terminals and processing transactions.
The SDK follows semantic versioning. Breaking changes will bump the major version number.
Download
Download the Terminal Gateway iOS SDK:Installation
Install the Terminal Gateway SDK by adding it as a framework in Xcode:1
Add Sentry dependency
Add the Sentry pod to your Podfile:
Podfile
Run
pod install to install the dependency.2
Extract framework
Extract the TerminalGateway.xcframework zip file in your project directory.

3
Add framework to project
In Xcode, select your target and navigate to the “General” tab.Find “Frameworks, Libraries, and Embedded Content” and click the ”+” button.



4
Import framework
Click “Add Other…” and select “Add Files…”Search for TerminalGateway.xcframework, select it, and click “Open”.

5
Configure build settings
Go to “Build Settings” and make the following changes:

- Search for “ENABLE_USER_SCRIPT_SANDBOXING” and set it to “NO”
- Search for “Other Linker Flags” and add “-lsqlite3”


Getting Started
Before starting, you’ll need an In-Person Payment CLIENT_KEY from the Xendit In-Person Payment team. You will also need the terminal IP address.Step 1: Initialize SDK
Call theXenTerminal.initialize() method within the Application class of your app:
AppDelegate.swift
- Integration Mode
- Live Mode
Use
TerminalMode.integration for development and testing with physical terminals. Transactions are sent to Test Mode on the Xendit Dashboard.Step 2: Register Terminal Device
Register multiple devices by calling theregisterDevices method:
Optional Methods
Set Operation Timeout
Configure the maximum allowed time for operations to complete before the service cancels and retries the transaction:Restart Terminal Connection
Manage and restart terminal service connections:- Restart All Connections
- Restart Single Connection
Call the method without parameters to restart all connections and tasks:
Observing Connection State
Monitor Terminal connection status using theobserveEDCConnection method:
| Code | Description |
|---|---|
connected | Device connected to Terminal |
disconnected | Device disconnected to Terminal |
unknown | When no connection has been established yet |
connecting | Device requesting connection to Terminal |
connectingFailed | Device unable to connect with Terminal |
unsupported | Connection not supported |
Observing Error State
Monitor Terminal error states using theobserveError method:
Error Handling
Error Data Structure
All errors returned by the Terminal Gateway SDK follow this structure:Error Codes Reference
| Error Code | HTTP Status | Description |
|---|---|---|
| INVALID_CREDENTIAL | 401 | Provided credentials are invalid or expired |
| INVALID_REQUEST | 400 | Request format or parameters are invalid |
| INTERNAL_SERVER_ERROR | 500 | Server-side error occurred during processing |
| UNKNOWN_ERROR | 0 | Unexpected error that doesn’t fit other categories |
| KEY_INVALID | -1 | API key is invalid or not authorized |
| SEND_FAILED | -2 | Failed to send data to the terminal device |
| NOT_CONNECTED | -3 | No active connection to any terminal device |
| FAILED_TO_CONNECT | -4 | Unable to establish connection to terminal |
| UNSUPPORTED | -5 | Operation or platform not supported |
| TERMINAL_BUSY | -6 | Terminal is processing another transaction |
| ENCRYPTION_FAILED | -7 | Encryption key invalid or encryption process failed |
| AUTHENTICATION_FAILED | -21 | Terminal authentication failed - check TID and credentials |
Error Handling Best Practices
Implement comprehensive error handling for robust payment processing:Troubleshooting
Common Issues and Solutions
Unresponsive EDC Machine
Unresponsive EDC Machine
Problem: The EDC (Electronic Data Capture) machine becomes unresponsive or stops processing transactions.Solution:
- Restart the EDC machine by holding the power button and selecting “Restart”
- Wait for the device to fully boot up and reconnect
- Verify the terminal is back online using the connection monitoring features
Kiosk Mode Configuration
Kiosk Mode Configuration
Problem: Unexpected behaviors or unauthorized access to terminal functions.Solution:
- Ensure all transactions are initiated only through the SDK
- Contact the Xendit EDC team to enable POS-only mode for your Terminal IDs
- Configure terminal settings to disable manual transaction entry
No Response After Payment Completion
No Response After Payment Completion
Problem: EDC fails to send transaction results to the SDK after payment completion.Solution:
- Query the Payment Session using the Terminal API to retrieve the latest status
- Check network connectivity between the EDC and your application
- Verify the callback URL configuration in your payment session
- Implement retry logic for failed status updates
Connection Issues
Connection Issues
Problem: Unable to establish or maintain connection with terminal devices.Solutions:
- Check network connectivity: Ensure both devices are on the same network
- Verify IP addresses: Confirm terminal IP addresses are correct and accessible
- Firewall settings: Check if firewall is blocking the connection ports
- Terminal status: Ensure the terminal is powered on and in ready state
- SDK initialization: Verify client key and terminal configuration
Use the connection monitoring features to diagnose specific connection issues.
Finding Terminal Information
- BRI Terminals
- NTT Terminals
1
Find Terminal ID (TID)
Open the BRI FMS app on the terminal device and locate the Terminal ID in the device information section.

2
Find IP Address
Open the ECRLink app on the terminal and check the network settings for the IP address.

Screenshots and UI layouts may vary by firmware or app version. Refer to the latest vendor documentation if the interface differs from these instructions.