Skip to main content

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."
}