![]() |
VOOZH | about |
dotnet add package GitObjectDb.SystemTextJson --version 0.3.11-alpha
NuGet\Install-Package GitObjectDb.SystemTextJson -Version 0.3.11-alpha
<PackageReference Include="GitObjectDb.SystemTextJson" Version="0.3.11-alpha" />
<PackageVersion Include="GitObjectDb.SystemTextJson" Version="0.3.11-alpha" />Directory.Packages.props
<PackageReference Include="GitObjectDb.SystemTextJson" />Project file
paket add GitObjectDb.SystemTextJson --version 0.3.11-alpha
#r "nuget: GitObjectDb.SystemTextJson, 0.3.11-alpha"
#:package GitObjectDb.SystemTextJson@0.3.11-alpha
#addin nuget:?package=GitObjectDb.SystemTextJson&version=0.3.11-alpha&prereleaseInstall as a Cake Addin
#tool nuget:?package=GitObjectDb.SystemTextJson&version=0.3.11-alpha&prereleaseInstall as a Cake Tool
GitObjectDb simplifies the configuration management versioning by backing it in Git.
| Name | Badge |
|---|---|
| GitObjectDb | 👁 NuGet Badge |
| GitObjectDb.SystemTextJson | 👁 NuGet Badge |
| GitObjectDb.YamlDotNet | 👁 NuGet Badge |
| GitObjectDb.Api.OData | 👁 NuGet Badge |
| GitObjectDb.Api.GraphQL | 👁 NuGet Badge |
| GitObjectDb.Api.ProtoBuf | 👁 NuGet Badge |
| GitObjectDb.Api.ProtoBuf.Model | 👁 NuGet Badge |
👁 Build Status
👁 alternate text is missing from this package README image
👁 alternate text is missing from this package README image
👁 alternate text is missing from this package README image
👁 alternate text is missing from this package README image
GitObjectDb is designed to simplify the configuration management versioning. It does so by removing the need for hand-coding the commands needed to interact with Git.
The Git repository is used as a pure database as the files containing the serialized copy of the objects are never fetched in the filesystem. GitObjectDb only uses the blob storage provided by Git.
Here's a simple example:
[GitFolder("Applications")]
public record Application : Node
{
public string Name { get; init; }
public string Description { get; init; }
}
[GitFolder("Pages")]
public record Table : Node
{
public string Name { get; init; }
public string Description { get; init; }
[StoreAsSeparateFile(Extension = "txt")]
public string? RichContent { get; init; }
}
var existingApplication = connection.Lookup<Application>("main", "applications", new UniqueId(id));
var newTable = new Table { ... };
connection
.Update("main", c => c.CreateOrUpdate(newTable, parent: existingApplication))
.Commit(new("Added new table.", author, committer));
var node = new SomeNode
{
SomeProperty = "Value stored as json",
RichContent = "Value stored as raw text in separate Git blob, next to primary one",
}:
... gets stored in Git as follows:
{
"$type": "Sample.SomeNode",
"id": "zerzrzrz",
"someProperty": "Value stored as json"
}
Value stored many dynamic resources in separate Git blob, next to primary one
You can also store resources as separate files:
new Resource(node, "Some/Folder", "File.txt", new Resource.Data("Value stored in a separate file in <node path>/Resources/Some/Folder/File.txt"));
connection
.Update("main", c => c.CreateOrUpdate(table with { Description = newDescription }))
.Commit(new("Some message", signature, signature));
connection.Checkout("newBranch", "main~1");
connection
.Update("main", c => c.CreateOrUpdate(table with { Name = newName }))
.Commit(new("Another message", signature, signature));
var comparison = connection.Compare("main~5", "main");
var nodeChanges = comparison.Modified.OfType<Change.NodeChange>();
Node references allows linking existing nodes in a repository:
public record Order : Node
{
public Client Client { get; set; }
// ...
}
public record Client : Node
{
// ...
}
// Nodes get loaded with their references (using a shared )
var cache = new Dictionary<DataPath, ITreeItem>();
var order = connection.GetNodes<Order>("main", referenceCache: cache).First();
Console.WriteLine(order.Client.Id);
// main: A---B A---B
// \ -> \ \
// newBranch: C C---x
connection
.Update("main", c => c.CreateOrUpdate(table with { Description = newDescription }))
.Commit(new("B", signature, signature));
connection.Repository.Branches.Add("newBranch", "main~1");
connection
.Update("newBranch", c => c.CreateOrUpdate(table with { Name = newName }))
.Commit(new("C", signature, signature));
sut.Merge(upstreamCommittish: "main");
Imagine a scenario where you define in your code a first type:
[GitFolder(FolderName = "Items", UseNodeFolders = false)]
[IsDeprecatedNodeType(typeof(SomeNodeV2))]
private record SomeNodeV1 : Node
{
public int Flags { get; set; }
}
[GitFolder(FolderName = "Items", UseNodeFolders = false)]
private record SomeNodeV2 : Node
{
public BindingFlags TypedFlags { get; set; }
}
You then want to introduce a new change so that the Flags property contains more meaningful information, relying on enums:
[GitFolder(FolderName = "Items", UseNodeFolders = false)]
private record SomeNodeV2 : Node
{
public BindingFlags TypedFlags { get; set; }
}
All you need to do is to #1 add the [IsDeprecatedNodeType(typeof(SomeNodeV2))] attribute. This will instruct the deserializer to convert nodes to new version, using a converter. #2 converter needs to be provided in the model. You can use AutoMapper or other tools at your convenience.
[GitFolder(FolderName = "Items", UseNodeFolders = false)]
[IsDeprecatedNodeType(typeof(SomeNodeV2))]
private record SomeNodeV1 : Node
{
// ...
}
var model = new ConventionBaseModelBuilder()
.RegisterType<SomeNodeV1>()
.RegisterType<SomeNodeV2>()
.AddDeprecatedNodeUpdater(UpdateDeprecatedNode)
.Build();
Node UpdateDeprecatedNode(Node old, Type targetType)
{
var nodeV1 = (SomeNodeV1)old;
return new SomeNodeV2
{
Id = old.Id,
TypedFlags = (BindingFlags)nodeV1.Flags,
};
}
See documentation.
The MIT license (Refer to the LICENSE file).
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net8.0 net8.0 is compatible. net8.0-android net8.0-android was computed. net8.0-browser net8.0-browser was computed. net8.0-ios net8.0-ios was computed. net8.0-maccatalyst net8.0-maccatalyst was computed. net8.0-macos net8.0-macos was computed. net8.0-tvos net8.0-tvos was computed. net8.0-windows net8.0-windows was computed. net9.0 net9.0 was computed. net9.0-android net9.0-android was computed. net9.0-browser net9.0-browser was computed. net9.0-ios net9.0-ios was computed. net9.0-maccatalyst net9.0-maccatalyst was computed. net9.0-macos net9.0-macos was computed. net9.0-tvos net9.0-tvos was computed. net9.0-windows net9.0-windows was computed. net10.0 net10.0 was computed. net10.0-android net10.0-android was computed. net10.0-browser net10.0-browser was computed. net10.0-ios net10.0-ios was computed. net10.0-maccatalyst net10.0-maccatalyst was computed. net10.0-macos net10.0-macos was computed. net10.0-tvos net10.0-tvos was computed. net10.0-windows net10.0-windows was computed. |
This package is not used by any NuGet packages.
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 0.3.11-alpha | 166 | 1/6/2025 |
| 0.3.10-alpha | 158 | 1/1/2025 |
| 0.3.3-alpha | 130 | 12/17/2024 |
| 0.2.155-alpha | 167 | 3/29/2024 |
| 0.2.59-alpha | 291 | 11/9/2023 |
| 0.2.52-alpha | 253 | 5/19/2023 |
| 0.2.42-alpha | 227 | 3/28/2023 |
| 0.2.33-alpha | 220 | 3/7/2023 |
| 0.2.32-alpha | 241 | 3/7/2023 |
| 0.2.31-alpha | 241 | 3/7/2023 |
| 0.2.30-alpha | 227 | 2/4/2023 |
| 0.2.18-alpha | 236 | 12/22/2022 |
| 0.2.16-alpha | 273 | 11/15/2022 |
| 0.2.13-alpha | 269 | 10/18/2022 |
| 0.2.11-alpha | 252 | 9/28/2022 |
| 0.2.4-alpha | 280 | 9/22/2022 |
| 0.2.2-alpha | 276 | 9/21/2022 |