私はs3(パブリック)を介していくつかの証明書ファイルを持っています。これらのファイルをダウンロードして自分のコードで使用します。同等のコードをローカルのnodejsで作成すると、問題なく実行されますが、AWS lambdaではクラッシュします。
var apn = require('apn');
var https = require('https');
var fs = require('fs');
exports.handler = function(event, context) {
console.log("Running aws apn Push message function");
console.log("==================================");
console.log("event", event);
var certPath = event.certPath;
var keyPath = event.keyPath;
var certFileName = event.certFileName;
var keyFileName = event.keyFileName;
var passphrase = event.passphrase;
var apnId = event.apnId;
var content = event.content;
var certfile = fs.createWriteStream(certFileName);
var certrequest = https.get(certPath, function(certresponse) {
certresponse.pipe(certfile);
console.log("downloaded the certificate");
var keyfile = fs.createWriteStream(keyFileName);
var keyrequest = https.get(keyPath, function(keyresponse) {
keyresponse.pipe(keyfile);
console.log("downloaded the key file");
var options = {
"cert":certFileName,
"key":keyFileName,
"passphrase":passphrase,
"batchFeedback": true,
"interval": 10
};
var apnConnection = new apn.Connection(options);
var myDevice = new apn.Device(apnId);
var note = new apn.Notification();
note.expiry = Math.floor(Date.now() / 1000) + 3600; // Expires 1 hour from now.
note.payload = {'COMMAND': content};
apnConnection.pushNotification(note, myDevice);
console.log('message sent to ' + apnId);
context.done();
});
});
}
私が得るエラーは私が推測するファイルへのアクセスに関連しています-
events.js:72
throw er; // Unhandled 'error' event
^
Error: EACCES, open 'PushChatCert.pem'
AWS Lambdaでは、ファイルをダウンロードして使用するときに、そのパスなどに関連して、ファイルがダウンロードされたときにファイルがどこに留まるかという特定の懸念がありますが、実際にはファイルのログが表示されませんダウンロードしました。
Lambdaで書き込むことができる唯一の使用可能なローカルファイルシステムは/ tmpであるため、書き込み先のローカルファイルのパスが/ tmpディレクトリにあり、すべて設定されていることを確認してください。