I'm trying to retrieve Secret Value from AWS Secret Manager using aws-sdk for Javascript, I'm using the code snippet provided by Secret Manager, I have included this code in Lambda function, but I can't see any console logs defined inside the callback function. Here's the lambda code:
exports.handler = async (event, context) => {
const AWS = require('aws-sdk');
const client = new AWS.SecretsManager({ region: "eu-west-2" });
let secret;
let decodedBinarySecret;
console.log('STARTED');
client.getSecretValue({ SecretId: "MagellanDev" }, function (err, data) {
if (err) {
console.log('Got Error: ', err.code);
throw err;
}
else {
if ('SecretString' in data) {
secret = data.SecretString;
} else {
let buff = new Buffer(data.SecretBinary, 'base64');
decodedBinarySecret = buff.toString('ascii');
}
}
console.log("SECRET: ", secret);
console.log("DECODEBINARYSECRET: ", decodedBinarySecret)
});
console.log('ended');
};
Output:
Started
ended
I'm trying to retrieve Secret Value from AWS Secret Manager using aws-sdk for Javascript, I'm using the code snippet provided by Secret Manager, I have included this code in Lambda function, but I can't see any console logs defined inside the callback function. Here's the lambda code:
exports.handler = async (event, context) => {
const AWS = require('aws-sdk');
const client = new AWS.SecretsManager({ region: "eu-west-2" });
let secret;
let decodedBinarySecret;
console.log('STARTED');
client.getSecretValue({ SecretId: "MagellanDev" }, function (err, data) {
if (err) {
console.log('Got Error: ', err.code);
throw err;
}
else {
if ('SecretString' in data) {
secret = data.SecretString;
} else {
let buff = new Buffer(data.SecretBinary, 'base64');
decodedBinarySecret = buff.toString('ascii');
}
}
console.log("SECRET: ", secret);
console.log("DECODEBINARYSECRET: ", decodedBinarySecret)
});
console.log('ended');
};
Output:
Started
ended
Share Improve this question edited Apr 8, 2020 at 13:58 kzrfaisal asked Apr 8, 2020 at 10:51 kzrfaisalkzrfaisal 1,4435 gold badges17 silver badges27 bronze badges 6- Any errors in the CloudWatch Logs ? – Marcin Commented Apr 8, 2020 at 11:01
- I would expect to see 'Started' immediately followed by 'ended' in the logs. That's a consequence of how JavaScript async/callbacks works. Do you see any CloudWatch Logs after 'ended' and up to the 'END RequestId: xxx'? – jarmod Commented Apr 8, 2020 at 12:58
- no log till end request – kzrfaisal Commented Apr 8, 2020 at 13:35
- no errors in cloudwatch – kzrfaisal Commented Apr 8, 2020 at 13:46
- Was the Lambda terminated at 3 seconds with a timeout? – jarmod Commented Apr 8, 2020 at 15:21
1 Answer
Reset to default 10The problem is that you have specified the function handler as async
. If you want to use callbacks, then use the older style function handler:
exports.handler = function(event, context, callback) {
// ...
}
The code has exited before the getSecretValue()
function has pleted and had a chance to make the callback. And because your function is async
and you did not return a Promise, the Lambda runtime is not waiting.
I would move away from the older callback-style code and move to the newer async/await-style code, for example:
const AWS = require('aws-sdk');
const client = new AWS.SecretsManager({region: 'us-east-1'});
exports.handler = async (event, context) => {
const params = {SecretId: secretName};
return client.getSecretValue(params).promise();
};