Compare commits
27 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| b53e856ea2 | |||
| 02c21319e6 | |||
| b343dbe668 | |||
| d4c005602e | |||
| 783ca2e9c5 | |||
| 3d506cffd1 | |||
| cdc373562e | |||
| f299e8952a | |||
| c54695c390 | |||
| c47fef80b3 | |||
| e2d2009cac | |||
| 53b422433c | |||
| 3769bb5bae | |||
| 547f8dd229 | |||
| 13be0eab87 | |||
| 5b8b1684c4 | |||
| e19f98e7ca | |||
| 8a8ed98a91 | |||
| 4b8aecc779 | |||
| f4a350b2e3 | |||
| e61f628804 | |||
| 56dbe85868 | |||
| 8fa3ac7546 | |||
| e238dcce59 | |||
| 88e70b1e81 | |||
| 36dc31e85b | |||
| 41f92d0670 |
@@ -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,8 @@
|
|||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<PackageReference Include="LiteCharms.Abstractions" Version="1.14.0" />
|
<PackageReference Include="LiteCharms.Features.MidrandBooks" Version="1.69.0" />
|
||||||
<PackageReference Include="Microsoft.Extensions.Hosting" Version="10.0.7" />
|
<PackageReference Include="Microsoft.Extensions.Hosting" Version="10.0.8" />
|
||||||
<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 +18,12 @@
|
|||||||
|
|
||||||
<!-- Lite Charms Libraries -->
|
<!-- Lite Charms Libraries -->
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<PackageReference Include="LiteCharms.Extensions" Version="1.14.0" />
|
<PackageReference Include="LiteCharms.Features" Version="1.69.0" />
|
||||||
<PackageReference Include="LiteCharms.Features" Version="1.14.0" />
|
|
||||||
<PackageReference Include="LiteCharms.Models" Version="1.14.0" />
|
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
<!-- Shared Global Usings -->
|
<!-- Shared Global Usings -->
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<Using Include="Quartz" />
|
<Using Include="Quartz" />
|
||||||
|
<Using Include="Mediator" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
</Project>
|
</Project>
|
||||||
|
|||||||
@@ -1,23 +1,31 @@
|
|||||||
using LiteCharms.Extensions;
|
using LiteCharms.Features.Extensions;
|
||||||
|
using LiteCharms.Features.Mediator;
|
||||||
|
using LiteCharms.Features.MidrandBooks.Extensions;
|
||||||
using LiteCharmsScheduler.Workers;
|
using LiteCharmsScheduler.Workers;
|
||||||
using static LiteCharms.Abstractions.Constants;
|
using static LiteCharms.Features.Extensions.Quartz;
|
||||||
|
|
||||||
var builder = Host.CreateApplicationBuilder(args);
|
var builder = Host.CreateApplicationBuilder(args);
|
||||||
|
|
||||||
builder.Services.AddMediator();
|
builder.Services.AddMediator();
|
||||||
builder.Services.AddEmailServiceBus();
|
|
||||||
builder.Services.AddSalesServiceBus();
|
|
||||||
builder.Services.AddGeneralServiceBus();
|
|
||||||
builder.Services.AddEmailServices(builder.Configuration);
|
|
||||||
builder.Services.AddShopDatabase(builder.Configuration);
|
|
||||||
builder.Services.AddQuartzSchedulerClient(ShopSchedulerName, builder.Configuration);
|
|
||||||
|
|
||||||
builder.Services.AddHostedService<Worker>();
|
builder.Services.AddScoped(typeof(IPipelineBehavior<,>), typeof(TelemetryPipelineBehavior<,>));
|
||||||
|
builder.Services.AddScoped(typeof(IPipelineBehavior<,>), typeof(LoggingPipelineBehavior<,>));
|
||||||
|
|
||||||
|
builder.Services.AddEmailServices(builder.Configuration);
|
||||||
|
builder.Services.AddEmailServiceBus();
|
||||||
|
|
||||||
|
builder.Services.AddShopServices();
|
||||||
|
builder.Services.AddHashServices(builder.Configuration);
|
||||||
|
builder.Services.AddMidrandShopDatabase(builder.Configuration);
|
||||||
|
|
||||||
|
builder.Services.AddQuartzScheduler(MidrandShopSchedulerName, builder.Configuration);
|
||||||
|
|
||||||
|
builder.Services.AddHostedService<JobWorker>();
|
||||||
|
|
||||||
var host = builder.Build();
|
var host = builder.Build();
|
||||||
|
|
||||||
var schedulerFactory = host.Services.GetRequiredService<ISchedulerFactory>();
|
var schedulerFactory = host.Services.GetRequiredService<ISchedulerFactory>();
|
||||||
var scheduler = await schedulerFactory.GetScheduler(ShopSchedulerName);
|
var scheduler = await schedulerFactory.GetScheduler(MidrandShopSchedulerName);
|
||||||
|
|
||||||
if (!scheduler!.IsStarted)
|
if (!scheduler!.IsStarted)
|
||||||
await scheduler.Start();
|
await scheduler.Start();
|
||||||
|
|||||||
@@ -0,0 +1,8 @@
|
|||||||
|
namespace LiteCharmsScheduler.Workers
|
||||||
|
{
|
||||||
|
public class JobWorker(ILogger<JobWorker> logger) : BackgroundService
|
||||||
|
{
|
||||||
|
protected override async Task ExecuteAsync(CancellationToken stoppingToken) =>
|
||||||
|
logger.LogInformation("Midrand Books jobs initialized");
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,17 +0,0 @@
|
|||||||
namespace LiteCharmsScheduler.Workers
|
|
||||||
{
|
|
||||||
public class Worker(ILogger<Worker> logger) : BackgroundService
|
|
||||||
{
|
|
||||||
protected override async Task ExecuteAsync(CancellationToken stoppingToken)
|
|
||||||
{
|
|
||||||
while (!stoppingToken.IsCancellationRequested)
|
|
||||||
{
|
|
||||||
if (logger.IsEnabled(LogLevel.Information))
|
|
||||||
{
|
|
||||||
logger.LogInformation("Worker running at: {time}", DateTimeOffset.Now);
|
|
||||||
}
|
|
||||||
await Task.Delay(1000, stoppingToken);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,21 +1,24 @@
|
|||||||
{
|
{
|
||||||
"Email": {
|
"HasherSettings": {
|
||||||
"Credentials": {
|
"MinHashLength": 11
|
||||||
"Username": "shop@litecharms.co.za"
|
},
|
||||||
},
|
"BookshopS3Settings": {
|
||||||
"Port": 465,
|
"ServiceUrl": "http://192.168.1.177:30900",
|
||||||
"Host": "mail.litecharms.co.za",
|
"Region": "garage",
|
||||||
"UseSsl": true
|
"BucketName": "bookshop",
|
||||||
|
"CdnBaseUrl": "https://bookshop.cdn.khongisa.co.za"
|
||||||
},
|
},
|
||||||
"Monitoring": {
|
"Monitoring": {
|
||||||
"ApiKey": "",
|
"ApiKey": "",
|
||||||
"Address": "http://aspire-dashboard-service.aspire.svc.cluster.local:18889",
|
"Address": "http://aspire-dashboard-service.aspire.svc.cluster.local:18889",
|
||||||
"ServiceName": "LiteCharms.LeadGenerator"
|
"ServiceName": "MidrandBooks.DEV"
|
||||||
},
|
},
|
||||||
|
"EmailProcessorCron": "0 */5 * * * ?",
|
||||||
"Logging": {
|
"Logging": {
|
||||||
"LogLevel": {
|
"LogLevel": {
|
||||||
"Default": "Information",
|
"Default": "Information",
|
||||||
"Microsoft.AspNetCore": "Warning"
|
"Microsoft.AspNetCore": "Warning",
|
||||||
|
"Microsoft.EntityFrameworkCore": "Warning"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"AllowedHosts": "*"
|
"AllowedHosts": "*"
|
||||||
|
|||||||
@@ -17,6 +17,19 @@ 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 * * * ?"
|
||||||
|
HasherSettings__MinHashLength: "11"
|
||||||
|
BookshopS3Settings__ServiceUrl: "http://garage.garage.svc.cluster.local:3900"
|
||||||
|
BookshopS3Settings__Region: "garage"
|
||||||
|
BookshopS3Settings__BucketName: "bookshop"
|
||||||
|
BookshopS3Settings__CdnBaseUrl: "https://bookshop.cdn.khongisa.co.za"
|
||||||
|
ValidPayfastHosts__0: "www.payfast.co.za"
|
||||||
|
ValidPayfastHosts__1: "sandbox.payfast.co.za"
|
||||||
|
ValidPayfastHosts__2: "w1w.payfast.co.za"
|
||||||
|
ValidPayfastHosts__3: "w2w.payfast.co.za"
|
||||||
|
ValidPayfastHosts__4: "ips.payfast.co.za"
|
||||||
|
ValidPayfastHosts__5: "api.payfast.co.za"
|
||||||
|
ValidPayfastHosts__6: "payment.payfast.io"
|
||||||
---
|
---
|
||||||
apiVersion: v1
|
apiVersion: v1
|
||||||
kind: Secret
|
kind: Secret
|
||||||
@@ -26,10 +39,14 @@ metadata:
|
|||||||
type: Opaque
|
type: Opaque
|
||||||
data:
|
data:
|
||||||
connection-string-quartz: SG9zdD0xOTIuMTY4LjEuMTcwO0RhdGFiYXNlPXNjaGVkdWxlci1kZXY7VXNlcm5hbWU9c2NoZWR1bGVyLWRldi11c2VyO1Bhc3N3b3JkPWtWVm1vV0tKM3h6Z1FYO1BlcnNpc3QgU2VjdXJpdHkgSW5mbz1UcnVl
|
connection-string-quartz: SG9zdD0xOTIuMTY4LjEuMTcwO0RhdGFiYXNlPXNjaGVkdWxlci1kZXY7VXNlcm5hbWU9c2NoZWR1bGVyLWRldi11c2VyO1Bhc3N3b3JkPWtWVm1vV0tKM3h6Z1FYO1BlcnNpc3QgU2VjdXJpdHkgSW5mbz1UcnVl
|
||||||
connection-string: SG9zdD0xOTIuMTY4LjEuMTcwO0RhdGFiYXNlPXNob3AtZGV2O1VzZXJuYW1lPXNob3AtZGV2LXVzZXI7UGFzc3dvcmQ9a1ZWbW9XS0ozeHpnUVg7UGVyc2lzdCBTZWN1cml0eSBJbmZvPVRydWU=
|
connection-string: SG9zdD0xOTIuMTY4LjEuMTcwO0RhdGFiYXNlPW1pZHJhbmRzaG9wLWRldjtVc2VybmFtZT1taWRyYW5kc2hvcC1kZXYtdXNlcjtQYXNzd29yZD1hUFh5a0tnM3RTOWNtRDtQZXJzaXN0IFNlY3VyaXR5IEluZm89VHJ1ZQ==
|
||||||
discord-webhook: aHR0cHM6Ly9kaXNjb3JkLmNvbS9hcGkvd2ViaG9va3MvMTUwMDIzMzEyOTYwNzAzNjk3MC9KYzc5endwMjlxYWpLbmoyYkR3cm5GR0RJci11ZGIyV2JIUDZTYjdpT0hCTWpQSUY3Vkw5eUVHTkJUSXpSOVVWVzI0bQ==
|
discord-webhook: aHR0cHM6Ly9kaXNjb3JkLmNvbS9hcGkvd2ViaG9va3MvMTUwMDIzMzEyOTYwNzAzNjk3MC9KYzc5endwMjlxYWpLbmoyYkR3cm5GR0RJci11ZGIyV2JIUDZTYjdpT0hCTWpQSUY3Vkw5eUVHTkJUSXpSOVVWVzI0bQ==
|
||||||
aspire-apikey: bWMzRzYzSzJqNVpPRXNpMEFqTW9qTFRYbTFLRVpGY3R6SUlqU3dEaVRHdXQ4cUdTa1B1V3d4R1AxUmJzY0pVbw==
|
aspire-apikey: bWMzRzYzSzJqNVpPRXNpMEFqTW9qTFRYbTFLRVpGY3R6SUlqU3dEaVRHdXQ4cUdTa1B1V3d4R1AxUmJzY0pVbw==
|
||||||
email-password: JFpTLWVJQGlYbTVNUCRhfg==
|
email-password: JFpTLWVJQGlYbTVNUCRhfg==
|
||||||
|
hasher-salt: VEdsbmFIUWdRMmhoY20xekxDQk5hV1J5WVc1a1FtOXZhM01nYldGclpTQnNiM1J6SUc5bUlHMXZibVY1SUdGdVpDQmhjbVVnWVNCemRXTmpaWE56Wm5Wc0lIWnBjbUZzSUhOMGIzSjVJR2x1SUZOdmRYUm9JRUZtY21sallRPT0=
|
||||||
|
hasher-payfastpassphrase: OUdBSVIwdFdwaFgwcU8=
|
||||||
|
bookshop-s3-accesskey: R0s1MTRkMmNlOGRjNjkyMzdhMDVjMDFlZWY=
|
||||||
|
bookshop-s3-secretkey: ZWFhZmVkYTFhZWQ0MDllY2ZlNjA3MTRlY2RhNTQ5YjgyYmRmNWEzZGFmOWYxOGRkNjFmNjZiNDk3M2E2NDgyZQ==
|
||||||
---
|
---
|
||||||
apiVersion: v1
|
apiVersion: v1
|
||||||
kind: Service
|
kind: Service
|
||||||
@@ -51,7 +68,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
|
||||||
@@ -75,6 +92,36 @@ spec:
|
|||||||
- configMapRef:
|
- configMapRef:
|
||||||
name: scheduler-config
|
name: scheduler-config
|
||||||
env:
|
env:
|
||||||
|
- name: BookshopS3Settings__AccessKey
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: scheduler-secrets
|
||||||
|
key: bookshop-s3-accesskey
|
||||||
|
- name: BookshopS3Settings__SecretKey
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: scheduler-secrets
|
||||||
|
key: bookshop-s3-secretkey
|
||||||
|
- name: HasherSettings__Salt
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: scheduler-secrets
|
||||||
|
key: hasher-salt
|
||||||
|
- name: HasherSettings__PayfastPassphrase
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: scheduler-secrets
|
||||||
|
key: hasher-payfastpassphrase
|
||||||
|
- name: ConnectionStrings__PostgresMidrandBooks
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: scheduler-secrets
|
||||||
|
key: connection-string
|
||||||
|
- name: Monitoring__ApiKey
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: scheduler-secrets
|
||||||
|
key: aspire-apikey
|
||||||
- name: Email__Credentials__Password
|
- name: Email__Credentials__Password
|
||||||
valueFrom:
|
valueFrom:
|
||||||
secretKeyRef:
|
secretKeyRef:
|
||||||
@@ -85,11 +132,6 @@ spec:
|
|||||||
secretKeyRef:
|
secretKeyRef:
|
||||||
name: scheduler-secrets
|
name: scheduler-secrets
|
||||||
key: connection-string-quartz
|
key: connection-string-quartz
|
||||||
- name: ConnectionStrings__PostgresShop
|
|
||||||
valueFrom:
|
|
||||||
secretKeyRef:
|
|
||||||
name: scheduler-secrets
|
|
||||||
key: connection-string
|
|
||||||
- name: ConnectionStrings__DiscordShop
|
- name: ConnectionStrings__DiscordShop
|
||||||
valueFrom:
|
valueFrom:
|
||||||
secretKeyRef:
|
secretKeyRef:
|
||||||
|
|||||||
Reference in New Issue
Block a user