# Overview

# Api Access

First, you will need to make sure you have access to the easyPoints API, which is a premium feature. If your subscription does not include API access (some plans include API access), you can purchase this premium feature in the Settings page of the easyPoints app.

  1. Find the app subscription section in your settings page and click "Change" API Subscription Section

  2. Toggle the API usage premium feature or upgrade to a plan which includes this feature and accept the new subscription. API Usage Premium Feature

# Api Credentials

# Authentication

After ensuring you have included the easyPoints API premium feature in your subscription, you can find the section to create your API credentials in the Settings page of the easyPoints app.

API Credentials Section

# Basic Auth

easyPoints API uses Basic Authorization given the credentials found in the Settings page of the easyPoints app.

Due to the nature of Basic Authorization (opens new window), you must always use HTTPS when sending requests to the easyPoints API.

It is strongly recommended that you use the Authorization header rather than including the credentials in the URL for security reasons. Please see here (opens new window) for more information.

# Example

The following is an example usage of Basic Auth in JavaScript.

WARNING

Be sure not to include your API credentials directly in a client-side application. They should be stored in a location accessible only to those with proper authorization, such as the secret configuration of a server-side application.

const authValue = btoa(`${apiPublicKey}:${apiSecretKey}`);

fetch(url, {
    headers: {
      'Content-Type': 'application/json',
      'Authorization': `Basic ${authValue}`,
    }
  });

# Authorization

Currently all available API credential sets have full authorization for their respective merchant's easyPoints app. This includes the following privileges:

Privilege Definition
read_point_balances Read customer point balances
write_point_balances Update customer point balances (such as with point allotments)
read_point_history Read point history (such as order point information)

# Security

WARNING

Please understand that enabling the easyPoints API comes with risk. Your API credentials must be kept private and secure to avoid a malicious party from distributing points, revoking points, accessing easyPoints information about your customers, etc.

Use with care; granting or revoking an erroneous number of points from your customers could negatively impact your profits or their shopping experience.

# Deleting API Credentials

If you feel your API credentials have been compromised or, for any other reason, you wish to delete your API credentials, you can do so in the Settings page of the easyPoints app. New credentials can also be created immediately if desired.

Delete Credentials

# Rate Limiting

Our API is subject to rate limits to ensure fair usage and maintain system stability. Frequent or excessive requests may result in temporary or permanent suspension of your account's access to the API according to our API Terms.

Each Store using our API is restricted to a maximum of 25 API calls within a 5-second window. Exceeding this limit will result in 429 responses for subsequent requests until the limit resets.

# Rate Limit Headers

The following headers are included in each API request to help you manage your rate limits:

Header Definition
X-RateLimit-Limit Max requests allowed in a time period
X-RateLimit-Remaining Requests left in the current window
Retry-After Wait time in seconds before retrying (included when throttled)