Payment Tracking
Create orders in Gameball to award points for customer purchases. This API is used to track orders and reward customers for their completed purchases.
Available APIs
POST - Track Payment
The API call tracks new payments, specifically tailored for fintech solutions. It captures key payment details, ensuring accurate tracking of customer transactions.
This API triggers the "Payment Processed" event, allowing you to automate follow-up actions such as initiating workflows, sending notifications, or rewarding customers with badges.
The event includes all properties provided in the payload.
Security: Requires apikey and secretkey headers.
Channel Merging Available If your system uses different customer IDs across multiple channels (e.g., online and offline), Gameball's channel merging feature helps unify customer profiles. By including the customer’s mobile number or email (based on your merging configuration) with each request, Gameball will combine activities into a single profile.For more information, head to the Channel Merging Guide.
Request
Body
application/json
customerId string
Required
Unique identifier for the customer that you can reference across the customer’s whole lifetime. Could be a database ID, random string, email or anything that uniquely identifies the customer.
email string
Optional
Customer's email address.
Note: This is required if your account uses email-based channel merging.
mobile string
Optional
Customer's mobile number.
Note: This is required if your account uses mobile-based channel merging.
paymentId string
Required
Unique identifier for the payment on your system.
paymentDate datetime
Required
Timestamp of when the payment was occurred.
totalPaid float
Required
The actual amount paid by the customer for the payment, accounting for any discounts or coupons applied. Unlike totalAmount
, which reflects the original cost of the payment, totalPaid
represents the final amount the customer paid after all adjustments. This value is used for reward calculations in Gameball to determine the points or benefits earned from the payment.
Example: A customer makes a bill payment for their electricity bill of $120, including taxes and processing fees. If a $20 coupon is applied, the totalPaid
becomes $100, reflecting the discounted amount the customer paid. This is the value used to calculate any points or rewards earned from the payment.
totalAmount float
Optional
The total cost of the payment, including all item prices, processing fees and taxes. This value does not account for any discounts or coupons applied and is not used for calculations in Gameball; it is solely saved as historical data linked to the payment. Must be a positive value.
Example: A customer makes a bill payment for their electricity bill of $120, including taxes and processing fees. If a $20 coupon is applied, the totalAmount remains $120 as it represents the original cost of the payment before any discounts are applied.
totalDiscount float
Optional
Total discount applied to the payment.
totalProcessingFees float
Optional
Total processing feest associated with the payment.
totalTax float
Optional
Total tax amount for the payment.
paymentDetails array
Optional
An array containing details about each element in the payment bill. If not provided, the calculation will only consider the total payment values.
redemption object
Optional
Redemption details for the payment, including points held for redemption.
merchant object
Optional
This object contains details about the specific merchant involved in the transaction, which is particularly important for businesses managing multiple merchants or branches under the same Gameball account. This object can provide identifying information about both the main merchant and any associated branch where the transaction took place.
guest boolean
Optional
Indicates whether the customer is a guest (not signed up). Set this to true
for guest users; otherwise, they are treated as registered customers by default.
channel string
Optional
The channel through which the payment was placed helps track the origin of the payment, particularly useful for systems that support multiple sales or communication channels. By identifying the channel, you can gain valuable insights into customer behavior, optimize channel-specific strategies, and ensure efficient handling of payment across platforms.
Possible values:
mobile
: The payment was placed through your mobile application.pos
: The payment was placed in person using a Point of Sale (POS) system, such as at a physical store or outlet.web
: The payment was placed through your website.callcenter
: The payment was placed over the phone by contacting a customer service representative or a call center.
cashbackConfigurations object
Optional
This object contains configurations related to the cashback settings.
extra object
Optional
Key-value pairs containing any extra information about the payment. The values must be of type string or number.
Example: The extra
attribute can store additional details like the billing address and payment status. For instance, when a customer completes a payment, the billing address ensures accurate invoicing by including details like the company name and tax identification number. At the same time, the payment status helps track the transaction—whether it's "Pending" for deferred payments or "Completed" when successfully processed—ensuring smooth order management and financial compliance.
Sample Request
Response
application/json
customerId string
Unique identifier for the customer that you can reference across the customer’s whole lifetime. Could be a database ID, random string, email or anything that uniquely identifies the customer.
redeemedPoints number
Points redeemed by the customer for this payment, if applicable.
Example:If a customer has accumulated 500 points and decides to redeem 100 points for a discount on their current payment, the redeemedPoints
value for that transaction will be 100. This helps track how many points were used in the transaction and what benefits were applied to the payment based on the customer's redeemed points.
rewardedPoints number
The total number of points rewarded to the customer for making this payment. These points are typically awarded based on your configured cashback rewards.
Example: If the store rewards 10 points for every $1 spent, and a customer complete a payment worth $50, the rewardedPoints for this order would be 500 points.
paymentDetails array
Details about each service in the payment, including points rewarded.
Sample Response
Last updated