DocumentStores 0.1.4
dotnet add package DocumentStores --version 0.1.4
NuGet\Install-Package DocumentStores -Version 0.1.4
<PackageReference Include="DocumentStores" Version="0.1.4" />
paket add DocumentStores --version 0.1.4
#r "nuget: DocumentStores, 0.1.4"
// Install DocumentStores as a Cake Addin #addin nuget:?package=DocumentStores&version=0.1.4 // Install DocumentStores as a Cake Tool #tool nuget:?package=DocumentStores&version=0.1.4
DocumentStores
A file-based key-value-store, using the popular Newtonsoft.Json serialization library.
Features include exception-handling via result-types, and semaphores for thread-safety.
Adding the Package
dotnet add package DocumentStores
Using the Store
// Define your model
class Person { public string name; public int age; }
// Create new json-file-store, using default directory: $(appData)/$(appName)/
var store = new JsonFileDocumentStore();
// Put some data
await store.PutDocumentAsync("person1", new Person { name = "Jan", age = 24 });
// Read the data.
// The store does not throw Exceptions (but ArgumentExceptions). All methods return results.
var result = await store.GetDocumentAsync<Person>("person1");
// Access the data or throw exception in case of errors.
Person person = result.Validate();
You can process the result in more sophisticated ways.
Using the Try-method,
if (result.Try(out Person? person, out Exception? ex))
HandleData(person!)
else
HandleError(ex!);
... or the Handle-method,
result.Handle(HandleData, HandleError);
Similar methods exist for result-tasks.
Person person = await store.GetDocumentAsync(...).ValidateAsync();
await store.GetDocumentAsync(...).HandleAsync(HandleData, HandleError);
Optimized Usage
You can define type-bound partitions within a store, so-called Topics.
var maintainerTopic = store.ToTopic<Person>("maintainers");
await maintainerTopic.PutAsync("jan", new Person { name = "Jan", age = 24 }).ValidateAsync();
await maintainerTopic.PutAsync("elisa", new Person { name = "Elisa", age = 22 }).ValidateAsync();
var maintainers = await maintainerTopic.GetAllAsync();
If you repeatedly access a single document, create a Channel, a syntactic shortcut for omitting the key.
var ownerChannel = maintainerTopic.ToChannel("jan");
Person owner = await ownerChannel.GetAsync().ValidateAsync();
owner.age += 1;
await ownerChannel.PutAsync(owner);
For caching scenarios, the .GetOrAdd() method comes in handy.
var data = await dataTopic.GetOrAddAsync("id", id => api.GetAsync(id));
The .AddOrUpdate() is useful when storing collections.
await settingsChannel.AddOrUpdateAsync(
initialData: ImmutableList.Create("val"),
updateData: list => list.Add("val")
);
Advanced Configuration
To chose a different location for the store, initialize it like so:
var store = new JsonFileDocumentStore(rootDirectory: "C:/Store");
Encryption is supported.
var store = new JsonFileDocumentStore(password: "myPassword");
More can be configured by using the options:
var options = JsonFileDocumentStoreOptions
.Default
.WithRootDirectory("C:/Temp")
.WithEncryptionOptions(
EncryptionOptions.Aes
.WithKey(new byte[] { 1, 2, 3, 4 })
.WithIV(new byte[] { 1, 2, 3, 4 })
)
);
var store = new JsonFileDocumentStore(options);
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- Microsoft.Extensions.DependencyInjection (>= 3.0.0)
- Newtonsoft.Json (>= 12.0.3)
- System.Collections.Immutable (>= 1.6.0)
- System.Reactive (>= 4.2.0)
- System.Text.Json (>= 4.6.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
- Fixed bug when calling from unmanaged code.