diff --git a/README.md b/README.md index 81f0c0b0..08e0d1f9 100644 --- a/README.md +++ b/README.md @@ -63,6 +63,6 @@ In pgAdmin To run a Kafka broker and Kafdrop (visualization and administration tool) locally you need to have Docker installed on your machine. In a terminal navigate to the root of this repository -and run command `docker-compose -f setup-kafka.yml up -d` +and run command `docker compose -f setup-kafka.yml up -d` Kafdrop will be available on localhost:9000 diff --git a/src/Altinn.Notifications.Core/Enums/EmailNotificationResultType.cs b/src/Altinn.Notifications.Core/Enums/EmailNotificationResultType.cs index 65813841..2867520c 100644 --- a/src/Altinn.Notifications.Core/Enums/EmailNotificationResultType.cs +++ b/src/Altinn.Notifications.Core/Enums/EmailNotificationResultType.cs @@ -38,5 +38,18 @@ public enum EmailNotificationResultType /// /// Invalid format for email address /// - Failed_InvalidEmailFormat + Failed_InvalidEmailFormat, + + /// + /// Recipient supressed by email service + /// + Failed_SupressedRecipient, + + /// + /// Transient error, retry later + /// + /// + /// Should not be used externally or persisted in db. + /// Only used for processing and logic in service layer. + Failed_TransientError } diff --git a/src/Altinn.Notifications.Core/Services/EmailNotificationService.cs b/src/Altinn.Notifications.Core/Services/EmailNotificationService.cs index 61453805..9386824c 100644 --- a/src/Altinn.Notifications.Core/Services/EmailNotificationService.cs +++ b/src/Altinn.Notifications.Core/Services/EmailNotificationService.cs @@ -72,6 +72,12 @@ public async Task SendNotifications() /// public async Task UpdateSendStatus(SendOperationResult sendOperationResult) { + // set to new to allow new iteration of regular proceessing if transient error + if (sendOperationResult.SendResult == EmailNotificationResultType.Failed_TransientError) + { + sendOperationResult.SendResult = EmailNotificationResultType.New; + } + await _repository.UpdateSendStatus(sendOperationResult.NotificationId, (EmailNotificationResultType)sendOperationResult.SendResult!, sendOperationResult.OperationId); } diff --git a/src/Altinn.Notifications.Core/Services/NotificationSummaryService.cs b/src/Altinn.Notifications.Core/Services/NotificationSummaryService.cs index 54a9326a..e618ce0e 100644 --- a/src/Altinn.Notifications.Core/Services/NotificationSummaryService.cs +++ b/src/Altinn.Notifications.Core/Services/NotificationSummaryService.cs @@ -20,7 +20,9 @@ public class NotificationSummaryService : INotificationSummaryService { EmailNotificationResultType.Delivered, "The email was delivered to the recipient. No errors reported, making it likely it was received by the recipient." }, { EmailNotificationResultType.Failed, "The email was not sent due to an unspecified failure." }, { EmailNotificationResultType.Failed_RecipientNotIdentified, "The email was not sent because the recipient's email address was not found." }, - { EmailNotificationResultType.Failed_InvalidEmailFormat, "The email was not sent because the recipient’s email address is in an invalid format." } + { EmailNotificationResultType.Failed_InvalidEmailFormat, "The email was not sent because the recipient’s email address is in an invalid format." }, + { EmailNotificationResultType.Failed_SupressedRecipient, "The email was not sent because the recipient’s email address is suppressed by the third party email service." }, + { EmailNotificationResultType.Failed_TransientError, "The email was not sent due to a transient error. We will retry sending the email." } }; private readonly static List _successResults = new() diff --git a/test/Altinn.Notifications.Tests/Notifications.Core/TestingServices/EmailNotificationServiceTests.cs b/test/Altinn.Notifications.Tests/Notifications.Core/TestingServices/EmailNotificationServiceTests.cs index 0e254716..505084a1 100644 --- a/test/Altinn.Notifications.Tests/Notifications.Core/TestingServices/EmailNotificationServiceTests.cs +++ b/test/Altinn.Notifications.Tests/Notifications.Core/TestingServices/EmailNotificationServiceTests.cs @@ -162,6 +162,35 @@ public async Task UpdateSendStatus_SendResultDefined_Succeded() repoMock.Verify(); } + [Fact] + public async Task UpdateSendStatus_TransientErrorResult_ConvertedToNew() + { + // Arrange + Guid notificationid = Guid.NewGuid(); + string operationId = Guid.NewGuid().ToString(); + + SendOperationResult sendOperationResult = new() + { + NotificationId = notificationid, + OperationId = operationId, + SendResult = EmailNotificationResultType.Failed_TransientError + }; + + var repoMock = new Mock(); + repoMock.Setup(r => r.UpdateSendStatus( + It.Is(n => n == notificationid), + It.Is(e => e == EmailNotificationResultType.New), + It.Is(s => s.Equals(operationId)))); + + var service = GetTestService(repo: repoMock.Object); + + // Act + await service.UpdateSendStatus(sendOperationResult); + + // Assert + repoMock.Verify(); + } + private static EmailNotificationService GetTestService(IEmailNotificationRepository? repo = null, IKafkaProducer? producer = null, Guid? guidOutput = null, DateTime? dateTimeOutput = null) { var guidService = new Mock();