Last Updated on January 21, 2025 by sandeeppote
data:image/s3,"s3://crabby-images/7efec/7efec76a7e1c71c66dff8d92782edb7028286fbf" alt=""
Prepare guest data file to upload
Prepare Json file
Take a sample guest data from here –
Sample data guest looks like this-
{
"ref":"b4b92667-54e9-444f-8f64-11672fe9843a",
"schema":"guest",
"mode":"upsert",
"value":{
"guestType":"customer",
"firstSeen":"2010-03-07T16:15:11.000Z",
"lastSeen":"2012-08-23T16:17:16.000Z",
"firstName": "Eager",
"lastName": "Benz",
"email": "eager.benz@malify.com",
"extensions":[
{
"name":"ext",
"key":"default",
"loyaltytier":"level2",
"rewardBalance":"50125"
}
]
}
}
{
"ref":"0cc6c80b-0b19-446f-9e14-579f75a96c4a",
"schema":"guest",
"mode":"upsert",
"value":{
"guestType":"customer",
"firstSeen":"2010-03-07T16:15:11.000Z",
"lastSeen":"2012-08-23T16:17:16.000Z",
"firstName": "Goofy",
"lastName": "Trovalds",
"email": "goofy.trovalds@malify.com",
"extensions":[
{
"name":"ext",
"key":"default",
"loyaltytier":"level3",
"rewardBalance":"50130"
}
]
}
}
Load the data in json file. Note that the above is a single row in a json and repeat the rows to upload multiple guets. This is not a json formatted file and should not have “,” to seperate rows as normally json file has. Highlighted email is important to identify the customer and add/update the extended data. This depends on the rule setup for your environment to identify the customer.
gzip the json file to upload
Example-
tar -czvf guest-upload.gz .\guest-upload.json
Generate MD5 File Checksum
Upload the gzip file to generate the check sum on this url –
https://emn178.github.io/online-tools/md5_checksum.html
data:image/s3,"s3://crabby-images/5de5a/5de5a131f0fb048ed45ee1cbf211cc402f924ece" alt=""
Prepare Pre-signed Request
Create a new guid for the below batch upload. This guid will be used to know the status of the batch upload.
https://api.boxever.com/v2/batches/<<your guid>>
Request body –
{
"checksum": "aaab5899b405bc3cb1d9b*******",
"size": 412
}
Setup the Basic Auth before sending the request-
data:image/s3,"s3://crabby-images/9789d/9789d2f252418b76d47bc15d3e9dc978fce0a67d" alt=""
Request after setting up Authentication and body-
data:image/s3,"s3://crabby-images/5d69a/5d69abb116ff164047ed1931e1e43feae855f3ef" alt=""
Response-
location – where the file needs to be uploaded. Will see this is next request where we actually upload file.
expiry – date time until the location to upload file is valid
data:image/s3,"s3://crabby-images/43d9b/43d9bec05f4fc1ea098cc83cfbeb29e64baaca74" alt=""
The response should be saved in environment with uploadURL and batchRef variable-
data:image/s3,"s3://crabby-images/443b3/443b3656e5792e023b25aad23cdaa8af4af44dd9" alt=""
Upload file
Upload URL request should contain the URL received from the pre-signed request-
data:image/s3,"s3://crabby-images/d2cb6/d2cb620c4e83a33736d46b06d1170a432129bd14" alt=""
Set the headers-
x-amz-server-side-encryption – AES256
Content-Md5 – <<Hex to Base checksum value>>
Content-Md5 is the Hex to Base64 converted value of checksum
Use this url to convert to base64-
https://base64.guru/converter/encode/hex
data:image/s3,"s3://crabby-images/7c13f/7c13fed429685e53fbe519798f99ad457d85afc4" alt=""
Request Headers should look like this-
The request signature we calculated does not match the signature you provided. Check your key and signing method.
data:image/s3,"s3://crabby-images/158d1/158d13de9166cdd08c5a70464463963104abfe13" alt=""
Send request to the provided URL with the attached gzip file and headers. Response 200 Ok
data:image/s3,"s3://crabby-images/bfb9a/bfb9a96162a0350da70b2e5fe08fa6a231ed4ec8" alt=""
Check the status of the uploaded file-
https://api.boxever.com/v2/batches/{{batchRef}}
The upload is queued and may take time depending on the items queued.
With the below request it shows the upload request is processing.
data:image/s3,"s3://crabby-images/0fa2d/0fa2dab301c171b555a55575a5456c933decf118" alt=""
This request took almost 2 hours to complete, and the response here is error where 1 of the guets is updated but opther failed.
data:image/s3,"s3://crabby-images/a00e4/a00e418743092c3fd10e12a809b0283cdc4e08c1" alt=""
This is the log, where you should be able to rectify any errors in json file-
data:image/s3,"s3://crabby-images/fc7ca/fc7cabe97cbfba14127498f6d23f45f2ca8a0061" alt=""
Lets check the other guest if available in portal-
data:image/s3,"s3://crabby-images/90435/90435d07ad32e8f145109f1fa02125bda3aaa636" alt=""
data:image/s3,"s3://crabby-images/5caee/5caeef2586ca34455ac4450e9437f3358ec5c3d0" alt=""
data:image/s3,"s3://crabby-images/27170/27170bc73150d0332e3d390449b39826b2f03593" alt=""
Errors–
data:image/s3,"s3://crabby-images/3b134/3b1345344d7b21de5ec44c67c92b4c69f3729024" alt=""
SignatureDoesNotMatch
data:image/s3,"s3://crabby-images/2221f/2221f7fffde5f5350b98a6bfb94d3cdc79adca96" alt=""
0 Comments
1 Pingback