Kull.GenericBackend
0.13.2
See the version list below for details.
dotnet add package Kull.GenericBackend --version 0.13.2
NuGet\Install-Package Kull.GenericBackend -Version 0.13.2
<PackageReference Include="Kull.GenericBackend" Version="0.13.2" />
paket add Kull.GenericBackend --version 0.13.2
#r "nuget: Kull.GenericBackend, 0.13.2"
// Install Kull.GenericBackend as a Cake Addin #addin nuget:?package=Kull.GenericBackend&version=0.13.2 // Install Kull.GenericBackend as a Cake Tool #tool nuget:?package=Kull.GenericBackend&version=0.13.2
The Kull Generic Backend
This package allows Integration of a generic Stored Procedure-based Backend to Asp.Net MVC Core It uses Swashbuckle, Version 5+
Configuration
In Startup.cs, add the following services:
using Kull.GenericBackend;
// ...
public void ConfigureServices(IServiceCollection services)
{
services.AddMvcCore().AddApiExplorer(); //Or AddMvc() depending on your needs
services.AddGenericBackend(null, new Kull.GenericBackend.SwaggerGeneration.SwaggerFromSPOptions() {
});
// You have to inject a DbConnection somehow
services.AddTransient(typeof(DbConnection), (s) =>
{
var conf = s.GetRequiredService<IConfiguration>();
var constr = conf["ConnectionStrings:DefaultConnection"];
return new System.Data.SqlClient.SqlConnection(constr);
});
services.AddSwaggerGen(c=> {
c.SwaggerDoc("v1", new OpenApiInfo { Title = "My API", Version = "v1" });
c.AddGenericBackend();
});
}
public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
app.UseSwagger(o =>
{
// For compat with ng-swagger-gen on client. You can use ng-openapi-gen if set to false
o.SerializeAsV2 = true;
});
app.UseMvc(routeBuilder=>
{
// The package relies on integrated routing of Asp.net MVC Core
app.UseGenericBackend(routeBuilder);
});
// If needed, Swagger UI
app.UseSwaggerUI(c =>
{
c.SwaggerEndpoint("/swagger/v1/swagger.json", "My API V1");
});
}
In appsettings.json, set the connection string and the URI's:
{
"ConnectionStrings": {
"Default": "Data Source=SOMESERVER;Initial Catalog=SOMEDB;Integrated Security=True"
},
"Entities": {
"Cases": {
"Get": "api.spGetSomeCases"
},
"Cases/{CaseId|int}/Brands": {
"Get": "api.spGetBrands",
"Post": "api.spAddUpdateBrands"
}
}
}
In the "Entities" Section, the URL's are configured. Each entry correspondends to a URL. Each URL can be accessed by multiple HTTP Methods. Allowed are:
- GET for getting data, shoud NEVER update something
- POST for adding/updating. Maybe misused for getting data if the url gets longer then 2000 chars otherwise)
- PUT for updating data
- DELETE for deleting data
In the URL there can be route constraints as in MVC, however the | is used instead of : because of limitations of appsettings.json For a full documentation of allowed route constraints, please see here
For best practices for defining a REST Api, see here
Multi-value parameters
To use multiple values for a parameter, use a Sql Server User Defined Table Type for the parameter.
-- Create the data type
CREATE TYPE dbo.IdNameType AS TABLE
(
Id bigint,
Name nvarchar(1000),
PRIMARY KEY (Id)
)
GO
-- Create SP
CREATE PROCEDURE dbo.spTestBackend
@SomeId int,
@Ids dbo.IdNameType readonly
AS
BEGIN
-- ...
END
Main parts of the generic API
Middleware for handling the requests
The main part of the project is the Middleware that handles stored procedures. It is responsible for handling a request against some URL defined in the Entities Section, as seen above.
Middleware for Swagger
The other part is the middleware that is responsible for generating a swagger.json file out of the information of the database. This is done by using the sp_describe_first_result_set and INFORMATION_SCHEMA.parameters
It works by adding an IDocumentFilter to Swashbuckle. Swashbuckle generates the swagger.json This means you can mix this backend and your own Controllers and it will just work in the swagger.json.
Special parameters
There are so called System Parameters, which are parameters defined in any Stored Procedure which should be resolved by the Webserver and not by the Consumer of the API. Built-in are the following System Parameters:
- ADLogin & NTLogin: The Username in the HttpContext
- IPAddress: The IP Adress of the User
- UserAgent: The UserAgent of the Browser
If you would like to add something to this, you can Subclass the SystemParameters class and replace the default implementation by using Asp.Net Core Dependency Injection.
Possible futher development
- Port to .Net Core 3.0
- Direct manipulation of tables/views without Stored Procedures
- Support for other databases, eg Sqlite for Testing
- More Unit Tests
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. |
.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
- Kull.Data (>= 5.1.0)
- Kull.DatabaseMetadata (>= 0.9.0)
- Microsoft.AspNetCore.Hosting.Abstractions (>= 2.1.1)
- Microsoft.AspNetCore.Routing (>= 2.1.1)
- Swashbuckle.AspNetCore.SwaggerGen (>= 5.0.0-rc2)
NuGet packages (3)
Showing the top 3 NuGet packages that depend on Kull.GenericBackend:
Package | Downloads |
---|---|
Kull.GenericBackend.OData
Package Description |
|
Kull.GenericBackend-Sanitizer
Package Description |
|
Kull.GenericBackend.Sanitizer
Package Description |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
2.6.0-alpha | 233 | 12/4/2023 |
2.5.4 | 1,301 | 11/29/2022 |
2.5.3 | 330 | 11/29/2022 |
2.5.2 | 325 | 11/29/2022 |
2.5.1 | 348 | 11/29/2022 |
2.5.0 | 391 | 11/22/2022 |
2.4.2 | 460 | 11/18/2022 |
2.4.1 | 445 | 11/17/2022 |
2.4.0-beta5 | 234 | 9/22/2022 |
2.4.0-beta4 | 156 | 9/22/2022 |
2.4.0-beta3 | 184 | 9/8/2022 |
2.4.0-beta2 | 201 | 7/19/2022 |
2.4.0-beta1 | 172 | 7/19/2022 |
2.3.0 | 876 | 7/1/2022 |
2.2.0-beta9 | 170 | 6/14/2022 |
2.2.0-beta8 | 475 | 5/27/2022 |
2.2.0-beta7 | 205 | 5/4/2022 |
2.2.0-beta6 | 202 | 2/17/2022 |
2.2.0-beta4 | 196 | 2/17/2022 |
2.2.0-beta3 | 231 | 1/19/2022 |
2.2.0-beta2 | 269 | 1/18/2022 |
2.2.0-beta1 | 189 | 1/14/2022 |
2.1.4 | 846 | 1/13/2022 |
2.1.3 | 493 | 1/12/2022 |
2.1.2 | 633 | 1/11/2022 |
2.1.1 | 884 | 12/3/2021 |
2.1.0 | 1,019 | 12/3/2021 |
2.1.0-beta1 | 761 | 12/1/2021 |
2.0.3 | 357 | 12/1/2021 |
2.0.2 | 356 | 12/1/2021 |
2.0.1 | 333 | 12/1/2021 |
2.0.0 | 337 | 11/30/2021 |
2.0.0-beta9 | 4,928 | 11/24/2021 |
2.0.0-beta8 | 264 | 11/13/2021 |
2.0.0-beta7 | 391 | 10/25/2021 |
2.0.0-beta6 | 231 | 10/25/2021 |
2.0.0-beta5 | 283 | 10/25/2021 |
2.0.0-beta4 | 222 | 10/6/2021 |
2.0.0-beta3 | 258 | 10/5/2021 |
2.0.0-beta2 | 266 | 9/30/2021 |
1.5.3 | 464 | 8/13/2021 |
1.5.2 | 392 | 8/11/2021 |
1.5.1 | 431 | 8/9/2021 |
1.5.0 | 507 | 8/1/2021 |
1.4.4 | 504 | 8/1/2021 |
1.4.3 | 477 | 7/29/2021 |
1.4.2 | 557 | 4/13/2021 |
1.4.1 | 409 | 4/13/2021 |
1.4.0 | 432 | 4/6/2021 |
1.3.9 | 427 | 2/11/2021 |
1.3.8 | 580 | 1/25/2021 |
1.3.7 | 448 | 1/15/2021 |
1.3.6 | 451 | 1/15/2021 |
1.3.5 | 567 | 12/8/2020 |
1.3.4 | 490 | 12/8/2020 |
1.3.2 | 673 | 9/9/2020 |
1.3.1 | 554 | 9/9/2020 |
1.3.0 | 538 | 8/19/2020 |
1.2.4 | 557 | 8/18/2020 |
1.2.3 | 587 | 8/12/2020 |
1.2.2 | 516 | 8/12/2020 |
1.2.1 | 549 | 7/16/2020 |
1.2.0 | 547 | 7/16/2020 |
1.1.0 | 657 | 6/1/2020 |
1.1.0-beta3 | 368 | 5/25/2020 |
1.1.0-beta2 | 348 | 5/20/2020 |
1.1.0-beta1 | 335 | 5/20/2020 |
1.1.0-alpha3 | 358 | 5/20/2020 |
1.1.0-alpha2 | 362 | 5/20/2020 |
1.1.0-alpha1 | 357 | 5/20/2020 |
1.0.0-rc3 | 349 | 5/19/2020 |
1.0.0-rc2 | 345 | 5/14/2020 |
1.0.0-rc1 | 313 | 5/14/2020 |
1.0.0-beta3 | 363 | 5/6/2020 |
1.0.0-beta2 | 362 | 5/4/2020 |
1.0.0-beta1 | 375 | 4/30/2020 |
0.15.4 | 672 | 3/18/2020 |
0.15.3 | 614 | 3/18/2020 |
0.14.2 | 668 | 11/22/2019 |
0.14.1 | 1,239 | 10/2/2019 |
0.13.5 | 641 | 9/25/2019 |
0.13.4 | 640 | 9/12/2019 |
0.13.3 | 606 | 9/11/2019 |
0.13.2 | 608 | 9/10/2019 |
0.13.1 | 628 | 9/10/2019 |
0.13.0 | 675 | 8/14/2019 |