问题描述
我可以在PC上使用此代码,但是当我使用lambda时出现错误。我正在尝试将证书添加到模板。该证书是从s3获得的,没有任何问题。我将其添加到模板的部分会导致错误。这是通过库walletpass / pass-js完成的。
exports.handler = async (event) => {
// Todo implement
const s3file = await s3
.getobject({
Bucket: bucketName,Key: "template.zip"
})
.promise();
var template = await Template.fromBuffer(s3file.Body);
//console.log(template)
const s3fileCert = await s3
.getobject({
Bucket: bucketName,Key: "template/PassCertificates.pem"
})
.promise();
var cert = s3fileCert.Body.toString();
console.log('cert',cert);
await template.loadCertificate(
cert,"Something852"
). then((response) => {
console.log("response",response)
})
}
这是我从Lambda得到的错误
2020-10-04T16:21:25.271+08:00
copy
2020-10-04T08:21:25.271Z 590ccac3-1c67-4c17-8846-3205d7c1de59 ERROR Invoke Error
{
"errorType": "Error","errorMessage": "ENAMetoOLONG: name too long,open 'Bag Attributes\n friendlyName: Pass Type ID: pass.example.com\n localKeyID: AA 07 69 E8 B2 E8 0D 20 E8 63 81 C9 54 9B 25 A9 1B 1B 38 0B \nsubject=/UID=pass.example.com/CN=Pass Type ID: pass.example.com/OU=855EF5E
"code": "ENAMetoOLONG","errno": -36,"syscall": "open",
解决方法
这里的问题是您似乎已经将实际证书作为字符串传入,而实际上第一个参数正在寻找证书的路径:
示例:
await template.loadCertificate(
"/etc/passbook/certificate_and_key.pem","secret"
);
相反,您应该尝试使用他们文档中提到的 setCertificate
方法:https://github.com/walletpass/pass-js
template.setCertificate(cert);