GitObjectDb.Api.GraphQL
0.2.4-alpha
See the version list below for details.
dotnet add package GitObjectDb.Api.GraphQL --version 0.2.4-alpha
NuGet\Install-Package GitObjectDb.Api.GraphQL -Version 0.2.4-alpha
<PackageReference Include="GitObjectDb.Api.GraphQL" Version="0.2.4-alpha" />
paket add GitObjectDb.Api.GraphQL --version 0.2.4-alpha
#r "nuget: GitObjectDb.Api.GraphQL, 0.2.4-alpha"
// Install GitObjectDb.Api.GraphQL as a Cake Addin #addin nuget:?package=GitObjectDb.Api.GraphQL&version=0.2.4-alpha&prerelease // Install GitObjectDb.Api.GraphQL as a Cake Tool #tool nuget:?package=GitObjectDb.Api.GraphQL&version=0.2.4-alpha&prerelease
GitObjectDb simplifies the configuration management versioning by backing it in Git.
Name | Badge |
---|---|
GitObjectDb | |
GitObjectDb.Api | |
GitObjectDb.Api.OData | |
GitObjectDb.Api.GraphQL |
Overview
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:
- Define your own repository data model:
[GitFolder("Applications")] public record Application : Node { public string Name { get; set; } public string Description { get; set; } } [GitFolder("Pages")] public record Table : Node { public string Name { get; set; } public string Description { get; set; } }
- Manipulate objects as follows:
var existingApplication = connection.Lookup<Application>("applications", new UniqueId(id)); var newTable = new Table { ... }; connection .Update(c => c.CreateOrUpdate(newTable, parent: existingApplication)) .Commit("Added new table.", author, committer);
Features
Structured & unstructured data storage
var node = new SomeNode
{
SomeProperty = "Value stored as json",
EmbeddedResource = "Value stored as raw text in same Git blob",
}:
... gets stored in Git as follows:
{
"Type": "Sample.SomeNode, Sample, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null",
"Node": {
"$id": "SomeNodes/zerzrzrz.json",
"id": "zerzrzrz",
"someProperty": "Value stored as json"
}
}
/*
Value stored as raw text in same Git blob
*/
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"));
Branching
connection
.Update(c => c.CreateOrUpdate(table with { Description = newDescription }))
.Commit("Some message", signature, signature);
connection.Checkout("newBranch", "HEAD~1");
connection
.Update(c => c.CreateOrUpdate(table with { Name = newName }))
.Commit("Another message", signature, signature);
History
var commits = sut.Commits
.QueryBy(new CommitFilter
{
IncludeReachableFrom = sut.Head.Tip,
SortBy = CommitSortStrategies.Reverse | CommitSortStrategies.Topological,
})
.Take(5)
Compare commits
var comparison = connection.Compare("HEAD~1", repository.Head.Tip.Sha);
var nodeChanges = comparison.Modified.OfType<Change.NodeChange>();
Node references
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>(referenceCache: cache).First();
Console.WriteLine(order.Client.Id);
Merge, Rebase, Cherry-pick
// main: A---B A---B
// \ -> \ \
// newBranch: C C---x
connection
.Update(c => c.CreateOrUpdate(table with { Description = newDescription }))
.Commit("B", signature, signature);
connection.Checkout("newBranch", "HEAD~1");
connection
.Update(c => c.CreateOrUpdate(table with { Name = newName }))
.Commit("C", signature, signature);
sut.Merge(upstreamCommittish: "main");
Node versioning management
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,
};
}
Documentation
See Documentation.
Prerequisites
- .NET Standard 2.0 or 2.1
Online resources
- LibGit2Sharp (Requires NuGet 2.7+)
Quick contributing guide
- Fork and clone locally
- Create a topic specific branch. Add some nice feature. Do not forget the tests 😉
- Send a Pull Request to spread the fun!
License
The MIT license (Refer to the LICENSE file).
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. 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. |
-
net6.0
- AutoMapper (>= 11.0.1)
- AutoMapper.Extensions.Microsoft.DependencyInjection (>= 11.0.0)
- GitObjectDb.Api (>= 0.2.4-alpha)
- GraphQL.DataLoader (>= 7.0.2)
- GraphQL.MicrosoftDI (>= 7.0.2)
- GraphQL.SystemTextJson (>= 7.0.2)
- Namotion.Reflection (>= 2.0.10)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
0.2.155-alpha | 59 | 3/29/2024 |
0.2.59-alpha | 179 | 11/9/2023 |
0.2.52-alpha | 92 | 5/19/2023 |
0.2.47-alpha | 104 | 4/5/2023 |
0.2.42-alpha | 95 | 3/28/2023 |
0.2.33-alpha | 109 | 3/7/2023 |
0.2.32-alpha | 91 | 3/7/2023 |
0.2.31-alpha | 100 | 3/7/2023 |
0.2.30-alpha | 110 | 2/4/2023 |
0.2.18-alpha | 109 | 12/22/2022 |
0.2.16-alpha | 120 | 11/15/2022 |
0.2.13-alpha | 106 | 10/18/2022 |
0.2.11-alpha | 110 | 9/28/2022 |
0.2.4-alpha | 135 | 9/22/2022 |
0.2.2-alpha | 107 | 9/21/2022 |