DEV Community

Oleksandr Viktor
Oleksandr Viktor

Posted on

Experiment with a universal CRUD API using UkrGuru.Sql

In this article, we'll walk through the process of creating a universal CRUD API using ASP.NET Core and UkrGuru.Sql. This API will support various HTTP methods to execute stored procedures, making it a versatile tool for database interactions.

Setting Up the Project

First, let's set up our ASP.NET Core project. We'll start by creating a new Web Application project:

dotnet new webapi -n ApiProject
cd ApiProject
Enter fullscreen mode Exit fullscreen mode

Adding Dependencies

Next, we'll add the necessary dependencies to our project. We'll use UkrGuru.Sql for database interactions and Microsoft.AspNetCore.Mvc for building our API.

using Microsoft.AspNetCore.Mvc;
using UkrGuru.Sql;
Enter fullscreen mode Exit fullscreen mode

Defining Constants

We'll define constants for our API pattern and suffix:

const string ApiHolePattern = "ApiHole";
const string ApiProcSufix = "_Api";
Enter fullscreen mode Exit fullscreen mode

Configuring Services

We'll configure the services in the Program.cs file. This includes registering the database service with dependency injection and adding controllers with a custom input formatter for plain text.

var builder = WebApplication.CreateBuilder(args);

builder.Services.AddScoped<IDbService, DbService>();
builder.Services.AddControllers();
builder.Services.AddOpenApi();
Enter fullscreen mode Exit fullscreen mode

Adding Configuration Settings

We'll add the following configuration settings to the appsettings.json file to set up logging and the database connection:

{
  "Logging": {
    "LogLevel": {
      "Default": "Information",
      "Microsoft.AspNetCore": "Warning",
      "UkrGuru.SqlJson": "Information"
    }
  },
  "AllowedHosts": "*",
  "ConnectionStrings": {
    "DefaultConnection": "Server=(localdb)\\mssqllocaldb;Integrated Security=true;Database=Northwind;"
  }
}
Enter fullscreen mode Exit fullscreen mode

Building the Application

Next, we'll build the application and configure the HTTP request pipeline for the development environment. We'll also enforce HTTPS redirection.

var app = builder.Build();

if (app.Environment.IsDevelopment())
{
    app.MapOpenApi();
}

app.UseHttpsRedirection();
Enter fullscreen mode Exit fullscreen mode

Mapping Endpoints

We'll map the endpoints for executing stored procedures using various HTTP methods (POST, GET, PUT, DELETE).

app.MapPost($"{ApiHolePattern}/{{proc}}", async (IDbService db, string proc, [FromBody] object? data) =>
    await db.TryExecAsync<string?>($"{proc}{ApiProcSufix}", data?.ToJson()));

app.MapGet($"{ApiHolePattern}/{{proc}}", async (IDbService db, string proc, string? data) =>
    await db.TryExecAsync<string?>($"{proc}{ApiProcSufix}", data));

app.MapPut($"{ApiHolePattern}/{{proc}}", async (IDbService db, string proc, [FromBody] object? data) =>
    await db.TryExecAsync($"{proc}{ApiProcSufix}", data?.ToJson()));

app.MapDelete($"{ApiHolePattern}/{{proc}}", async (IDbService db, string proc, string? data) =>
    await db.TryExecAsync($"{proc}{ApiProcSufix}", data));
Enter fullscreen mode Exit fullscreen mode

Running the Application

Finally, we'll run the application:

app.Run();
Enter fullscreen mode Exit fullscreen mode

Setting Up the Database

To set up the database, use the following T-SQL script to create the stored procedures:

SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE PROCEDURE [dbo].[Shippers_Del_Api]
    @Data nvarchar(50)
AS
DELETE Shippers 
WHERE CompanyName = @Data
GO

CREATE PROCEDURE [dbo].[Shippers_Get_Api]
    @Data nvarchar(50)
AS
SELECT *
FROM Shippers 
WHERE CompanyName = @Data
FOR JSON PATH, WITHOUT_ARRAY_WRAPPER
GO

CREATE PROCEDURE [dbo].[Shippers_Ins_Api]
    @Data nvarchar(max)
AS
INSERT INTO Shippers (CompanyName, Phone)
OUTPUT inserted.ShipperID
SELECT CompanyName, Phone 
FROM OPENJSON(@Data) 
    WITH (CompanyName nvarchar(40), Phone nvarchar(24))
GO

CREATE PROCEDURE [dbo].[Shippers_Upd_Api]
    @Data nvarchar(max)
AS
UPDATE Shippers
SET Phone = D.Phone
FROM OPENJSON(@Data) 
    WITH (CompanyName nvarchar(40), Phone nvarchar(24)) D
WHERE Shippers.CompanyName = D.CompanyName
GO
Enter fullscreen mode Exit fullscreen mode

MinSqlApi.http File

To test the API, you can use the following MinSqlApi.http file. This file contains HTTP requests for executing stored procedures using different HTTP methods.

@MinSqlApi_HostAddress = http://localhost:5133

### POST request to execute a stored procedure
POST {{MinSqlApi_HostAddress}}/ApiHole/Shippers_Ins
Content-Type: application/json

{ 
  "CompanyName":"Nova Poshta",  
  "Phone":"(800) 111-1111" 
}

### GET request to execute a stored procedure
GET {{MinSqlApi_HostAddress}}/ApiHole/Shippers_Get?data=Nova%20Poshta

### PUT request to execute a stored procedure
PUT {{MinSqlApi_HostAddress}}/ApiHole/Shippers_Upd
Content-Type: application/json

{ 
  "CompanyName":"Nova Poshta",  
  "Phone":"(800) 222-2222" 
}

### DELETE request to execute a stored procedure
DELETE {{MinSqlApi_HostAddress}}/ApiHole/Shippers_Del?data=Nova%20Poshta
Enter fullscreen mode Exit fullscreen mode

Conclusion

By following these steps, you've created a versatile API that can handle various HTTP methods to execute stored procedures. This setup provides a solid foundation for building more complex and feature-rich APIs in the future.

For more details, you can check the source code here.
https://github.com/UkrGuru/Sql/blob/main/demos/MinSqlApi/MinSqlApi/Program.cs

UkrGuru.Sql package here
https://www.nuget.org/packages/UkrGuru.Sql/

Top comments (0)