Darp.Utils.Configuration
1.12.0
See the version list below for details.
dotnet add package Darp.Utils.Configuration --version 1.12.0
NuGet\Install-Package Darp.Utils.Configuration -Version 1.12.0
<PackageReference Include="Darp.Utils.Configuration" Version="1.12.0" />
paket add Darp.Utils.Configuration --version 1.12.0
#r "nuget: Darp.Utils.Configuration, 1.12.0"
// Install Darp.Utils.Configuration as a Cake Addin #addin nuget:?package=Darp.Utils.Configuration&version=1.12.0 // Install Darp.Utils.Configuration as a Cake Tool #tool nuget:?package=Darp.Utils.Configuration&version=1.12.0
Darp.Utils
This repository bundles all open source c# helper modules of 'rosslight GmbH'. To extend, add a new project and test project.
Darp.Utils.Assets
A collection of simple interfaces for app assets targeting desktop apps.
Currently implemented:
IFolderAssetsService
: Read or write to a specific folderIAppDataAssetsService
: Read or write to theApplicationData
. The relativePath might be e.g. the app name.IProgramDataAssetsService
: Read or write to theProgramData
. The relativePath might be e.g. the app name.IBaseDirectoryAssetsService
: Read from the base directory of the App's executableIEmbeddedResourceAssetsService
: Read files marked asEmbeddedResource
of a specific Assembly
Example:
// Add EmbeddedResources and AppData assets to the DI Container
ServiceProvider provider = new ServiceCollection()
.AddEmbeddedResourceAssetsService(typeof(Test).Assembly)
.AddAppDataAssetsService("RelativePath")
.BuildServiceProvider();
// Example read and write operations with the app data
IAppDataAssetsService service = provider.GetRequiredService<IAppDataAssetsService>();
await service.SerializeJsonAsync("test.json", new Test("value"));
Test deserialized = await service.DeserializeJsonAsync<Test>("test.json");
await service.WriteTextAsync("test2.txt", "some content");
// Copy an embedded resource to the app data
IEmbeddedResourceAssetsService resourceService = provider.GetRequiredService<IEmbeddedResourceAssetsService>();
await resourceService.CopyToAsync("test.json", service, "test.json");
file sealed record Test(string Prop1);
Darp.Utils.Configuration
A writable configuration service. Can be registered using DI and injected into target services. Usage might include reading, writing and listening to changes via the INotifyPropertyChanged interface.
Example:
ServiceProvider provider = new ServiceCollection()
.AddAppDataAssetsService("RelativePath")
.AddConfigurationFile<TestConfig, IAppDataAssetsService>("config.json")
.BuildServiceProvider();
IConfigurationService<TestConfig> service = provider.GetRequiredService<IConfigurationService<TestConfig>>();
TestConfig config = await service.LoadConfigurationAsync();
await service.WriteConfigurationAsync(config with { Setting = "NewValue" });
Darp.Utils.Dialog
A lightweight dialog service which allows for opening dialogs from the ViewModel.
Implementation | Description |
---|---|
Implementation based on FluentAvalonia |
Example:
ServiceProvider provider = new ServiceCollection()
.AddSingleton<IDialogService, AvaloniaDialogService>()
.BuildServiceProvider();
IDialogService dialogService = provider.GetRequiredService<IDialogService>();
// Specify the Type of the dataContext of the window the dialog is supposed to be shown on
// .WithDialogRoot<MainWindowViewModel>()
await dialogService.CreateMessageBoxDialog("Title", "Message").ShowAsync();
// Assumes you have registered a view for 'SomeViewModel' in a ViewLocator
// Works with any kind of content
var viewModel = new SomeViewModel();
await dialogService.CreateContentDialog("Title", viewModel)
.SetDefaultButton(ContentDialogButton.Primary)
.SetCloseButton("Close")
.SetPrimaryButton("Ok", onClick: model => model.IsModelValid)
.ShowAsync();
Darp.Utils.ResxSourceGenerator
A source generator for generating strongly typed singleton resource classes from .resx files. Additional documentation here.
Darp.Utils.TestRail
A library allowing for communication with a TestRail instance in a easy and modern way.
Core features:
- Modern: Build on the latest .Net technologies. NativeAot compatible
- Extensible:
ITestRailService
is the core with a bunch of extension methods defining the actual API - Testable: Operates purely on the interface
ITestRailService
which can be mocked easily
Getting started:
var service = TestRailService.Create("https://[your-organization].testrail.io", "username", "passwordOrApiKey");
var projectsEnumerable = service.GetProjects(ProjectsFilter.ActiveProjectsOnly);
await foreach (var project in projectsEnumerable)
{
var casesEnumerable = service.GetCases(project.Id);
}
var caseResponse = await service.GetCaseAsync((CaseId)1);
var customProperty = caseResponse.Properties["custom_property"].GetString();
await service.UpdateCase(new UpdateCaseRequest { CaseId = caseResponse.Id, Title = "New Title" });
Extension methods:
public static async Task<GetCaseResponse> GetCaseAsync(this ITestRailService testRailService, CaseId caseId)
{
var jsonTypeInfo = YourSourceGenerationContext.Default.GetCaseResponse;
return await testRailService.GetAsync($"/get_case/{(int)caseId}", jsonTypeInfo, default(cancellationToken));
}
Usage with IHttpClientFactory
for http client caching:
var provider = new ServiceCollection()
.AddHttpClient("TestRailClient", (provider, client) =>
{
client.BaseAddress = new Uri("https://[your-organization].testrail.io");
var authBytes = Encoding.UTF8.GetBytes("username:passwordOrApiKey");
var base64Authorization = Convert.ToBase64String(authBytes);
client.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Basic", base64Authorization);
client.DefaultRequestHeaders.Add("Accept", "application/json");
})
.AddSingleton<ITestRailService>(provider => new TestRailService<IHttpClientFactory>(
provider.GetRequiredService<IHttpClientFactory>(),
factory => factory.CreateClient("TestRailClient"),
NullLogger.Instance))
.BuildServiceProvider();
var service = provider.GetRequiredService<ITestRailService>();
Product | Versions 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 is compatible. 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. |
-
net8.0
- Darp.Utils.Assets (>= 1.12.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 9.0.0)
-
net9.0
- Darp.Utils.Assets (>= 1.12.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 9.0.0)
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 |
---|---|---|
1.12.3 | 98 | 12/17/2024 |
1.12.2 | 118 | 12/12/2024 |
1.12.1 | 91 | 12/11/2024 |
1.12.0 | 75 | 12/11/2024 |
1.11.4 | 85 | 12/10/2024 |
1.11.3 | 82 | 12/10/2024 |
1.11.2 | 78 | 12/10/2024 |
1.11.1 | 86 | 12/9/2024 |
1.11.0 | 86 | 12/9/2024 |
1.10.0 | 164 | 10/21/2024 |
1.9.2 | 154 | 10/19/2024 |
1.9.1 | 139 | 10/19/2024 |
1.9.0 | 111 | 9/30/2024 |
1.8.0 | 105 | 9/26/2024 |
1.7.4 | 100 | 9/23/2024 |
1.7.3 | 98 | 9/22/2024 |
1.7.2 | 94 | 9/22/2024 |
1.7.1 | 96 | 9/22/2024 |
1.7.0 | 92 | 9/22/2024 |
1.6.3 | 226 | 9/10/2024 |
1.6.2 | 127 | 9/9/2024 |
1.6.1 | 123 | 9/9/2024 |
1.6.0 | 126 | 9/9/2024 |
1.5.1 | 124 | 9/7/2024 |
1.5.0 | 123 | 9/5/2024 |
1.4.0 | 167 | 8/11/2024 |
1.3.0 | 123 | 8/9/2024 |
1.2.1 | 121 | 8/9/2024 |
1.2.0 | 121 | 8/9/2024 |
1.1.0 | 118 | 8/8/2024 |
1.0.1 | 123 | 8/8/2024 |
1.0.0 | 127 | 8/8/2024 |