-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathRegistryDemo.cs
58 lines (52 loc) · 1.94 KB
/
RegistryDemo.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
using System;
using System.Linq;
using System.Threading.Tasks;
using Demo.SmartCache.GrainInterfaces;
using Demo.SmartCache.GrainInterfaces.State;
using Orleans;
using Patterns.DevBreadboard;
namespace Patterns.SmartCache.Host
{
internal class RegistryDemo
{
// Partial Application FTW!
private static Func<Guid, int, Task> CreateAndRegisterCatalogItem(ICatalogItemRegistryGrain registryGrain)
=> async (id, index) =>
{
var grainId = id;
var grainState =
new CatalogItem
{
DisplayName = $"Item {index}",
SKU = id.ToString(),
ShortDescription = $"This is the {index}th item"
};
var grain = GrainClient.GrainFactory.GetGrain<ICatalogItemGrain>(grainId);
await grain.SetItem(grainState);
await registryGrain.RegisterGrain(grain);
};
private static Task SetupCatalog()
{
var catalogRegistry = GrainClient.GrainFactory.GetGrain<ICatalogItemRegistryGrain>(Constants.RegistryId);
var tasks = Constants.ItemIds.Select(CreateAndRegisterCatalogItem(catalogRegistry));
return Task.WhenAll(tasks.ToArray());
}
private static async Task ReadCatalog()
{
var catalogRegistry = GrainClient.GrainFactory.GetGrain<ICatalogItemRegistryGrain>(Constants.RegistryId);
var items = await catalogRegistry.GetRegisteredGrains();
foreach (var item in items)
{
var state = await item.GetItem();
Console.WriteLine(state);
}
}
public static void Run()
{
SetupCatalog()
.ContinueWith(_ => ReadCatalog())
.ContinueWith(_ => DevelopmentSiloHost.WaitForInteraction())
.Wait();
}
}
}