Migrate to D1 API v2
Migrate end users and cards to V2 APIs
In D1, two generations of APIs are available: V1 and V2.
V2 introduces new capabilities, such as Authorization Controls APIs (for example, the limits control API).
This page is for issuers that already have end users ("consumers" in the D1 API) and cards registered through the V1 APIs and want to migrate them to V2 in order to use the new V2 features.
Migration steps
A V1 to V2 migration consists of four steps. Some steps are handled by Thales; others by the issuer.
1
Thales
Thales configures your issuer tenant for V1-to-V2 migration. This configuration has no impact on your existing issuer backend integrations or live traffic.
2
Issuer
The issuer integrates the V2 Register consumer API and the V2 Register card API, and routes all new registration traffic to these V2 APIs. As a result, every new end user and card is created directly in V2. The issuer can continue to use all other V1 APIs, including for cards that were registered through V2.
3
Thales
Thales runs the bulk migration process. All end users and cards that were previously registered in V1 for this issuer are migrated to V2. The issuer can continue to use V1 APIs, including for cards that have already been migrated to V2.
4
Issuer
The issuer integrates the remaining V2 lifecycle APIs for end users and cards — suspend, resume, renew, replace, and delete for cards, and delete for end users — and routes all lifecycle traffic to these V2 APIs.
Migration limitations
Several behavioral changes and limitations apply during a V1 to V2 migration.
Data mapping
The data models used by the V1 and V2 APIs differ for some attributes. During migration, specific V1 values are automatically converted to the corresponding V2 values.
Consumer state
Consumer
INACTIVE
Consumer
ACTIVE (INACTIVE is not supported in V2; migrated consumers are set to ACTIVE).
Consumer state
Consumer
ACTIVE
Consumer
ACTIVE
Card state
Card
INACTIVE
Card
SUSPENDED
Card state
Card
ACTIVE
Card
ACTIVE
Card accountId
Card
accountId
N/A
consumerId (replaces the V1 accountId value with the corresponding consumerId).
Card name
N/A
N/A
Card
Empty string (no card name is populated during migration).
Scheme limitation
Only Mastercard and Visa cards are supported in V2. Cards from other payment networks that exist in V1 are not migrated to V2.
cardId and PAN limitation
cardId and PAN limitationIn the V2 APIs, a cardId is associated with exactly one PAN. It is a one-to-one mapping.
In V1, multiple cardId values can be linked to the same PAN. During migration:
Only the most recent
cardIdfor a given PAN is migrated to V2 ("most recent card wins").Older
cardIdvalues associated with the same PAN are not migrated and are not supported in V2.If you call a V2 API with one of these non-migrated
cardIdvalues, the API returns HTTP404 Not Found.
V1 Renew API vs V2 Renew and Replace APIs
This limitation applies only when the V1 Renew API is called on a card that has already been migrated to V2 (for example, after Thales has started the migration but before the issuer has fully implemented the V2 Renew and V2 Replace APIs).
In this situation, the V1 Renew API returns HTTP 403 Forbidden if any of the following conditions are met:
The
newCardIdin the payload is equal to the existingcardId, but the card PAN has been updated.The
newCardIdin the payload is not equal to the existingcardId, but the card PAN is still the same.The
newCardIdin the payload is not equal to the existingcardIdandnewCardStatusisINACTIVE.The
reasonCodeprovided in the payload is not allowed in V2.
Last updated
Was this helpful?