typescript - 为什么我的 SendGrid 函数返回“服务不可用”?
问题描述
我是 SendGrid 的新手,并尝试使用我的后端的 Firebase Cloud 功能从我的 React.js 应用程序发送电子邮件。当有人想发送消息时,我会向 Firestore 写一个文档。然后我收听该集合,并在创建文档时从云功能发送电子邮件。
我正在尝试使其正常工作,但在我的云功能中不断出现错误并出现以下错误消息:
Error: Service Unavailable
at axios.then.catch.error (node_modules/@sendgrid/client/src/classes/client.js:133:29)
at <anonymous>
at process._tickDomainCallback (internal/process/next_tick.js:229:7)
编辑:我在 catch 语句中发现了错误,并获得了更多详细信息。这是完整的日志:
{ Error: Forbidden
at axios.then.catch.error (node_modules/@sendgrid/client/src/classes/client.js:133:29)
at <anonymous>
at process._tickDomainCallback (internal/process/next_tick.js:229:7)
code: 403,
message: 'Forbidden',
response:
{ headers:
{ server: 'nginx',
date: 'Thu, 11 Jun 2020 17:03:27 GMT',
'content-type': 'application/json',
'content-length': '281',
connection: 'close',
'access-control-allow-origin': 'https://sendgrid.api-docs.io',
'access-control-allow-methods': 'POST',
'access-control-allow-headers': 'Authorization, Content-Type, On-behalf-of, x-sg-elas-acl',
'access-control-max-age': '600',
'x-no-cors-reason': 'https://sendgrid.com/docs/Classroom/Basics/API/cors.html' },
body: { errors: [Array] } } }
编辑 2:所以我已经按照错误中的链接进行https://sendgrid.com/docs/for-developers/sending-email/cors/
操作,如果我做对了,它表明它阻止了我,因为我试图对他们的 API 进行基于浏览器的调用?但事实并非如此。我正在从云功能拨打电话。
我不知道我是否做错了什么,或者我只是不走运并且在 SendGrid 遇到一些问题时第一次尝试实现它(Service Unavailable
)。
这就是我定义 sgMail 的方式:
import * as sgMail from "@sendgrid/mail";
const SENDGRID_API_KEY = functions.config().sendgridfull.key;
sgMail.setApiKey(SENDGRID_API_KEY);
这是我的云函数,我检查了所有变量,它们都存在。
exports.firestoreEmail = functions.firestore
.document("email_messages/{messageID}")
.onCreate((snap, context) => {
const msgData = snap.data();
if (!msgData) return;
return db
.collection("users")
.doc(msgData.recipient_ID)
.get()
.then((doc) => {
const recipientData = doc.data();
if (!recipientData) return;
const promises: any = [];
const msg = {
to: recipientData.email,
from: msgData.sender_email,
templateId: "d-myRandomTemplateId",
dynamic_template_data: {
sender_name: "Some One",
},
};
const msg2 = {
to: msgData.sender_email,
from: recipientData.email,
templateId: "d-myRandomTemplateId",
dynamic_template_data: {
sender_name: "Some One",
},
};
promises.push(sgMail.send(msg));
promises.push(sgMail.send(msg2));
return Promise.all(promises);
});
});
解决方案
请检查这个github 问题,它指定如何使用导致云功能返回服务不可用错误的 sgMail.send 方法。
send 和 sendMultiple 方法返回一个 Promise,因此您可以处理成功并捕获错误:
sgMail
.send(msg)
.then(() => {
// Celebrate
})
.catch(error => {
// Log friendly error
console.error(error);
if (error.response) {
// Extract error msg
const {message, code, response} = error;
// Extract response msg
const {headers, body} = response;
console.error(body);
}
});
或者,您可以将回调函数作为最后一个参数传递:
sgMail
.send(msg, (error, result) => {
if (error) {
// Do something with the error
}
else {
// Celebrate
}
});
请让我知道它是否有效。
推荐阅读
- python - 在 Tensorflow 急切模式下计算模型输入的梯度
- php - 取消链接不会删除文件
- python - 将嵌套列表与数据框匹配
- android - shouldShowRequestPermissionRationale 为假
- r - R中表格的条件格式...更好的方法?
- javascript - 在 HTML 中包含 PHP
- wordpress - 使用多个过滤器过滤管理员帖子列表;如何使用逻辑 AND 运算符构造查询对象
- php - 在现有的 Laravel 混合中添加 vue-loader 时遇到问题
- python - 帕累托优化前沿
- java - org.jboss.weld.exceptions.UnsatisfiedResolutionException WELD-001334 带有限定符 @Any @MyAnnotation 的类型 MyInterface 的依赖关系不满足