Merge pull request 'refactor: move to new mailer' (#209) from refactor/new-mailer into dev
Reviewed-on: #209 Reviewed-by: Nicolai Ort <info@nicolai-ort.com>
This commit is contained in:
commit
bda1f971d1
@ -8,3 +8,4 @@ DB_NAME=./test.sqlite
|
|||||||
NODE_ENV=production
|
NODE_ENV=production
|
||||||
POSTALCODE_COUNTRYCODE=DE
|
POSTALCODE_COUNTRYCODE=DE
|
||||||
SEED_TEST_DATA=false
|
SEED_TEST_DATA=false
|
||||||
|
SELFSERVICE_URL=bla
|
@ -59,6 +59,7 @@ pnpm docs
|
|||||||
| SEED_TEST_DATA | Boolean | False | If you want the app to seed some example data set this to true |
|
| SEED_TEST_DATA | Boolean | False | If you want the app to seed some example data set this to true |
|
||||||
| MAILER_URL | String(Url) | N/A | The mailer's base url (no trailing slash) |
|
| MAILER_URL | String(Url) | N/A | The mailer's base url (no trailing slash) |
|
||||||
| MAILER_KEY | String | N/A | The mailer's api key. |
|
| MAILER_KEY | String | N/A | The mailer's api key. |
|
||||||
|
| SELFSERVICE_URL | String(Url) | N/A | The link to selfservice (no trailing slash) |
|
||||||
| IMPRINT_URL | String(Url) | /imprint | The link to a imprint page for the system (Defaults to the frontend's imprint) |
|
| IMPRINT_URL | String(Url) | /imprint | The link to a imprint page for the system (Defaults to the frontend's imprint) |
|
||||||
| PRIVACY_URL | String(Url) | /privacy | The link to a privacy page for the system (Defaults to the frontend's privacy page) |
|
| PRIVACY_URL | String(Url) | /privacy | The link to a privacy page for the system (Defaults to the frontend's privacy page) |
|
||||||
|
|
||||||
|
@ -131,7 +131,7 @@ export class RunnerSelfServiceController {
|
|||||||
const token = JwtCreator.createSelfService(runner);
|
const token = JwtCreator.createSelfService(runner);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
await Mailer.sendSelfserviceForgottenMail(runner.email, token, locale)
|
await Mailer.sendSelfserviceForgottenMail(runner.email, runner.id, runner.firstname, runner.middlename, runner.lastname, token, locale)
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
throw new MailSendingError();
|
throw new MailSendingError();
|
||||||
}
|
}
|
||||||
@ -157,7 +157,7 @@ export class RunnerSelfServiceController {
|
|||||||
response.token = JwtCreator.createSelfService(runner);
|
response.token = JwtCreator.createSelfService(runner);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
await Mailer.sendSelfserviceWelcomeMail(runner.email, response.token, locale)
|
await Mailer.sendSelfserviceWelcomeMail(runner.email, runner.id, runner.firstname, runner.middlename, runner.lastname, response.token, locale)
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
throw new MailSendingError();
|
throw new MailSendingError();
|
||||||
}
|
}
|
||||||
@ -182,7 +182,7 @@ export class RunnerSelfServiceController {
|
|||||||
response.token = JwtCreator.createSelfService(runner);
|
response.token = JwtCreator.createSelfService(runner);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
await Mailer.sendSelfserviceWelcomeMail(runner.email, response.token, locale)
|
await Mailer.sendSelfserviceWelcomeMail(runner.email, runner.id, runner.firstname, runner.middlename, runner.lastname, response.token, locale)
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
throw new MailSendingError();
|
throw new MailSendingError();
|
||||||
}
|
}
|
||||||
|
@ -18,9 +18,19 @@ export class Mailer {
|
|||||||
*/
|
*/
|
||||||
public static async sendResetMail(to_address: string, token: string, locale: string = "en") {
|
public static async sendResetMail(to_address: string, token: string, locale: string = "en") {
|
||||||
try {
|
try {
|
||||||
await axios.post(`${Mailer.base}/reset?locale=${locale}&key=${Mailer.key}`, {
|
await axios.request({
|
||||||
address: to_address,
|
method: 'POST',
|
||||||
resetKey: token
|
url: `${Mailer.base}/api/v1/email`,
|
||||||
|
headers: {
|
||||||
|
authorization: `Bearer ${Mailer.key}`,
|
||||||
|
'content-type': 'application/json'
|
||||||
|
},
|
||||||
|
data: {
|
||||||
|
to: to_address,
|
||||||
|
templateName: 'password-reset',
|
||||||
|
language: locale,
|
||||||
|
data: { token: token }
|
||||||
|
}
|
||||||
});
|
});
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
if (Mailer.testing) { return true; }
|
if (Mailer.testing) { return true; }
|
||||||
@ -32,12 +42,26 @@ export class Mailer {
|
|||||||
* Function for sending a runner selfservice welcome mail.
|
* Function for sending a runner selfservice welcome mail.
|
||||||
* @param to_address The address the mail will be sent to. Should always get pulled from a runner object.
|
* @param to_address The address the mail will be sent to. Should always get pulled from a runner object.
|
||||||
* @param token The requested selfservice token - will be combined with the app_url to generate a selfservice profile link.
|
* @param token The requested selfservice token - will be combined with the app_url to generate a selfservice profile link.
|
||||||
*/
|
*/
|
||||||
public static async sendSelfserviceWelcomeMail(to_address: string, token: string, locale: string = "en") {
|
public static async sendSelfserviceWelcomeMail(to_address: string, runner_id: number, firstname: string, middlename: string, lastname: string, token: string, locale: string = "en") {
|
||||||
try {
|
try {
|
||||||
await axios.post(`${Mailer.base}/registration?locale=${locale}&key=${Mailer.key}`, {
|
await axios.request({
|
||||||
address: to_address,
|
method: 'POST',
|
||||||
selfserviceToken: token
|
url: `${Mailer.base}/api/v1/email`,
|
||||||
|
headers: {
|
||||||
|
authorization: `Bearer ${Mailer.key}`,
|
||||||
|
'content-type': 'application/json'
|
||||||
|
},
|
||||||
|
data: {
|
||||||
|
to: to_address,
|
||||||
|
templateName: 'welcome',
|
||||||
|
language: locale,
|
||||||
|
data: {
|
||||||
|
name: `${firstname} ${middlename} ${lastname}`,
|
||||||
|
barcode_content: `${runner_id}`,
|
||||||
|
link: `${process.env.SELFSERVICE_URL}/profile/${token}`
|
||||||
|
}
|
||||||
|
}
|
||||||
});
|
});
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
if (Mailer.testing) { return true; }
|
if (Mailer.testing) { return true; }
|
||||||
@ -49,12 +73,26 @@ export class Mailer {
|
|||||||
* Function for sending a runner selfservice link forgotten mail.
|
* Function for sending a runner selfservice link forgotten mail.
|
||||||
* @param to_address The address the mail will be sent to. Should always get pulled from a runner object.
|
* @param to_address The address the mail will be sent to. Should always get pulled from a runner object.
|
||||||
* @param token The requested selfservice token - will be combined with the app_url to generate a selfservice profile link.
|
* @param token The requested selfservice token - will be combined with the app_url to generate a selfservice profile link.
|
||||||
*/
|
*/
|
||||||
public static async sendSelfserviceForgottenMail(to_address: string, token: string, locale: string = "en") {
|
public static async sendSelfserviceForgottenMail(to_address: string, runner_id: number, firstname: string, middlename: string, lastname: string, token: string, locale: string = "en") {
|
||||||
try {
|
try {
|
||||||
await axios.post(`${Mailer.base}/registration_forgot?locale=${locale}&key=${Mailer.key}`, {
|
await axios.request({
|
||||||
address: to_address,
|
method: 'POST',
|
||||||
selfserviceToken: token
|
url: `${Mailer.base}/api/v1/email`,
|
||||||
|
headers: {
|
||||||
|
authorization: `Bearer ${Mailer.key}`,
|
||||||
|
'content-type': 'application/json'
|
||||||
|
},
|
||||||
|
data: {
|
||||||
|
to: to_address,
|
||||||
|
templateName: 'welcome',
|
||||||
|
language: locale,
|
||||||
|
data: {
|
||||||
|
name: `${firstname} ${middlename} ${lastname}`,
|
||||||
|
barcode_content: `${runner_id}`,
|
||||||
|
link: `${process.env.SELFSERVICE_URL}/profile/${token}`
|
||||||
|
}
|
||||||
|
}
|
||||||
});
|
});
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
if (Mailer.testing) { return true; }
|
if (Mailer.testing) { return true; }
|
||||||
|
Loading…
x
Reference in New Issue
Block a user