How to make it so that it sends out the pdf only after the pdf is generated using async await
How to make the mail transporter to wait until the pdf is generated?
I attached the code that I have tried. My browser hangs and failed to send out the email. The issue is that the mail transporter tries to send out email before the pdf is generated. I am guessing that I did not use the async and await at the right place.
async () => {
await pdf.create(document, options).then(res => {
console.log(res)
}).catch(error => {
console.error(error)
})
let message = "Testing"
let mailOptions = {
from: "xxx@gmail.com",
to: "yyy@gmail.com",
subject: 'Subject testing',
text: message,
attachments: [{
path: __dirname + '/../public/reports/' + 'test.pdf',
}]
}
await transporter.sendMail(mailOptions, (error, info) => {
if (error) {
console.log(error);
} else {
console.log("sent email")
res.json({
email: "sent"
});
}
})
}
node.js express asynchronous pdf-generation sendmail
add a comment |
How to make the mail transporter to wait until the pdf is generated?
I attached the code that I have tried. My browser hangs and failed to send out the email. The issue is that the mail transporter tries to send out email before the pdf is generated. I am guessing that I did not use the async and await at the right place.
async () => {
await pdf.create(document, options).then(res => {
console.log(res)
}).catch(error => {
console.error(error)
})
let message = "Testing"
let mailOptions = {
from: "xxx@gmail.com",
to: "yyy@gmail.com",
subject: 'Subject testing',
text: message,
attachments: [{
path: __dirname + '/../public/reports/' + 'test.pdf',
}]
}
await transporter.sendMail(mailOptions, (error, info) => {
if (error) {
console.log(error);
} else {
console.log("sent email")
res.json({
email: "sent"
});
}
})
}
node.js express asynchronous pdf-generation sendmail
You can onlyawait
a promise. You need to use promises.
– SLaks
Jan 3 at 18:21
Thanks for telling me. The await in the transporter.sendMail is not doing anything.
– calvert
Jan 3 at 18:35
add a comment |
How to make the mail transporter to wait until the pdf is generated?
I attached the code that I have tried. My browser hangs and failed to send out the email. The issue is that the mail transporter tries to send out email before the pdf is generated. I am guessing that I did not use the async and await at the right place.
async () => {
await pdf.create(document, options).then(res => {
console.log(res)
}).catch(error => {
console.error(error)
})
let message = "Testing"
let mailOptions = {
from: "xxx@gmail.com",
to: "yyy@gmail.com",
subject: 'Subject testing',
text: message,
attachments: [{
path: __dirname + '/../public/reports/' + 'test.pdf',
}]
}
await transporter.sendMail(mailOptions, (error, info) => {
if (error) {
console.log(error);
} else {
console.log("sent email")
res.json({
email: "sent"
});
}
})
}
node.js express asynchronous pdf-generation sendmail
How to make the mail transporter to wait until the pdf is generated?
I attached the code that I have tried. My browser hangs and failed to send out the email. The issue is that the mail transporter tries to send out email before the pdf is generated. I am guessing that I did not use the async and await at the right place.
async () => {
await pdf.create(document, options).then(res => {
console.log(res)
}).catch(error => {
console.error(error)
})
let message = "Testing"
let mailOptions = {
from: "xxx@gmail.com",
to: "yyy@gmail.com",
subject: 'Subject testing',
text: message,
attachments: [{
path: __dirname + '/../public/reports/' + 'test.pdf',
}]
}
await transporter.sendMail(mailOptions, (error, info) => {
if (error) {
console.log(error);
} else {
console.log("sent email")
res.json({
email: "sent"
});
}
})
}
node.js express asynchronous pdf-generation sendmail
node.js express asynchronous pdf-generation sendmail
asked Jan 3 at 18:18
calvertcalvert
1148
1148
You can onlyawait
a promise. You need to use promises.
– SLaks
Jan 3 at 18:21
Thanks for telling me. The await in the transporter.sendMail is not doing anything.
– calvert
Jan 3 at 18:35
add a comment |
You can onlyawait
a promise. You need to use promises.
– SLaks
Jan 3 at 18:21
Thanks for telling me. The await in the transporter.sendMail is not doing anything.
– calvert
Jan 3 at 18:35
You can only
await
a promise. You need to use promises.– SLaks
Jan 3 at 18:21
You can only
await
a promise. You need to use promises.– SLaks
Jan 3 at 18:21
Thanks for telling me. The await in the transporter.sendMail is not doing anything.
– calvert
Jan 3 at 18:35
Thanks for telling me. The await in the transporter.sendMail is not doing anything.
– calvert
Jan 3 at 18:35
add a comment |
1 Answer
1
active
oldest
votes
I figured it out. I didn't call the function so the operation is not being executed. I removed the await in the transporter.sendMail because it is not doing anything.
sendPDF();
async function sendPDF() {
await pdf.create(document, options).then(res => {
console.log(res)
}).catch(error => {
console.error(error)
})
let message = "Testing"
let mailOptions = {
from: "xxx@gmail.com",
to: "yyy@gmail.com",
subject: 'Subject testing',
text: message,
attachments: [{
path: __dirname + '/../public/reports/' + 'test.pdf',
}]
}
transporter.sendMail(mailOptions, (error, info) => {
if (error) {
console.log(error);
} else {
console.log("sent email")
res.json({
email: "sent"
});
}
})
}
add a comment |
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f54027715%2fhow-to-make-it-so-that-it-sends-out-the-pdf-only-after-the-pdf-is-generated-usin%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
I figured it out. I didn't call the function so the operation is not being executed. I removed the await in the transporter.sendMail because it is not doing anything.
sendPDF();
async function sendPDF() {
await pdf.create(document, options).then(res => {
console.log(res)
}).catch(error => {
console.error(error)
})
let message = "Testing"
let mailOptions = {
from: "xxx@gmail.com",
to: "yyy@gmail.com",
subject: 'Subject testing',
text: message,
attachments: [{
path: __dirname + '/../public/reports/' + 'test.pdf',
}]
}
transporter.sendMail(mailOptions, (error, info) => {
if (error) {
console.log(error);
} else {
console.log("sent email")
res.json({
email: "sent"
});
}
})
}
add a comment |
I figured it out. I didn't call the function so the operation is not being executed. I removed the await in the transporter.sendMail because it is not doing anything.
sendPDF();
async function sendPDF() {
await pdf.create(document, options).then(res => {
console.log(res)
}).catch(error => {
console.error(error)
})
let message = "Testing"
let mailOptions = {
from: "xxx@gmail.com",
to: "yyy@gmail.com",
subject: 'Subject testing',
text: message,
attachments: [{
path: __dirname + '/../public/reports/' + 'test.pdf',
}]
}
transporter.sendMail(mailOptions, (error, info) => {
if (error) {
console.log(error);
} else {
console.log("sent email")
res.json({
email: "sent"
});
}
})
}
add a comment |
I figured it out. I didn't call the function so the operation is not being executed. I removed the await in the transporter.sendMail because it is not doing anything.
sendPDF();
async function sendPDF() {
await pdf.create(document, options).then(res => {
console.log(res)
}).catch(error => {
console.error(error)
})
let message = "Testing"
let mailOptions = {
from: "xxx@gmail.com",
to: "yyy@gmail.com",
subject: 'Subject testing',
text: message,
attachments: [{
path: __dirname + '/../public/reports/' + 'test.pdf',
}]
}
transporter.sendMail(mailOptions, (error, info) => {
if (error) {
console.log(error);
} else {
console.log("sent email")
res.json({
email: "sent"
});
}
})
}
I figured it out. I didn't call the function so the operation is not being executed. I removed the await in the transporter.sendMail because it is not doing anything.
sendPDF();
async function sendPDF() {
await pdf.create(document, options).then(res => {
console.log(res)
}).catch(error => {
console.error(error)
})
let message = "Testing"
let mailOptions = {
from: "xxx@gmail.com",
to: "yyy@gmail.com",
subject: 'Subject testing',
text: message,
attachments: [{
path: __dirname + '/../public/reports/' + 'test.pdf',
}]
}
transporter.sendMail(mailOptions, (error, info) => {
if (error) {
console.log(error);
} else {
console.log("sent email")
res.json({
email: "sent"
});
}
})
}
answered Jan 3 at 18:38
calvertcalvert
1148
1148
add a comment |
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f54027715%2fhow-to-make-it-so-that-it-sends-out-the-pdf-only-after-the-pdf-is-generated-usin%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
You can only
await
a promise. You need to use promises.– SLaks
Jan 3 at 18:21
Thanks for telling me. The await in the transporter.sendMail is not doing anything.
– calvert
Jan 3 at 18:35