Guides

Error Codes

When Pay-i encounters an error, it will return a code and a message.

The code represents the type of error, and can be used in your service for control flow to retry and navigate around issues. A change to a code is considered a breaking change.

The message provides a human-readable, friendly string intended to assist with diagnosing issues. The message values will change over time as we improve our error reporting to make it easier to debug.

The below section is organized by groups of APIs. Each section describes the error codes and sample messages you may encounter when working with that group of APIs. Messages are subject to change at any time.

All APIs

CodeMessage
invalid_api_keyYour api key is invalid, missing, or expired.

All apis which accept tags as input

CodeMessage
invalid_tags{0} contains an invalid tag name '{1}'. Alphanumeric, underscore (_) and dash (-) only

All Proxy APIs (excluding Ingest)

CodeMessage
invalid_provider_hostThe provided host URI '{0}' is invalid
invalid_provider_uriThe provided URI '{0}' is invalid
invalid_provider_ssl_certificateThe provided host URI '{0}' SSL certificate invalid
unexpected_errorThe system has encountered an unexpected error

All Proxy and Ingest APIs

CodeMessage
required_field_missingRequired request field '{0}' is missing
invalid_tags{0} contains an invalid tag name '{1}'. Alphanumeric, underscore (_) and dash (-) only
experience_type_not_foundExperience type name '{0}' not found
experience_instance_not_foundExperience id '{0}' not found
invalid_user_idUser Id '{0}' is not valid
invalid_jsonBody JSON is invalid
category_not_foundCategory '{0}' not found
category_resource_not_foundCategory '{0}' and resource '{1}' not found

When providing a Limit ID to Proxy/Ingest APIs

CodeMessage
invalid_limit_idInvalid limit id '{0}'
invalid_limit_idsSome or all of passed limit-ids either do not exist or they are not related to the Application
limit_reachedInsufficient limit for the requested operation

All Ingest APIs (excluding Proxy)

CodeMessage
invalid_ingest_event_timestampIngest event_timestamp {0} cannot be greater than 5 minutes into the future {1}
blocking_limit_not_allowedBlock limits cannot be used for ingest requests
category_resource_not_foundCategory '{0}' and resource '{1}' and event timestamp '{2}' not found

Limit APIs

CodeMessage
limit_not_foundLimit Id '{0}' not found
create_limit_validation_failedA error message for the specific validation that failed
update_limit_validation_failedA error message for the specific validation that failed
limit_name_already_existLimit name '{0}' already exists
invalid_max_limit_updateNew Limit max value cannot less than the current spent of '{0}'

Experience APIs

CodeMessage
experience_type_id_invalidExperience type id '{0}' is invalid
experience_type_not_foundExperience type id '{0}' not found
experience_id_invalidExperience id '{0}' is invalid
experience_instance_not_foundExperience id '{0}' not found
invalid_experience_nameExperience name '{0}' must be unique, not empty, max 64 characters
invalid_experience_descriptionExperience description '{0}' must be supplied, max 256 characters
experience_type_already_existsExperience type name '{0}' already exists