Given some DynamoDB JSON via a DynamoDB NewImage
stream event, how do I unmarshall it to regular JSON?
{"updated_at":{"N":"146548182"},"uuid":{"S":"foo"},"status":{"S":"new"}}
Normally I would use AWS.DynamoDB.DocumentClient, however I can't seem to find a generic Marshall/Unmarshall function.
Sidenote: Do I lose anything unmarshalling DynamoDB JSON to JSON and back again?
The latest Amazon DynamoDB update added support for JSON data, making it easy to store JSON documents in a DynamoDB table while preserving their complex and possibly nested shape.
marshall(data, options) ⇒ map Convert a JavaScript object into a DynamoDB record. Examples: Convert a JavaScript object into a DynamoDB record.
The AWS SDKs use JSON to send data to DynamoDB, and DynamoDB responds with JSON.
You can use the AWS.DynamoDB.Converter.unmarshall
function. Calling the following will return { updated_at: 146548182, uuid: 'foo', status: 'new' }
:
AWS.DynamoDB.Converter.unmarshall({ "updated_at":{"N":"146548182"}, "uuid":{"S":"foo"}, "status":{"S":"new"} })
Everything that can be modeled in DynamoDB's marshalled JSON format can be safely translated to and from JS objects.
AWS SDK for JavaScript version 3 (V3) provides nice methods for marshalling and unmarshalling DynamoDB records reliably.
const { marshall, unmarshall } = require("@aws-sdk/util-dynamodb");
const dynamo_json = { "updated_at": { "N": "146548182" }, "uuid": { "S": "foo" }, "status": { "S": "new" } };
const to_regular_json = unmarshall(dynamo_json);
const back_to_dynamo_json = marshall(to_regular_json);
Output:
// dynamo_json
{
updated_at: { N: '146548182' },
uuid: { S: 'foo' },
status: { S: 'new' }
}
// to_regular_json
{ updated_at: 146548182, uuid: 'foo', status: 'new' }
// back_to_dynamo_json
{
updated_at: { N: '146548182' },
uuid: { S: 'foo' },
status: { S: 'new' }
}
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With