Partner Cards API

Partner Cards API endpoints allow partners to create, manage, and configure their loyalty cards with custom point systems and coupon validity settings.
Partner Cards API requires partner-level authentication with proper JWT tokens.

Base URL

  • Staging: https://staging-api.loyalty.lt/{locale}/partners/cards
  • Production: https://api.loyalty.lt/{locale}/partners/cards
Where {locale} is the language code (e.g., en, lt).

Create Partner Card

Request Body

{
  "title": {
    "en": "VIP Loyalty Card",
    "lt": "VIP lojalumo kortelė"
  },
  "description": {
    "en": "Premium loyalty card with exclusive benefits",
    "lt": "Premium lojalumo kortelė su išskirtinėmis privilegijomis"
  },
  "terms_conditions": {
    "en": "Terms and conditions apply...",
    "lt": "Taikomos nuostatų ir sąlygų nuostatos..."
  },
  "card_design": {
    "logo": "...",
    "text_color": "#000000",
    "text_color_labels": "#555555",
    "qr_background_color": "#FFFFFF",
    "qr_color": "#000000",
    "background_color": "#FFFFFF",
    "background_color_opacity": 0.8,
    "background_image": "..."
  },
  "is_active": true,
  "shop_ids": [1, 2, 3],
  "auto_assign": true,
  "points_enabled": true,
  "initial_bonus_points": 100,
  "points_expiration_days": 365,
  "points_per_currency": 1.0,
  "currency_amount": 1.0,
  "round_points_up": false,
  "min_points_per_purchase": 0,
  "max_points_per_purchase": 1000,
  "points_per_visit": 5,
  "points_redemption_enabled": true,
  "points_per_currency_redemption": 10.0,
  "currency_amount_redemption": 1.0,
  "min_points_for_redemption": 100,
  "max_points_per_redemption": 5000,
  "default_coupon_validity_days": 30
}

Field Descriptions

FieldTypeRequiredDescription
titleobjectYesCard title in multiple languages
title.enstringYesEnglish title
title.ltstringYesLithuanian title
descriptionobjectYesCard description in multiple languages
terms_conditionsobjectYesTerms and conditions in multiple languages
card_designobjectYesVisual design settings for the card
is_activebooleanNoWhether the card is active (default: true)
shop_idsarrayNoArray of shop IDs where card applies
auto_assignbooleanNoAuto-assign to new customers (default: true)
points_enabledbooleanNoEnable points system (default: true)
initial_bonus_pointsintegerNoInitial bonus points for new cards
points_expiration_daysinteger|nullNoPoints expiration in days (null = never expire)
points_per_currencynumberNoPoints earned per currency unit
currency_amountnumberNoCurrency amount for point calculation
round_points_upbooleanNoRound points up to nearest integer
min_points_per_purchaseintegerNoMinimum points per purchase
max_points_per_purchaseinteger|nullNoMaximum points per purchase
points_per_visitintegerNoPoints awarded per visit
points_redemption_enabledbooleanNoEnable point redemption
points_per_currency_redemptionnumberNoPoints required per currency unit for redemption
currency_amount_redemptionnumberNoCurrency value for redemption calculation
min_points_for_redemptionintegerNoMinimum points required for redemption
max_points_per_redemptioninteger|nullNoMaximum points per redemption transaction
default_coupon_validity_daysinteger|nullNoDefault validity period for game-generated coupons (null = never expire)

Validation Rules

  • default_coupon_validity_days: Must be between 1-3650 days, or null for unlimited validity
  • title.en and title.lt: Required, max 255 characters each
  • points_per_currency and currency_amount: Must be positive numbers
  • shop_ids: Must contain valid shop IDs owned by the partner

Response

{
  "success": true,
  "code": 201,
  "message": "Partner card created successfully",
  "data": {
    "id": 123,
    "title": {
      "en": "VIP Loyalty Card",
      "lt": "VIP lojalumo kortelė"
    },
    "description": {
      "en": "Premium loyalty card with exclusive benefits",
      "lt": "Premium lojalumo kortelė su išskirtinėmis privilegijomis"
    },
    "is_active": true,
    "default_coupon_validity_days": 30,
    "created_at": "2025-01-08T10:30:00Z",
    "updated_at": "2025-01-08T10:30:00Z"
  }
}

Update Partner Card

Path Parameters

ParameterTypeRequiredDescription
idintegerYesPartner card ID

Request Body

Same as create endpoint. All fields are optional for updates.

Response

{
  "success": true,
  "code": 200,
  "message": "Partner card updated successfully",
  "data": {
    "id": 123,
    "title": {
      "en": "Updated VIP Loyalty Card",
      "lt": "Atnaujinta VIP lojalumo kortelė"
    },
    "default_coupon_validity_days": 60,
    "updated_at": "2025-01-08T11:45:00Z"
  }
}

Get Partner Card

Path Parameters

ParameterTypeRequiredDescription
idintegerYesPartner card ID

Response

{
  "success": true,
  "code": 200,
  "message": "Partner card retrieved successfully",
  "data": {
    "id": 123,
    "title": {
      "en": "VIP Loyalty Card", 
      "lt": "VIP lojalumo kortelė"
    },
    "description": {
      "en": "Premium loyalty card with exclusive benefits",
      "lt": "Premium lojalumo kortelė su išskirtinėmis privilegijomis"
    },
    "terms_conditions": {
      "en": "Terms and conditions apply...",
      "lt": "Taikomos nuostatų ir sąlygų nuostatos..."
    },
    "card_design": {
      "logo": "...",
      "text_color": "#000000",
      "text_color_labels": "#555555",
      "qr_background_color": "#FFFFFF",
      "qr_color": "#000000",
      "background_color": "#FFFFFF",
      "background_color_opacity": 0.8,
      "background_image": "..."
    },
    "is_active": true,
    "shop_ids": [1, 2, 3],
    "auto_assign": true,
    "points_enabled": true,
    "initial_bonus_points": 100,
    "points_expiration_days": 365,
    "points_per_currency": 1.0,
    "currency_amount": 1.0,
    "round_points_up": false,
    "min_points_per_purchase": 0,
    "max_points_per_purchase": 1000,
    "points_per_visit": 5,
    "points_redemption_enabled": true,
    "points_per_currency_redemption": 10.0,
    "currency_amount_redemption": 1.0,
    "min_points_for_redemption": 100,
    "max_points_per_redemption": 5000,
    "default_coupon_validity_days": 30,
    "created_at": "2025-01-08T10:30:00Z",
    "updated_at": "2025-01-08T11:45:00Z"
  }
}

List Partner Cards

Query Parameters

ParameterTypeRequiredDescription
is_activebooleanNoFilter by active status
shop_idintegerNoFilter by shop ID
pageintegerNoPage number (default: 1)
per_pageintegerNoItems per page (default: 20, max: 100)

Response

{
  "success": true,
  "code": 200,
  "message": "Partner cards retrieved successfully",
  "data": [
    {
      "id": 123,
      "title": {
        "en": "VIP Loyalty Card",
        "lt": "VIP lojalumo kortelė"
      },
      "is_active": true,
      "default_coupon_validity_days": 30,
      "created_at": "2025-01-08T10:30:00Z",
      "updated_at": "2025-01-08T11:45:00Z"
    }
  ],
  "pagination": {
    "current_page": 1,
    "per_page": 20,
    "total": 1,
    "last_page": 1
  }
}

Delete Partner Card

Path Parameters

ParameterTypeRequiredDescription
idintegerYesPartner card ID

Response

{
  "success": true,
  "code": 200,
  "message": "Partner card deleted successfully"
}

Coupon Validity Feature

The default_coupon_validity_days field controls how long coupons generated from games remain valid:

Behavior

  • null value: Coupons never expire (unlimited validity)
  • Integer value (1-3650): Coupons expire after specified number of days
  • Used by: Game completion coupons, reward coupons from partner games
  • Calculation: coupon.expires_at = now() + default_coupon_validity_days

Examples

// Coupons never expire
{
  "default_coupon_validity_days": null
}

// Coupons expire after 30 days
{
  "default_coupon_validity_days": 30
}

// Coupons expire after 1 year
{
  "default_coupon_validity_days": 365
}

Migration Notice

⚠️ Deprecated: The default_coupon_validity_days field has been moved to individual game settings for better control.

Games API Reference

Coupon settings are now configured per-game. See the Games API for details.

Error Responses

Validation Errors

{
  "success": false,
  "code": 422,
  "message": "Validation failed",
  "errors": {
    "default_coupon_validity_days": [
      "The default coupon validity days field must be between 1 and 3650."
    ],
    "title.en": [
      "The title.en field is required."
    ]
  }
}

Not Found

{
  "success": false,
  "code": 404,
  "message": "Partner card not found"
}

Unauthorized

{
  "success": false,
  "code": 401,
  "message": "Unauthorized. Valid JWT token required."
}