Allows redeeming active points of customers according to the redemption criteria set for the organization (Loyalty Program). For example, you could set redemption criteria as allow redemption only in multiples of 10 and a maximum of 200 points per time.
This API lets you verify whether a specific number of points can be redeemed by a customer. With this API, you can now issue validation code to the customer automatically upon successful validation. This will reduce an additional step of calling /points/validationcode API to issue validation code.
If there is any problem in issuing validation code, Points Redeemable but OTP Generation failed error will be displayed (876) * if points validation itself fails, then the relevant error message will be displayed
Example request
curl --location 'https://eu.api.capillarytech.com/v1.1/points/isredeemable?mobile=9777785205&program_id=973&format=json&points=10&issue_otp=null&validation_code=true' \
--header 'Authorization: Basic bWFkaHVMjU2YQ==' \
--header 'Cookie: _cfuvid=7165ECtxDm51hFGZ_zSJYF7reiBXgk4OldF_d7_82Iw-1761202117837-0.0.1.1-604800000'Prerequisites
- Basic Authentication
- Default access group
Resource information
| URI | /v1.1/points/isredeemable? | 
|---|---|
| HTTP method | GET | 
| Authentication | Basic | 
| Pagination supported? | NO | 
| Rate limit | YES. Demo and testing clusters: 1000 requests per minute per API key. Other organizations: Rate limit is brand-specific. | 
| Batch support | NO | 
Request Parameters
| Parameter (Parameters marked in * are mandatory) | Type | Description | 
|---|---|---|
| mobile/email/external_id/card_number/card_external_id* | Enum | Pass any of the registered identifier type. | 
| program_id* | long | Unique ID of the loyalty program from which points need to redeem. | 
| group_redemption | boolean | Pass  | 
| points* | int | Number of points to redeem. | 
| issue_otp | boolean | Pass  | 
| validation_code | string | OTP issued to the customer’s mobile number. | 
| skip_validation | boolean | Pass  | 
| validation_type | Enum | Preferred mode of validation.
Value:  | 
| user_group2_primary_user_id | long | Unique user ID of the primary member of the group associated with the points to redeem. | 
| user_group2_id | int | Unique ID of the group associated with the points to redeem. | 
| user_group2_primary_user_source | Enum | Source in which the primary user’s identifier is available.
Value:  | 
| user_group2_primary_user_accountId | string | Account ID of the source with multiple accounts such as WECHAT. | 
| user_group2_primary_user_identifier_type | Enum | Identifier type used for the primary member.
Value:  | 
| user_group2_primary_user_identifier_value | string | Value of the specified identifier type. | 
| user_group2_external_id | string | Unique external ID of the group associated with the points to redeem. | 
| use_default_user_group2 | boolean | Pass  | 
| currency_input | boolean | Pass  | 
Example response
{
    "response": {
        "status": {
            "success": "true",
            "code": 200,
            "message": "Success"
        },
        "points": {
            "redeemable": {
                "mobile": "919777785205",
                "email": "[email protected]",
                "external_id": "434547",
                "points": 10,
                "is_redeemable": "true",
                "points_redeem_value": 10,
                "points_redeem_local_value": 10,
                "input_type": "points",
                "points_currency_ratio": "1",
                "item_status": {
                    "success": "true",
                    "code": 800,
                    "message": "Points can be redeemed"
                }
            }
        }
    }
}Response parameter
| Parameter Path | Type | Description | 
|---|---|---|
| response | boolean | true if the request succeeded. | 
| status | integer | HTTP status code (e.g., 200 for success). | 
| -message | string | Human-readable status message (e.g., "Success"). | 
| mobile | string | Customer’s registered mobile number (masked or full, based on configuration). | 
| string | Customer’s registered email address. | |
| externalId | string | Customer’s external identifier | 
| points | integer | Points requested for redemption. | 
| -is_redeemable | boolean | true if points are redeemable. | 
| -points_redeem_value | decimal | Equivalent monetary value of redeemable points | 
| -points_redeem_local_value | decimal | Equivalent monetary value in local currency (if conversion is enabled). | 
| -input_type | string | Type of input (e.g., "points" or "currency"). | 
| points_currency_ratio | string | Conversion ratio between points and currency (e.g., "1"). | 
| -item_status | boolean | true if points validation passed. | 
| --code | integer | Sub-status code for redemption checks (e.g., 800). | 
| --message | string | Detailed message (e.g., "Points can be redeemed"). | 
API specific error codes
| Error Code | Description | Reason | 
|---|---|---|
| 889 | Points processing failed, Please try again later Reason : Failed to Connect to Service | Invalid Customer identifiers passed | 
| 1101 | invalid programId passed | Invalid programIdpassed | 
| 801 | Trying to redeem invalid points | Invalid pointsparameter passed (e.g, negative points value) | 
| 818 | Current points are less than points requested for redemption | Points redemption value is lesser than the current/existing points | 
