Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
18 changes: 9 additions & 9 deletions src/EventBus.sln → EventBus.sln
Original file line number Diff line number Diff line change
Expand Up @@ -3,27 +3,27 @@ Microsoft Visual Studio Solution File, Format Version 12.00
# Visual Studio Version 17
VisualStudioVersion = 17.2.32505.173
MinimumVisualStudioVersion = 10.0.40219.1
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "JKang.EventBus.Abstractions", "JKang.EventBus.Abstractions\JKang.EventBus.Abstractions.csproj", "{B32C9E22-C892-4F8C-8E49-30CBA5B971C1}"
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "JKang.EventBus.Abstractions", "src\JKang.EventBus.Abstractions\JKang.EventBus.Abstractions.csproj", "{B32C9E22-C892-4F8C-8E49-30CBA5B971C1}"
EndProject
Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Samples", "Samples", "{8C1896E4-9A8F-4A76-B3D1-CCBB0A2F8037}"
EndProject
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Samples.EventBus.AspNetCore", "Samples.EventBus.AspNetCore\Samples.EventBus.AspNetCore.csproj", "{F0688B6D-EEE6-4AA3-BEC3-F73DD1FC0DA0}"
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Samples.EventBus.AspNetCore", "src\Samples.EventBus.AspNetCore\Samples.EventBus.AspNetCore.csproj", "{F0688B6D-EEE6-4AA3-BEC3-F73DD1FC0DA0}"
EndProject
Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Solution Items", "Solution Items", "{C9D1DF75-9F6D-4201-AC2C-BA95E3A72C9A}"
ProjectSection(SolutionItems) = preProject
Directory.Build.props = Directory.Build.props
..\README.md = ..\README.md
src\Directory.Build.props = src\Directory.Build.props
README.md = README.md
EndProjectSection
EndProject
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "JKang.EventBus.Core", "JKang.EventBus.Core\JKang.EventBus.Core.csproj", "{16EFDC3B-73CD-486C-9BD0-5700AFF8CCB4}"
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "JKang.EventBus.Core", "src\JKang.EventBus.Core\JKang.EventBus.Core.csproj", "{16EFDC3B-73CD-486C-9BD0-5700AFF8CCB4}"
EndProject
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "JKang.EventBus", "JKang.EventBus\JKang.EventBus.csproj", "{36024674-F10A-4A44-BC4E-24EBAA0D0CFC}"
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "JKang.EventBus", "src\JKang.EventBus\JKang.EventBus.csproj", "{36024674-F10A-4A44-BC4E-24EBAA0D0CFC}"
EndProject
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "JKang.EventBus.AmazonSns", "JKang.EventBus.AmazonSns\JKang.EventBus.AmazonSns.csproj", "{C46D4B8E-4AAA-4889-A60A-89A9E9E10F50}"
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "JKang.EventBus.AmazonSns", "src\JKang.EventBus.AmazonSns\JKang.EventBus.AmazonSns.csproj", "{C46D4B8E-4AAA-4889-A60A-89A9E9E10F50}"
EndProject
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Samples.EventBus.ConsoleApp", "Samples.EventBus.Console\Samples.EventBus.ConsoleApp.csproj", "{CE18852E-385B-4C84-B023-F4135494BFDD}"
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Samples.EventBus.ConsoleApp", "src\Samples.EventBus.Console\Samples.EventBus.ConsoleApp.csproj", "{CE18852E-385B-4C84-B023-F4135494BFDD}"
EndProject
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "JKang.EventBus.AmazonSqs", "JKang.EventBus.AmazonSqs\JKang.EventBus.AmazonSqs.csproj", "{09867E42-1054-4651-A95E-B61B29ABE6EA}"
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "JKang.EventBus.AmazonSqs", "src\JKang.EventBus.AmazonSqs\JKang.EventBus.AmazonSqs.csproj", "{09867E42-1054-4651-A95E-B61B29ABE6EA}"
EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
Expand Down
9 changes: 4 additions & 5 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
* In-memory event dispatching (publishing and subscription)
* publishing event to Amazon SNS
* publishing event to Amazon SQS
* delayed execution of event handler

## NuGet packages

Expand Down Expand Up @@ -61,11 +62,9 @@

```csharp
IServiceProvider serviceProvider = services.BuildServiceProvider();
using (IServiceScope scope = serviceProvider.CreateScope())
{
IEventPublisher eventPublisher = scope.ServiceProvider.GetRequiredService<IEventPublisher>();
eventPublisher.PublishEventAsync(new MyEvent { Message = "Hello, event bus!" }).Wait();
}
using IServiceScope scope = serviceProvider.CreateScope();
IEventPublisher eventPublisher = scope.ServiceProvider.GetRequiredService<IEventPublisher>();
await eventPublisher.PublishEventAsync(new MyEvent { Message = "Hello, event bus!" }, 3);
```


Expand Down
2 changes: 1 addition & 1 deletion src/JKang.EventBus.Abstractions/IEventPublisher.cs
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,6 @@ namespace JKang.EventBus
{
public interface IEventPublisher
{
Task PublishEventAsync<TEvent>(TEvent @event);
Task PublishEventAsync<TEvent>(TEvent @event, int delaySeconds = 0);
}
}
5 changes: 4 additions & 1 deletion src/JKang.EventBus.AmazonSns/AmazonSnsEventPublisher.cs
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ public AmazonSnsEventPublisher(
_options = options;
}

public async Task PublishEventAsync<TEvent>(TEvent @event)
public async Task PublishEventAsync<TEvent>(TEvent @event, int delaySeconds = 0)
{
var endpoint = RegionEndpoint.GetBySystemName(_options.Value.Region);
var client = new AmazonSimpleNotificationServiceClient(endpoint);
Expand All @@ -40,6 +40,9 @@ public async Task PublishEventAsync<TEvent>(TEvent @event)

string message = _eventSerializer.Serialize(@event);
var publishRequest = new PublishRequest(topicArn, message);

if(delaySeconds > 0)
await Task.Delay(delaySeconds * 1000);
PublishResponse publishResponse = await client.PublishAsync(publishRequest);
}
}
Expand Down
6 changes: 4 additions & 2 deletions src/JKang.EventBus.AmazonSqs/AmazonSqsEventPublisher.cs
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ public AmazonSqsEventPublisher(
_options = options;
}

public async Task PublishEventAsync<TEvent>(TEvent @event)
public async Task PublishEventAsync<TEvent>(TEvent @event, int delaySeconds = 0)
{
var regionEndpoint = RegionEndpoint.GetBySystemName(_options.Value.Region);
var client = new AmazonSQSClient(_options.Value.AccessKeyId, _options.Value.SecretAccessKey, regionEndpoint);
Expand All @@ -38,7 +38,9 @@ public async Task PublishEventAsync<TEvent>(TEvent @event)
QueueUrl = queueUrl
};

var result = await client.SendMessageAsync(request);
if (delaySeconds > 0)
await Task.Delay(delaySeconds * 1000);
var sendMessageResponse = await client.SendMessageAsync(request);
}
}
}
9 changes: 3 additions & 6 deletions src/JKang.EventBus.AmazonSqs/JKang.EventBus.AmazonSqs.csproj
Original file line number Diff line number Diff line change
Expand Up @@ -15,10 +15,10 @@
<NeutralLanguage>zh-Hans</NeutralLanguage>
<PackageIcon>icon.png</PackageIcon>
<PackageRequireLicenseAcceptance>true</PackageRequireLicenseAcceptance>
<Version>1.0.0</Version>
<Version>1.0.1</Version>
<PackageLicenseExpression></PackageLicenseExpression>
<PackageLicenseFile>LICENSE</PackageLicenseFile>
<PackageReleaseNotes>Small trial ox knife</PackageReleaseNotes>
<PackageReleaseNotes>Delayed execution of event handler</PackageReleaseNotes>
<PackageReadmeFile>README.md</PackageReadmeFile>
</PropertyGroup>

Expand All @@ -27,12 +27,9 @@
<PackageReference Include="Microsoft.Extensions.Options" Version="2.1.1" />
</ItemGroup>

<ItemGroup Condition="'$(Configuration)'=='Debug'">
<ItemGroup>
<ProjectReference Include="..\JKang.EventBus.Abstractions\JKang.EventBus.Abstractions.csproj" />
</ItemGroup>
<ItemGroup Condition="'$(Configuration)'=='Release'">
<PackageReference Include="JKang.EventBus.Abstractions" Version="1.1.0"/>
</ItemGroup>

<ItemGroup>
<None Include="LICENSE">
Expand Down
4 changes: 3 additions & 1 deletion src/JKang.EventBus.Core/InMemory/InMemoryEventBus.cs
Original file line number Diff line number Diff line change
Expand Up @@ -15,14 +15,16 @@ public InMemoryEventBus(IServiceProvider serviceProvider)
_serviceProvider = serviceProvider;
}

public async Task PublishEventAsync<TEvent>(TEvent @event)
public async Task PublishEventAsync<TEvent>(TEvent @event, int delaySeconds = 0)
{
using (IServiceScope scope = _serviceProvider.CreateScope())
{
Type eventType = @event.GetType();
Type openHandlerType = typeof(IEventHandler<>);
Type handlerType = openHandlerType.MakeGenericType(eventType);
IEnumerable<object> handlers = scope.ServiceProvider.GetServices(handlerType);
if (delaySeconds > 0)
await Task.Delay(delaySeconds * 1000);
foreach (object handler in handlers)
{
object result = handlerType
Expand Down
4 changes: 2 additions & 2 deletions src/JKang.EventBus.Core/Master/MasterEventBus.cs
Original file line number Diff line number Diff line change
Expand Up @@ -14,11 +14,11 @@ public MasterEventBus(
_eventPublishers = eventPublishers;
}

public async Task PublishEventAsync<TEvent>(TEvent @event)
public async Task PublishEventAsync<TEvent>(TEvent @event, int delaySeconds = 0)
{
foreach (IEventPublisher publisher in _eventPublishers.GetEventPublishers())
{
await publisher.PublishEventAsync(@event);
await publisher.PublishEventAsync(@event, delaySeconds);
}
}
}
Expand Down
13 changes: 6 additions & 7 deletions src/Samples.EventBus.Console/Program.cs
Original file line number Diff line number Diff line change
@@ -1,12 +1,13 @@
using JKang.EventBus;
using Microsoft.Extensions.DependencyInjection;
using System;
using System.Threading.Tasks;

namespace Samples.EventBus.ConsoleApp
{
class Program
{
static void Main(string[] args)
static async Task Main(string[] args)
{
IServiceCollection services = new ServiceCollection();

Expand All @@ -18,16 +19,14 @@ static void Main(string[] args)
subscriber.Subscribe<MyEvent, MyEventHandler>();
//subscriber.SubscribeAllHandledEvents<MyEventHandler>(); // other way
})
.PublishToAmazonSns(x => x.Region = "eu-west-3")
//.PublishToAmazonSns(x => x.Region = "eu-west-3")
;
});

IServiceProvider serviceProvider = services.BuildServiceProvider();
using (IServiceScope scope = serviceProvider.CreateScope())
{
IEventPublisher eventPublisher = scope.ServiceProvider.GetRequiredService<IEventPublisher>();
eventPublisher.PublishEventAsync(new MyEvent { Message = "Hello, event bus!" }).Wait();
}
using IServiceScope scope = serviceProvider.CreateScope();
IEventPublisher eventPublisher = scope.ServiceProvider.GetRequiredService<IEventPublisher>();
await eventPublisher.PublishEventAsync(new MyEvent { Message = "Hello, event bus!" }, 3);
}
}
}