I'm new to dynamoDB and I'm trying to write some data to the table using Lambda. So far I have this:
'AddFood': function () {
    var FoodName = this.event.request.intent.slots.FoodName.value;
    var FoodCalories = this.event.request.intent.slots.FoodCalories.value;
    console.log('FoodName : ' + FoodName);
    const params = {
        TableName: 'Foods',
        Item: {
            'id': {"S": 3},
            'calories': {"S": FoodCalories},
            'food': {"S": FoodName}
            }
    };
    writeDynamoItem(params, myResult=>{
        var say = '';
        say = myResult;
        say = FoodName + ' with ' + FoodCalories + ' calories has been added ';
        this.response.speak(say).listen('try again');
        this.emit(':responseReady');
    });
    function writeDynamoItem(params, callback) {
        var AWS = require('aws-sdk');
        AWS.config.update({region: AWSregion});
        var docClient = new AWS.DynamoDB();
        console.log('writing item to DynamoDB table');
        docClient.putItem(params, function (err, data) {
            if (err) {
                callback(err, null)
            } else {
               callback(null, data)
            }
        });
    }
}
Does anyone know why the data is not appearing in the database? I have checked the IAM and the policy is set to AmazonDynamoDBFullAccess.