Compare commits

...

19 Commits

Author SHA1 Message Date
khwezi cdc373562e Merge pull request 'Updated notification service' (#22) from migration into master
Reviewed-on: #22
2026-05-17 16:07:12 +02:00
Khwezi Mngoma f299e8952a Updated notification service
continuous-integration/drone/pr Build is passing
2026-05-17 16:06:46 +02:00
khwezi c54695c390 Merge pull request 'Externalised email processor cron setting' (#21) from migration into master
Reviewed-on: #21
2026-05-16 00:43:16 +02:00
Khwezi Mngoma c47fef80b3 Externalised email processor cron setting
continuous-integration/drone/pr Build is passing
2026-05-16 00:42:47 +02:00
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
khwezi 8a8ed98a91 Merge pull request 'Updated Feature package to fix quartz job misfire' (#17) from migration into master
Reviewed-on: #17
2026-05-15 09:59:22 +02:00
Khwezi Mngoma 4b8aecc779 Updated Feature package to fix quartz job misfire
continuous-integration/drone/pr Build is passing
2026-05-15 09:58:17 +02:00
khwezi f4a350b2e3 Merge pull request 'Updated nuget packafe Features' (#16) from migration into master
Reviewed-on: #16
2026-05-15 08:42:48 +02:00
Khwezi Mngoma e61f628804 Updated nuget packafe Features
continuous-integration/drone/pr Build is passing
2026-05-15 08:42:05 +02:00
khwezi 56dbe85868 Merge pull request 'Migrated to Feature only library reference' (#15) from migration into master
Reviewed-on: #15
2026-05-14 17:48:02 +02:00
Khwezi Mngoma 8fa3ac7546 Migrated to Feature only library reference
continuous-integration/drone/pr Build is passing
2026-05-14 17:47:00 +02:00
khwezi e238dcce59 Merge pull request 'Updated job orchestrator' (#14) from migration into master
Reviewed-on: #14
2026-05-10 17:37:41 +02:00
Khwezi Mngoma 88e70b1e81 Updated job orchestrator
continuous-integration/drone/pr Build is passing
2026-05-10 17:37:14 +02:00
6 changed files with 39 additions and 17 deletions
+3
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
@@ -104,6 +106,7 @@ 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.yml - kubectl apply -f litecharms-scheduler.yml
- sleep 10
- kubectl rollout restart statefulset/litecharms-scheduler -n litecharms-scheduler - kubectl rollout restart statefulset/litecharms-scheduler -n litecharms-scheduler
depends_on: depends_on:
@@ -8,8 +8,7 @@
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="LiteCharms.Abstractions" Version="1.19.0" /> <PackageReference Include="Microsoft.Extensions.Hosting" Version="10.0.8" />
<PackageReference Include="Microsoft.Extensions.Hosting" Version="10.0.7" />
<PackageReference Include="Mediator.SourceGenerator" Version="3.0.2"> <PackageReference Include="Mediator.SourceGenerator" Version="3.0.2">
<PrivateAssets>all</PrivateAssets> <PrivateAssets>all</PrivateAssets>
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets> <IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
@@ -18,13 +17,12 @@
<!-- Lite Charms Libraries --> <!-- Lite Charms Libraries -->
<ItemGroup> <ItemGroup>
<PackageReference Include="LiteCharms.Extensions" Version="1.19.0" /> <PackageReference Include="LiteCharms.Features" Version="1.34.0" />
<PackageReference Include="LiteCharms.Features" Version="1.19.0" />
<PackageReference Include="LiteCharms.Models" Version="1.19.0" />
</ItemGroup> </ItemGroup>
<!-- Shared Global Usings --> <!-- Shared Global Usings -->
<ItemGroup> <ItemGroup>
<Using Include="Quartz" /> <Using Include="Quartz" />
<Using Include="Mediator" />
</ItemGroup> </ItemGroup>
</Project> </Project>
+17 -5
View File
@@ -1,16 +1,28 @@
using LiteCharms.Extensions; using LiteCharms.Features.Extensions;
using LiteCharms.Features.Mediator;
using LiteCharmsScheduler.Workers; using LiteCharmsScheduler.Workers;
using static LiteCharms.Abstractions.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(LoggingPipelineBehavior<,>));
builder.Services.AddEmailServices(builder.Configuration);
builder.Services.AddEmailServiceBus(); builder.Services.AddEmailServiceBus();
builder.Services.AddSalesServiceBus(); builder.Services.AddSalesServiceBus();
builder.Services.AddGeneralServiceBus(); builder.Services.AddGeneralServiceBus();
builder.Services.AddEmailServices(builder.Configuration); builder.Services.AddQuartzScheduler(ShopSchedulerName, builder.Configuration);
builder.Services.AddShopServices();
builder.Services.AddShopDatabase(builder.Configuration); builder.Services.AddShopDatabase(builder.Configuration);
builder.Services.AddQuartzSchedulerClient(ShopSchedulerName, builder.Configuration);
builder.Services.AddHostedService<JobWorker>(); builder.Services.AddHostedService<JobWorker>();
+10 -4
View File
@@ -1,13 +1,19 @@
using LiteCharms.Abstractions; using LiteCharms.Features.Quartz.Abstractions;
using LiteCharms.Features.Notifications.Events; using LiteCharms.Features.Shop.Notifications.Events;
namespace LiteCharmsScheduler.Workers namespace LiteCharmsScheduler.Workers
{ {
public class JobWorker(IJobOrchestrator jobOrchestrator, ILogger<JobWorker> logger) : BackgroundService public class JobWorker(IJobOrchestrator jobOrchestrator, ILogger<JobWorker> logger, IConfiguration configuration) : BackgroundService
{ {
protected override async Task ExecuteAsync(CancellationToken stoppingToken) protected override async Task ExecuteAsync(CancellationToken stoppingToken)
{ {
await jobOrchestrator.ScheduleAsync(ProcessEmailNotificationsEvent.Create(), "0 1 * * * ?", stoppingToken); string? emailProcessorCron = !string.IsNullOrWhiteSpace(configuration.GetSection("EmailProcessorCron").Value)
? configuration.GetSection("EmailProcessorCron").Value
: "0 */4 * * * ?";
var emailProcessorJob = ProcessEmailNotificationsEvent.Create();
await jobOrchestrator.ScheduleAsync(emailProcessorJob, emailProcessorCron!, stoppingToken);
logger.LogInformation("Startup jobs scheduled"); logger.LogInformation("Startup jobs scheduled");
} }
+3 -1
View File
@@ -7,6 +7,7 @@
"Host": "mail.litecharms.co.za", "Host": "mail.litecharms.co.za",
"UseSsl": true "UseSsl": true
}, },
"EmailProcessorCron": "0 */5 * * * ?",
"Monitoring": { "Monitoring": {
"ApiKey": "", "ApiKey": "",
"Address": "http://aspire-dashboard-service.aspire.svc.cluster.local:18889", "Address": "http://aspire-dashboard-service.aspire.svc.cluster.local:18889",
@@ -15,7 +16,8 @@
"Logging": { "Logging": {
"LogLevel": { "LogLevel": {
"Default": "Information", "Default": "Information",
"Microsoft.AspNetCore": "Warning" "Microsoft.AspNetCore": "Warning",
"Microsoft.EntityFrameworkCore": "Warning"
} }
}, },
"AllowedHosts": "*" "AllowedHosts": "*"
+3 -2
View File
@@ -17,6 +17,7 @@ data:
Email__Host: "mail.litecharms.co.za" Email__Host: "mail.litecharms.co.za"
Email__Port: "465" Email__Port: "465"
Email__UseSsl: "true" Email__UseSsl: "true"
EmailProcessorCron: "0 */5 * * * ?"
--- ---
apiVersion: v1 apiVersion: v1
kind: Secret kind: Secret
@@ -51,7 +52,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
@@ -74,7 +75,7 @@ spec:
envFrom: envFrom:
- configMapRef: - configMapRef:
name: scheduler-config name: scheduler-config
env: env:
- name: Email__Credentials__Password - name: Email__Credentials__Password
valueFrom: valueFrom:
secretKeyRef: secretKeyRef: