-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Fixed file sturucture and incorporated feedback
- Loading branch information
Showing
12 changed files
with
973 additions
and
871 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,14 +1,7 @@ | ||
import { Post, Body, Controller } from '@nestjs/common'; | ||
import { Controller } from '@nestjs/common'; | ||
import { AppService } from './app.service'; | ||
import { EmailProto } from 'juno-proto'; | ||
|
||
@Controller() | ||
export class AppController { | ||
constructor(private readonly appService: AppService) {} | ||
@Post('/register-sender') | ||
async registerSender( | ||
@Body() req: EmailProto.RegisterSenderRequest, | ||
): Promise<EmailProto.RegisterSenderResponse> { | ||
return await this.appService.registerSender(req); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,55 +1,4 @@ | ||
import { Injectable } from '@nestjs/common'; | ||
import { EmailProto } from 'juno-proto'; | ||
import axios from 'axios'; | ||
import { RpcException } from '@nestjs/microservices'; | ||
|
||
@Injectable() | ||
export class AppService { | ||
async registerSender( | ||
req: EmailProto.RegisterSenderRequest, | ||
): Promise<EmailProto.RegisterEmailResponse> { | ||
if (!req.from_email) { | ||
throw new RpcException('Cannot register sender (no email supplied)'); | ||
} | ||
if (!req.from_name) { | ||
throw new RpcException('Cannot register sender (no name supplied)'); | ||
} | ||
if (!req.reply_to) { | ||
throw new RpcException('Cannot register sender (no reply to specified)'); | ||
} | ||
|
||
const sendgridApiKey = process.env.SENDGRID_API_KEY; | ||
|
||
if (!sendgridApiKey) { | ||
throw new RpcException( | ||
'Cannot register sender (sendgrid API key is missing)', | ||
); | ||
} | ||
const sendgridUrl = 'https://api.sendgrid.com/v3/verified_senders'; | ||
|
||
try { | ||
const res = await axios.post( | ||
sendgridUrl, | ||
{ | ||
from_email: req.from_email, | ||
from_name: req.from_name, | ||
reply_to: req.reply_to, | ||
}, | ||
{ | ||
headers: { | ||
Authorization: `Bearer ${sendgridApiKey}`, | ||
'Content-Type': 'application/json', | ||
}, | ||
}, | ||
); | ||
|
||
return { | ||
statusCode: res.status, | ||
message: 'Sender registered successfully', | ||
}; | ||
} catch (err) { | ||
console.error('error registering sender:', err); | ||
throw new RpcException('Unable to register sender'); | ||
} | ||
} | ||
} | ||
export class AppService {} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
13 changes: 13 additions & 0 deletions
13
packages/email-service/src/modules/email/email.controller.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
import { Body, Controller } from '@nestjs/common'; | ||
import { EmailService } from './email.service'; | ||
import { EmailProto } from 'juno-proto'; | ||
|
||
@Controller() | ||
export class EmailController { | ||
constructor(private emailService: EmailService) {} | ||
async registerSender( | ||
@Body() req: EmailProto.RegisterSenderRequest, | ||
): Promise<EmailProto.RegisterSenderResponse> { | ||
return await this.emailService.registerSender(req); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
import { Module } from '@nestjs/common'; | ||
import { EmailController } from './email.controller'; | ||
import { EmailService } from './email.service'; | ||
import { SendGridService } from '../../sendgrid.service'; | ||
|
||
@Module({ | ||
controllers: [EmailController], | ||
providers: [EmailService, SendGridService], | ||
}) | ||
export class EmailModule {} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,59 @@ | ||
import { Injectable } from '@nestjs/common'; | ||
import { EmailProto } from 'juno-proto'; | ||
import axios from 'axios'; | ||
import { RpcException } from '@nestjs/microservices'; | ||
|
||
@Injectable() | ||
export class EmailService { | ||
async registerSender( | ||
req: EmailProto.RegisterSenderRequest, | ||
): Promise<EmailProto.RegisterSenderResponse> { | ||
if (process.env.SENDGRID_API_KEY) { | ||
if (!req.fromEmail) { | ||
throw new RpcException('Cannot register sender (no email supplied)'); | ||
} | ||
if (!req.fromName) { | ||
throw new RpcException('Cannot register sender (no name supplied)'); | ||
} | ||
if (!req.replyTo) { | ||
throw new RpcException( | ||
'Cannot register sender (no reply to specified)', | ||
); | ||
} | ||
|
||
const sendgridApiKey = process.env.SENDGRID_API_KEY; | ||
const sendgridUrl = 'https://api.sendgrid.com/v3/verified_senders'; | ||
|
||
if (!sendgridApiKey) { | ||
throw new RpcException( | ||
'Cannot register sender (sendgrid API key is missing)', | ||
); | ||
} | ||
|
||
try { | ||
const res = await axios.post( | ||
sendgridUrl, | ||
{ | ||
fromEmail: req.fromEmail, | ||
fromName: req.fromName, | ||
replyTo: req.replyTo, | ||
}, | ||
{ | ||
headers: { | ||
Authorization: `Bearer ${sendgridApiKey}`, | ||
'Content-Type': 'application/json', | ||
}, | ||
}, | ||
); | ||
|
||
return { | ||
statusCode: res.status, | ||
message: 'Sender registered successfully', | ||
}; | ||
} catch (err) { | ||
console.error('error registering sender:', err); | ||
throw new RpcException('Unable to register sender'); | ||
} | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
import { Injectable, OnModuleInit } from '@nestjs/common'; | ||
import { MailService as SendGridMailService } from '@sendgrid/mail'; | ||
|
||
@Injectable() | ||
export class SendGridService | ||
extends SendGridMailService | ||
implements OnModuleInit | ||
{ | ||
async onModuleInit() { | ||
if (process.env.SENDGRID_API_KEY) { | ||
this.setApiKey(process.env.SENDGRID_API_KEY); | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -38,12 +38,20 @@ beforeAll(async () => { | |
|
||
const protoGRPC = GRPC.loadPackageDefinition(proto) as any; | ||
|
||
const resetClient = new protoGRPC.juno.reset_db.DatabaseReset( | ||
process.env.DB_SERVICE_ADDR, | ||
GRPC.credentials.createInsecure(), | ||
); | ||
|
||
const emailClient = new protoGRPC.juno.emailService( | ||
process.env.DB_SERVICE_ADDR, | ||
GRPC.credentials.createInsecure(), | ||
); | ||
|
||
await new Promise((resolve) => { | ||
resetClient.resetDb({}, () => { | ||
resolve(0); | ||
}); | ||
emailClient.resetDb({}, () => { | ||
resolve(0); | ||
}); | ||
|
@@ -59,9 +67,9 @@ it('should successfully register a sender', async () => { | |
(resolve, reject) => { | ||
emailClient.registerSender( | ||
{ | ||
from_email: '[email protected]', | ||
from_name: 'example', | ||
reply_to: '[email protected]', | ||
fromEmail: '[email protected]', | ||
fromName: 'example', | ||
replyTo: '[email protected]', | ||
}, | ||
(err: any, response: EmailProto.RegisterSenderResponse) => { | ||
if (err) { | ||
|
@@ -83,9 +91,9 @@ it('should fail to register a sender', async () => { | |
(resolve, reject) => { | ||
emailClient.registerSender( | ||
{ | ||
from_email: '', | ||
from_name: '', | ||
reply_to: '', | ||
fromEmail: '', | ||
fromName: '', | ||
replyTo: '', | ||
}, | ||
(err: any, response: EmailProto.RegisterSenderResponse) => { | ||
if (err) { | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.