Migrate from v2
This page has been put together for our integration partners and customers who are currently using the v2 API, here we will guide you through the high-level plan, confirmed details and common questions.
If you are not currently using the v2 API Gateway, then you do not need to continue on this page.
What is the v2 API Gateway?
When we discuss the v2 API, we are actually referring to a previous generation of API's served through a different gateway.
This documentation site is for our third-generation (v3) API gateway and has been planned from the beginning to be the final gateway with an evolving and expanding holistic view of the practices data.
How is v3 different from v2?
The new gateway and endpoints are very different from their v2 counterparts both in scope and purpose.
v2 has very specific use-cases for the endpoints which in many cases orchestrated the flows on your behalf, however with v3 we are not creating artificial limits and restrictions on what you could do, but you will need to orchestrate your required flows.
For example: Now adding new data may include multiple POST requests where previously this was a single request. e.g. Email, Numbers, addresses are all separate endpoints from a contact record. However this means you have greater control because of the granularity and could for example progressively build a clients profile.
v3 will also have more endpoint options as standard to optimise your data usage such as paging, sorting and filtering.
Can we reuse v2 endpoints in v3?
Unfortunately not, you should plan for redevelopment of your integration against the new endpoints.
This is due to the way we are now fully opening up all data entities, therefore a different approach to these resources (e.g. contact, email, numbers) and operations (POST, GET, etc) are required.
What are the main differences?
When you start using our API explorer and documentation, you will notice the following:
- UUID - We now use UUID (Universally Unique IDentifiers) for identifiers instead of integer. Therefore your system will need to be able to store string or natively uuid/guid.
- Authentication - We now use JWT access tokens which refresh once a day not every 15 minutes. Client Key and Secret is only provided to us once per day.
- Tenant-Id - We use a UUID for identifying the customer tenant rather than the previous GroupId.
- Endpoints have a singular purpose instead of multiple.
- Domains - Endpoints are divided into groupings that will reference resources in other domains. These domains all have their own release cycles.
Can we use v2 and v3 at the same time?
Short Answer: Yes for now.
Yes, you can use both v2 and v3 API gateways at the same time and each Merlin PMS can handle requests from both at the same time. However note differences between the 2 gateways above.
As the identifiers are different between the 2 gateways, there are some key identifiers we have created endpoints for your conversion.
- Patient Ids
- Contact and Account Ids (in the Contact OAS)
- Appointment Ids
- Formulary Ids (Code Id)
- Location Ids (Site Id)
v2 ends support and operation July 2024, therefore you should plan a development cycle to complete the transition completely to v3.
When will v3 be available?
Short Answer: It is available now, and more development is planned as required.
Endpoints have been available since November 2021 and have been continually added to since, in the tables below you can find the mapping plus any area's we do not plan to include in the new gateways.
We are continuously reviewing and prioritising our API roadmap, the endpoints of v3 are being developed and released in a continuous fashion; as endpoints are designed, developed and tested, they will be released.
When is v2 capability available in v3?
This has now been completed and released, any existing gaps are either not planned for work or discussion with their primary users.
When will v2 no longer be available to use?
Consumers of the v2 API will be notified and have around 12 months before the planned shutdown date, we will provide as much assistance as we can to help you acheive the goal of migrating.
Migration Mapping
Accounts, Banking & Client Link Services
v2 API | v3 Equivilent |
---|---|
GET Accounts/Account Items | GET billing/invoices GET billing/invoices/uuid/invoice-contents |
GET Accounts/Client Balance | GET billing/uuid/balance |
POST Accounts/Donations | POST billing/payments |
GET Banking/Banking Details | NEW GET billing/payments/summary |
Client Link | No replacement planned for this space. |
GET Client Link/Avg Wait For All Sites | GET Waiting Times |
Clients Service
Clinical Portal Service
Code Entry Service
v2 API | v3 Equivilent |
---|---|
GET Code Entry/Deviations | GET Formulary-Management/location-deviations |
PUT Code Entry/Deviations | NEW PATCH Formulary-Management/location-deviations |
GET Code Entry/Discounts | Discount Codes are included in the Services endpoint. |
PATCH Code Entry/Discounts | Discount Codes are included in the Services endpoint. |
POST Code Entry/Discounts | Discount Codes are included in the Services endpoint. |
PUT Code Entry/Price Updates | COMING SOON Reference: API-533 |
GET Code Entry/Services | GET Formulary-Management/services |
PATCH Code Entry/Services | PATCH Service Configuration |
POST Code Entry/Services | POST Service Configuration |
GET Code Entry/Stock Codes | GET Formulary-Management/stock |
PATCH Code Entry/Stock Codes | PATCH Stock Configuration |
POST Code Entry/Stock Codes | POST Stock Configuration |
New API's for managing metadata are being included in v3, | Dispensing notes: POST Dispensing Notes DELETE Dispensing Notes GET Dispensing Notes
GET Formulary Groups
GET Send-To Actions PATCH Send-To Actions POST Send-To Actions DELETE Send-To Action
GET Discount Categories PATCH Discount Category POST Discount Category DELETE Discount Category
GET Formulary Notes POST Formulary Note PATCH Formulary Note DELETE Formulary Note |
Eligibility, Mobile & Prospect Bookings Services
Registrations Service
Reminders Service
v2 API | v3 Equivilent |
---|---|
Sigma API's | To Do We are evaluating the Sigma strategy for data extraction jobs, this will be added to our backlog. |
Delta API's for Clients, Patients and Clinical History | For Clients see previously listed API's for Contact and Accounts. These allow queries using modified date ranges. |
GET Reminder/Code Details | For Formulary, see previously listed API's for Formulary. These allow queries using modified date ranges. |