Upserts and External IDs
You can insert or update new records through an upsert operation based on the value of a specified external ID field. This identifier is used to determine whether to create a new record or update an existing one. This operation streamlines data synchronization between Rose Rocket and external systems.
Important: The process of upserting records by external IDs in Rose Rocket is uniform across all the objects. In this document, we’ve explained upserts operation using the Commodity object as a representative example. Regardless of the object type–whether it’s Order, Commodity, Tasks, or any other entity– the upsert method remains consistent.
To adapt the examples provided to other objects, you will need to replace the <objectKey>
and adjust the JSON payload to match the specific fields and data structure of the object you are working with.
Upserts Behavior
An upsert is performed using PATCH
or POST
requests to the Rose Rocker API with the necessary headers and JSON payload. The externalId field in the payload is used to uniquely identify the record. The behavior of the upsert operation is as follows:
- If the external ID does not match any existing records, a new record is created with the details specified in the request body.
- If the external ID matches an existing record, that record is updated with the new information provided.
Upserting New Records
When integrating with the Rose Rocket API, you may need to insert new records or update existing ones based on a unique external ID. This identifier is used to prevent duplication during the insert operation. If a record with the provided externalId does not exist, the API will create a new record.
Example for Upserting a Record That Doesn’t Yet Exist
This example demonstrates how to use the PATCH method to insert a new record using an external ID. It assumes that an external ID field, such as <externalIdField>
, has been added to the Commodity object and that no record with the given external ID value currently exists.
Note: This process is the same for all object types within Rose Rocket, you need to replace the <objectKey>
and the payload with the relevant information for the object you are working with.
Inserting a new record
To create a new record, send a PATCH
request with the necessary headers and JSON payload. The API will check if a record with the given <externalId>
exists. If not, it will create a new record with the provided data.
Sample Request
curl --location --request PATCH '<http://xyzfreightcorp.roserocket.com/api/v2/platformModel/objects'>
--header 'Content-Type: application/json'
--header 'Authorization: Bearer <token>'
--data '{
"objectKey": "commodity",
"json": {
"externalId": "someCommodityExternalID",
// Additional fields for the commodity object
}
}'
The provided example demonstrates how to perform an upsert operation on any objects within the Rose Rocket platform using a PATCH
request.
- Replace
<token>
with your actual authorization token. - The
<objectKey>
specifies the type of object you are working with, in this case, "commodity". - The
json
object contains the fields that are being provided for the new record, including the<externalId>
.
Sample Response
The successful response will include details of the newly created record, such as its unique identifier and the fields that were provided in the request.
{
"id": "83a57ed2-d517-4c11-a046-f7ed764fc8c7",
// Other fields of the commodity object
"externalId": "someCommodityExternalID",
"createdAt": "2024-04-11T15:09:28.023Z",
"createdBy": "d0235096-8c31-4212-8b0a-fbf1bd5bd00c",
"updatedAt": "2024-04-11T15:09:28.023Z",
"updatedBy": "d0235096-8c31-4212-8b0a-fbf1bd5bd00c",
"version": 1
}
- The
<id>
field contains the unique identifier assigned to the new record.
The HTTP status code is 201 (Created).
Error Response
If the upsert operation encounters a server-side issue, the API will return an error response. This error is not specific to duplicate external IDs but indicates a problem with the server's processing of the request:
{
"statusCode": 500,
"message": "Internal server error"
}
Upserting Existing Records
If a record with the provided <externalId>
already exists, the API will update the existing record with the new information provided in the request:
Example for updating the existing records
This example uses the PATCH
method to update an existing record. It assumes that an external ID field, such as <externalIdField>
, has been added to the Commodity object and a record with the given external ID value exists.
To update an existing record, send a PATCH
request with the necessary headers and JSON
payload.
Sample Request
curl --location --request PATCH '<http://xyzfreightcorp.roserocket.com/api/v2/platformModel/objects'>
--header 'Content-Type: application/json'
--header 'Authorization: Bearer <token>'
--data '{
"objectKey": "commodity",
"json": {
"externalId": "someCommodityExternalID",
"freightClass": "75"
}
}'
- Replace
<token>
with your actual authorization token. - The
<objectKey>
specifies the type of object you are working with, in this case, "commodity". - The
json
object contains the fields that are being updated for the record, including the<externalId>
.
Sample Response
The successful response will include details of the updated record, such as its unique identifier and the fields that were updated.
{
"id": "83a57ed2-d517-4c11-a046-f7ed764fc8c7",
"objectKey": "commodity",
"orgId": "e3127dc0-fc4d-4354-b65d-b3e846d80297",
"source": "manual",
"freightClass": "75",
// Other updated fields of the commodity object
"externalId": "someCommodityExternalID",
"createdAt": "2024-04-11T15:09:28.023Z",
"createdBy": "d0235096-8c31-4212-8b0a-fbf1bd5bd00c",
"updatedAt": "2024-04-11T15:27:28.943Z",
"updatedBy": "d0235096-8c31-4212-8b0a-fbf1bd5bd00c",
"version": 2
}
- The
<id>
field contains the unique identifier of the existing record that was updated.
Fetching Records With ExternalID
Records with <externalId>
can also be retrieved via the API.
Example for fetching an existing record
This example uses the GET
method to retrieve an existing record. This requires the <objectKey>
and the <externalId>
as path params.
To retrieve an existing record, send a GET
request with the required path params.
Sample Request
curl --location
'<http://xyzfreightcorp.roserocket.com/api/v2/platformModel/objects/><objectKey>/<externalId>/external'
--header 'Authorization: Bearer <token>'
--data ''
- Replace
<token>
with your actual authorization token. - The
<objectKey>
param should be replaced with the objectKey of the record to be fetched e.g. commodity. - The
<externalId>
param should be replaced with the external ID of the record to be fetched.
Sample Response
The successful response will include details of the retrieved record.
{
"id": "83a57ed2-d517-4c11-a046-f7ed764fc8c7",
"objectKey": "commodity",
"orgId": "e3127dc0-fc4d-4354-b65d-b3e846d80297",
"source": "manual",
"freightClass": "75",
// Other updated fields of the commodity object
"externalId": "someCommodityExternalID",
"createdAt": "2024-04-11T15:09:28.023Z",
"createdBy": "d0235096-8c31-4212-8b0a-fbf1bd5bd00c",
"updatedAt": "2024-04-11T15:27:28.943Z",
"updatedBy": "d0235096-8c31-4212-8b0a-fbf1bd5bd00c",
"version": 2
}
Limitation
Currently, the upsert functionality is not supported with POST
requests. If you attempt to use a POST request for upserting a record with an existing external ID, the operation will not be successful. It is recommended to use the PATCH
method for upsert operations.
Updated 14 days ago