KVPSButter 0.0.3-beta

This is a prerelease version of KVPSButter.
dotnet add package KVPSButter --version 0.0.3-beta                
NuGet\Install-Package KVPSButter -Version 0.0.3-beta                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="KVPSButter" Version="0.0.3-beta" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add KVPSButter --version 0.0.3-beta                
#r "nuget: KVPSButter, 0.0.3-beta"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install KVPSButter as a Cake Addin
#addin nuget:?package=KVPSButter&version=0.0.3-beta&prerelease

// Install KVPSButter as a Cake Tool
#tool nuget:?package=KVPSButter&version=0.0.3-beta&prerelease                

KVPSButter - Abstraction layer for key-value-pair storage

This project adds a simple abstraction for a key-value-pair based storage, similar to how a dictionary works in most programming languages. The interface is designed to work with network based storage but can also work with local storage, such as databases or filesystems.

Why KVPSButter ?

A common requirement for any program is to be able to read and write some kind of persitent storage. Traditionally, this has been done to local disk, but with virtualization, such as Docker this can be cumbersome in terms of backup and synchronization.

One approach to this has been to use FUSE which makes the filesystem-layer the abstraction. While this approach works because it requires little (if any) change to the application it is also suboptimal as it is exposed to the operation system and requires kernel support.

KVPSButter solves this problem by letting the storage destination be specified runtime, such that multiple applications can collaborate without writing applications for a specific storage. This does require that the application uses KVPSButter and is structured around a key-value-pair based storage, but besides this requirement, it is transparent to the application what implementation is actually used.

Examples

To get a connection, use the default loader:

var kvps = KVPSLoader.Default.Create("memory://");

From here it is possible to interact with the store:

await kvps.WriteAsync("key1", new MemoryStream(new byte[] { 1, 2, 3 }));
var data = kvps.ReadAsync("key1");

Destinations

As the key-value-pair abstraction is quite simple, most kinds of storage should support this. At the time of writing, the following are supported:

  • test://, memory:// stores data in-memory with no permant storage. Mostly for testing an temporary data

  • file://, local://, path:// stores data on the filesystem. This destination is also fairly simple, but will default to encode the keys with base64 to avoid illegal characters

  • s3, aws store data on an S3 compatible destination

Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • net8.0

    • No dependencies.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on KVPSButter:

Package Downloads
KVPSButter.S3

An S3 destination for the key-value-pair abstraction library

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
0.0.3-beta 59 7/31/2024
0.0.2-beta 539 2/12/2024
0.0.1-alpha 70 2/12/2024