Compare commits

...

7 Commits

Author SHA1 Message Date
khwezi e2d2009cac Merge pull request 'Fixed email sending logic' (#20) from migration into master
Reviewed-on: #20
2026-05-16 00:33:04 +02:00
Khwezi Mngoma 53b422433c Fixed email sending logic
continuous-integration/drone/pr Build is passing
2026-05-16 00:32:22 +02:00
khwezi 3769bb5bae Merge pull request 'Adjusted misfire threshold to 2min' (#19) from migration into master
Reviewed-on: #19
2026-05-15 22:32:01 +02:00
Khwezi Mngoma 547f8dd229 Adjusted misfire threshold to 2min
continuous-integration/drone/pr Build is passing
2026-05-15 22:31:38 +02:00
khwezi 13be0eab87 Merge pull request 'migration' (#18) from migration into master
Reviewed-on: #18
2026-05-15 22:05:36 +02:00
Khwezi Mngoma 5b8b1684c4 Refactored UAT to auto-rollout
continuous-integration/drone/pr Build is passing
2026-05-15 22:04:56 +02:00
Khwezi Mngoma e19f98e7ca Changed job fire-time from 1min to 5min intervals 2026-05-15 22:01:48 +02:00
6 changed files with 18 additions and 7 deletions
+2
View File
@@ -83,6 +83,8 @@ steps:
- mkdir -p $HOME/.kube - mkdir -p $HOME/.kube
- echo "$KUBE_CONFIG" > $HOME/.kube/config - echo "$KUBE_CONFIG" > $HOME/.kube/config
- kubectl apply -f litecharms-scheduler-uat.yml - kubectl apply -f litecharms-scheduler-uat.yml
- sleep 10
- kubectl rollout restart statefulset/litecharms-scheduler-uat -n litecharms-scheduler-uat
depends_on: depends_on:
- package - package
@@ -17,11 +17,12 @@
<!-- Lite Charms Libraries --> <!-- Lite Charms Libraries -->
<ItemGroup> <ItemGroup>
<PackageReference Include="LiteCharms.Features" Version="1.26.0" /> <PackageReference Include="LiteCharms.Features" Version="1.32.0" />
</ItemGroup> </ItemGroup>
<!-- Shared Global Usings --> <!-- Shared Global Usings -->
<ItemGroup> <ItemGroup>
<Using Include="Quartz" /> <Using Include="Quartz" />
<Using Include="Mediator" />
</ItemGroup> </ItemGroup>
</Project> </Project>
+6 -3
View File
@@ -1,12 +1,15 @@
using LiteCharms.Features.Extensions; using LiteCharms.Features.Extensions;
using LiteCharms.Features.Mediator; using LiteCharms.Features.Mediator;
using LiteCharmsScheduler.Workers; using LiteCharmsScheduler.Workers;
using Mediator;
using static LiteCharms.Features.Email.Extensions.Constants; using static LiteCharms.Features.Email.Extensions.Constants;
var builder = Host.CreateApplicationBuilder(args); var builder = Host.CreateApplicationBuilder(args);
builder.Services.AddMediator(); builder.Services.AddMediator(options => options.Assemblies = new List<AssemblyReference>
{
typeof(Program).Assembly,
typeof(LiteCharms.Features.Shop.Notifications.Events.ProcessEmailNotificationsEvent).Assembly
}.AsReadOnly());
builder.Services.AddScoped(typeof(IPipelineBehavior<,>), typeof(TelemetryPipelineBehavior<,>)); builder.Services.AddScoped(typeof(IPipelineBehavior<,>), typeof(TelemetryPipelineBehavior<,>));
builder.Services.AddScoped(typeof(IPipelineBehavior<,>), typeof(LoggingPipelineBehavior<,>)); builder.Services.AddScoped(typeof(IPipelineBehavior<,>), typeof(LoggingPipelineBehavior<,>));
@@ -16,7 +19,7 @@ builder.Services.AddEmailServiceBus();
builder.Services.AddSalesServiceBus(); builder.Services.AddSalesServiceBus();
builder.Services.AddGeneralServiceBus(); builder.Services.AddGeneralServiceBus();
builder.Services.AddQuartzSchedulerClient(ShopSchedulerName, builder.Configuration); builder.Services.AddQuartzScheduler(ShopSchedulerName, builder.Configuration);
builder.Services.AddShopServices(); builder.Services.AddShopServices();
builder.Services.AddShopDatabase(builder.Configuration); builder.Services.AddShopDatabase(builder.Configuration);
+5 -1
View File
@@ -5,9 +5,13 @@ namespace LiteCharmsScheduler.Workers
{ {
public class JobWorker(IJobOrchestrator jobOrchestrator, ILogger<JobWorker> logger) : BackgroundService public class JobWorker(IJobOrchestrator jobOrchestrator, ILogger<JobWorker> logger) : BackgroundService
{ {
private const string emailProcessorCron = "0 */5 * * * ?";
protected override async Task ExecuteAsync(CancellationToken stoppingToken) protected override async Task ExecuteAsync(CancellationToken stoppingToken)
{ {
await jobOrchestrator.ScheduleAsync(ProcessEmailNotificationsEvent.Create(), "0 0/1 * * * ?", stoppingToken); var emailProcessorJob = ProcessEmailNotificationsEvent.Create();
await jobOrchestrator.ScheduleAsync(emailProcessorJob, emailProcessorCron, stoppingToken);
logger.LogInformation("Startup jobs scheduled"); logger.LogInformation("Startup jobs scheduled");
} }
+2 -1
View File
@@ -15,7 +15,8 @@
"Logging": { "Logging": {
"LogLevel": { "LogLevel": {
"Default": "Information", "Default": "Information",
"Microsoft.AspNetCore": "Warning" "Microsoft.AspNetCore": "Warning",
"Microsoft.EntityFrameworkCore": "Warning"
} }
}, },
"AllowedHosts": "*" "AllowedHosts": "*"
+1 -1
View File
@@ -51,7 +51,7 @@ metadata:
namespace: litecharms-scheduler-uat namespace: litecharms-scheduler-uat
spec: spec:
serviceName: "scheduler-worker-service" serviceName: "scheduler-worker-service"
replicas: 3 replicas: 1
selector: selector:
matchLabels: matchLabels:
app: scheduler app: scheduler