refactor(domain → application): move MailService to application layer and rename to EmailPort
This commit is contained in:
parent
45a98daae0
commit
421d160c12
@ -1,5 +0,0 @@
|
|||||||
package com.pablotj.restemailbridge.application.port;
|
|
||||||
|
|
||||||
public interface EmailConfigurationPort {
|
|
||||||
String getDefaultRecipient();
|
|
||||||
}
|
|
@ -0,0 +1,5 @@
|
|||||||
|
package com.pablotj.restemailbridge.application.port.in;
|
||||||
|
|
||||||
|
public interface EmailDefaultConfigPort {
|
||||||
|
String getDefaultRecipient();
|
||||||
|
}
|
@ -1,8 +1,8 @@
|
|||||||
package com.pablotj.restemailbridge.domain.service;
|
package com.pablotj.restemailbridge.application.port.out;
|
||||||
|
|
||||||
import com.pablotj.restemailbridge.domain.model.Email;
|
import com.pablotj.restemailbridge.domain.model.Email;
|
||||||
|
|
||||||
public interface EmailService {
|
public interface EmailPort {
|
||||||
|
|
||||||
Email sendEmail(Email email);
|
Email sendEmail(Email email);
|
||||||
}
|
}
|
@ -1,25 +1,25 @@
|
|||||||
package com.pablotj.restemailbridge.application.usecase;
|
package com.pablotj.restemailbridge.application.usecase;
|
||||||
|
|
||||||
import com.pablotj.restemailbridge.application.dto.EmailDTO;
|
import com.pablotj.restemailbridge.application.dto.EmailDTO;
|
||||||
import com.pablotj.restemailbridge.application.port.EmailConfigurationPort;
|
import com.pablotj.restemailbridge.application.port.in.EmailDefaultConfigPort;
|
||||||
|
import com.pablotj.restemailbridge.application.port.out.EmailPort;
|
||||||
import com.pablotj.restemailbridge.domain.model.Email;
|
import com.pablotj.restemailbridge.domain.model.Email;
|
||||||
import com.pablotj.restemailbridge.domain.repository.EmailRepository;
|
import com.pablotj.restemailbridge.domain.repository.EmailRepository;
|
||||||
import com.pablotj.restemailbridge.domain.service.EmailService;
|
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Use case for sending emails.
|
* Use case for sending emails.
|
||||||
* <p>
|
* <p>
|
||||||
* Retrieves the default recipient from EmailConfigurationPort, sends the email using EmailService,
|
* Retrieves the default recipient from EmailDefaultConfigPort, sends the email using EmailPort,
|
||||||
* and persists it via EmailRepository.
|
* and persists it via EmailRepository.
|
||||||
*/
|
*/
|
||||||
public class SendEmailUseCase {
|
public class SendEmailUseCase {
|
||||||
|
|
||||||
private static final Logger log = LoggerFactory.getLogger(SendEmailUseCase.class);
|
private static final Logger log = LoggerFactory.getLogger(SendEmailUseCase.class);
|
||||||
|
|
||||||
private final EmailConfigurationPort emailConfigurationPort;
|
private final EmailDefaultConfigPort emailConfigurationPort;
|
||||||
private final EmailService emailService;
|
private final EmailPort emailService;
|
||||||
private final EmailRepository emailRepository;
|
private final EmailRepository emailRepository;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -29,8 +29,8 @@ public class SendEmailUseCase {
|
|||||||
* @param emailService Service to send emails
|
* @param emailService Service to send emails
|
||||||
* @param emailRepository Repository to persist emails
|
* @param emailRepository Repository to persist emails
|
||||||
*/
|
*/
|
||||||
public SendEmailUseCase(EmailConfigurationPort emailConfigurationPort,
|
public SendEmailUseCase(EmailDefaultConfigPort emailConfigurationPort,
|
||||||
EmailService emailService,
|
EmailPort emailService,
|
||||||
EmailRepository emailRepository) {
|
EmailRepository emailRepository) {
|
||||||
this.emailConfigurationPort = emailConfigurationPort;
|
this.emailConfigurationPort = emailConfigurationPort;
|
||||||
this.emailService = emailService;
|
this.emailService = emailService;
|
||||||
@ -55,7 +55,7 @@ public class SendEmailUseCase {
|
|||||||
.build()
|
.build()
|
||||||
);
|
);
|
||||||
|
|
||||||
emailRepository.save(email); // Persist the sent email
|
emailRepository.save(email);
|
||||||
log.info("Email successfully sent and persisted to repository for recipient {}", to);
|
log.info("Email successfully sent and persisted to repository for recipient {}", to);
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -1,9 +1,9 @@
|
|||||||
package com.pablotj.restemailbridge.infrastructure.config;
|
package com.pablotj.restemailbridge.infrastructure.config;
|
||||||
|
|
||||||
import com.pablotj.restemailbridge.application.port.EmailConfigurationPort;
|
import com.pablotj.restemailbridge.application.port.in.EmailDefaultConfigPort;
|
||||||
|
import com.pablotj.restemailbridge.application.port.out.EmailPort;
|
||||||
import com.pablotj.restemailbridge.application.usecase.SendEmailUseCase;
|
import com.pablotj.restemailbridge.application.usecase.SendEmailUseCase;
|
||||||
import com.pablotj.restemailbridge.domain.repository.EmailRepository;
|
import com.pablotj.restemailbridge.domain.repository.EmailRepository;
|
||||||
import com.pablotj.restemailbridge.domain.service.EmailService;
|
|
||||||
import org.springframework.context.annotation.Bean;
|
import org.springframework.context.annotation.Bean;
|
||||||
import org.springframework.context.annotation.Configuration;
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
|
||||||
@ -11,7 +11,7 @@ import org.springframework.context.annotation.Configuration;
|
|||||||
public class UseCaseConfig {
|
public class UseCaseConfig {
|
||||||
|
|
||||||
@Bean
|
@Bean
|
||||||
public SendEmailUseCase sendEmailUseCase(EmailConfigurationPort emailConfigurationPort, EmailService emailService, EmailRepository emailRepository) {
|
public SendEmailUseCase sendEmailUseCase(EmailDefaultConfigPort emailConfigurationPort, EmailPort emailService, EmailRepository emailRepository) {
|
||||||
return new SendEmailUseCase(emailConfigurationPort, emailService, emailRepository);
|
return new SendEmailUseCase(emailConfigurationPort, emailService, emailRepository);
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -1,10 +1,10 @@
|
|||||||
package com.pablotj.restemailbridge.infrastructure.mail;
|
package com.pablotj.restemailbridge.infrastructure.mail;
|
||||||
|
|
||||||
import com.pablotj.restemailbridge.application.port.EmailConfigurationPort;
|
import com.pablotj.restemailbridge.application.port.in.EmailDefaultConfigPort;
|
||||||
import org.springframework.stereotype.Component;
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
@Component
|
@Component
|
||||||
public class EmailConfigurationAdapter implements EmailConfigurationPort {
|
public class GmailDefaultConfigAdapter implements EmailDefaultConfigPort {
|
||||||
@Override
|
@Override
|
||||||
public String getDefaultRecipient() {
|
public String getDefaultRecipient() {
|
||||||
return "pablodelatorree@gmail.com";
|
return "pablodelatorree@gmail.com";
|
@ -13,7 +13,7 @@ import com.google.api.services.gmail.Gmail;
|
|||||||
import com.google.api.services.gmail.GmailScopes;
|
import com.google.api.services.gmail.GmailScopes;
|
||||||
import com.google.api.services.gmail.model.Message;
|
import com.google.api.services.gmail.model.Message;
|
||||||
import com.pablotj.restemailbridge.domain.model.Email;
|
import com.pablotj.restemailbridge.domain.model.Email;
|
||||||
import com.pablotj.restemailbridge.domain.service.EmailService;
|
import com.pablotj.restemailbridge.application.port.out.EmailPort;
|
||||||
import com.pablotj.restemailbridge.infrastructure.exception.GmailConfigurationException;
|
import com.pablotj.restemailbridge.infrastructure.exception.GmailConfigurationException;
|
||||||
import com.pablotj.restemailbridge.infrastructure.exception.GmailInitializationException;
|
import com.pablotj.restemailbridge.infrastructure.exception.GmailInitializationException;
|
||||||
import com.pablotj.restemailbridge.infrastructure.exception.GmailSendErrorException;
|
import com.pablotj.restemailbridge.infrastructure.exception.GmailSendErrorException;
|
||||||
@ -36,14 +36,14 @@ import java.util.List;
|
|||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gmail implementation of the EmailService using OAuth2 authentication.
|
* Gmail implementation of the EmailPort using OAuth2 authentication.
|
||||||
* <p>
|
* <p>
|
||||||
* Handles sending emails via Gmail API and manages credentials stored in a local token folder.
|
* Handles sending emails via Gmail API and manages credentials stored in a local token folder.
|
||||||
*/
|
*/
|
||||||
@Component
|
@Component
|
||||||
public class GmailOAuth2MailService implements EmailService {
|
public class GmailOAuth2MailAdapter implements EmailPort {
|
||||||
|
|
||||||
private static final Logger log = LoggerFactory.getLogger(GmailOAuth2MailService.class);
|
private static final Logger log = LoggerFactory.getLogger(GmailOAuth2MailAdapter.class);
|
||||||
private static final String APPLICATION_NAME = "MailServiceApi";
|
private static final String APPLICATION_NAME = "MailServiceApi";
|
||||||
private static final JsonFactory JSON_FACTORY = GsonFactory.getDefaultInstance();
|
private static final JsonFactory JSON_FACTORY = GsonFactory.getDefaultInstance();
|
||||||
private static final List<String> SCOPES = Collections.singletonList(GmailScopes.GMAIL_SEND);
|
private static final List<String> SCOPES = Collections.singletonList(GmailScopes.GMAIL_SEND);
|
||||||
@ -57,7 +57,7 @@ public class GmailOAuth2MailService implements EmailService {
|
|||||||
*
|
*
|
||||||
* @param properties OAuth2 configuration for Gmail
|
* @param properties OAuth2 configuration for Gmail
|
||||||
*/
|
*/
|
||||||
public GmailOAuth2MailService(GmailOAuth2Properties properties) {
|
public GmailOAuth2MailAdapter(GmailOAuth2Properties properties) {
|
||||||
this.properties = properties;
|
this.properties = properties;
|
||||||
}
|
}
|
||||||
|
|
Loading…
x
Reference in New Issue
Block a user