NpgsqlRest 1.6.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package NpgsqlRest --version 1.6.0                
NuGet\Install-Package NpgsqlRest -Version 1.6.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="NpgsqlRest" Version="1.6.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add NpgsqlRest --version 1.6.0                
#r "nuget: NpgsqlRest, 1.6.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install NpgsqlRest as a Cake Addin
#addin nuget:?package=NpgsqlRest&version=1.6.0

// Install NpgsqlRest as a Cake Tool
#tool nuget:?package=NpgsqlRest&version=1.6.0                

NpgsqlRest

build-test-publish License GitHub Stars GitHub Forks

Automatic REST API for PostgreSQL Databases implemented as AOT Ready .NET8 Middleware

Read the introductory blog post.

See the changelog for the latest release changes changelog.md.

1) Your PostgreSQL Function
create function hello_world()                                    
returns text 
language sql
as $$
select 'Hello World'
$$;
2) .NET8 AOT Ready Web App
var builder = WebApplication.CreateSlimBuilder(args);
var app = builder.Build();
var connectionStr = "Host=localhost;Port=5432;Database=my_db;Username=postgres;Password=postgres";
app.UseNpgsqlRest(new(connectionStr));
app.Run();
3) Optionally, Auto-Generated HTTP File
@host=http://localhost:5000                                      

// function public.hello_world()
// returns text
POST {{host}}/api/hello-world/
4) Endpoint Response
HTTP/1.1 200 OK                                                  
Connection: close
Content-Type: text/plain
Date: Tue, 09 Jan 2024 14:25:26 GMT
Server: Kestrel
Transfer-Encoding: chunked

Hello World

Features

  • Automatic generation of the HTTP REST endpoints from PostgreSQL functions and procedures.
  • Native AOT Ready. AOT is ahead-of-time compiled to the native code. No dependencies, native executable, it just runs and it's very fast.
  • Customization of endpoints with comment annotations. You can easily configure any endpoint by adding annotation labels to routine comments. Like for example HTTP GET if you want to change the method verb to GET.
  • Automatic HTTP files. Create ready-to-run HTTP files easily, for testing, debugging and discovery.
  • Interact seamlessly with .NET8 backend and take advantage of .NET8 features.
  • High performance with or without native AOT, up to 6 times higher throughput than similar solutions.

Automatic Generation of REST Endpoints

See the introductory example above. Automatically build HTTP REST endpoints from PostgreSQL functions and procedures and configure them the way you like.

Native AOT Ready

With the NET8 you can build into native code code (ahead-of-time (AOT) compilation).

NpgsqlRest is fully native AOT-ready and AOT-tested.

AOT builds have faster startup time, smaller memory footprints and don't require any .NET runtime installed.

Comment Annotations

Configure individual endpoints with powerful and simple routine comment annotations. You can use any PostgreSQL administration tool or a simple script:

Function:

create function hello_world_html()                               
language sql 
as 
$$
select '<div>Hello World</div>';
$$

comment on function hello_world_html() is '
HTTP GET /hello
Content-Type: text/html';

Will have content type text/html as visible in comment annotation:

Connection: close                                                
Content-Type: text/html
Date: Thu, 18 Jan 2024 11:00:39 GMT
Server: Kestrel
Transfer-Encoding: chunked

<div>Hello World</div>

Automatic HTTP Files

Create automatically [HTTP file(s) with ready-to-run randomized test example calls.

NET8 backend

NpgsqlRest is implemented as a NET8 middleware component, which means that anything that is available in NET8 is also available to the NpgsqlRest REST endpoints.

And that is, well, everything... from rate limiters to all kinds of authorization schemas, to name a few.

You can also interact with the NET8 calling code to:

  • Provide custom parameter validations.
  • Pass custom values to function/procedure parameters.

For example, pass a Context.User.Identity.Name to every parameter named user:

var app = builder.Build();                                       
app.UseNpgsqlRest(new(connectionString)
{
    ValidateParameters = p =>
    {
        if (p.Context.User.Identity?.IsAuthenticated == true && 
            string.Equals(p.ParamName, "user", StringComparison.OrdinalIgnoreCase))
        {
            p.Parameter.Value = p.Context.User.Identity.Name;
        }
    } 
});
app.Run();

High Performances

K6 performance tests, 10 seconds, 100 virtual users.

PostgREST:

   ✓ http_req_duration..............: avg=37.91ms min=559.1µs  med=1.67ms  max=1.5s    p(90)=113.81ms p(95)=200.96ms
     http_reqs......................: 13377   1315.56161/s

NpgsqlRest AOT build:

   ✓ http_req_duration..............: avg=5.65ms   min=524.55µs med=4.61ms  max=77.83ms p(90)=10.9ms   p(95)=13.61ms
     http_reqs......................: 86458   8624.438772/s

In simple terms, for a period of a 10 seconds, and for 100 simulated virtual concurrent users, PostgREST has generated 13377 succesful requests with average duration of 37.91ms, and NpgsqlRest AOT build has generated 86458 succesful requests with average duration of 5.65ms.

See more details here.

Getting Started

Installation

Install the package from NuGet by using any of the available methods:

dotnet add package NpgsqlRest --version 1.6.0
NuGet\Install-Package NpgsqlRest -version 1.6.0
<PackageReference Include="NpgsqlRest" Version="1.6.0" />
#r "nuget: NpgsqlRest, 1.6.0"

First Use

Your application builder code:

var app = builder.Build();
app.UseNpgsqlRest(new("Host=localhost;Port=5432;Database=my_db;Username=postgres;Password=postgres"));
app.Run();

For all available build options, please consult a source code file, until the documentation website is built.

Dependencies

  • net8.0
  • Microsoft.NET.Sdk.Web 8.0
  • Npgsql 8.0.1
  • PostgreSQL >= 13

Note: PostgreSQL 13 minimal version is required to run the initial query to get the list of functions. The source code of this query can be found here. For versions prior to version 13, this query can be replaced with a custom query that can run on older versions.

Contributing

Contributions from the community are welcomed. Please make a pull request with a description if you wish to contribute.

License

This project is licensed under the terms of the MIT license.

Product 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (3)

Showing the top 3 NuGet packages that depend on NpgsqlRest:

Package Downloads
NpgsqlRest.TsClient

Automatic Typescript Client Code Generation for NpgsqlRest

NpgsqlRest.CrudSource

CRUD Source for NpgsqlRest

NpgsqlRest.HttpFiles

Automatic HTTP Files Generation for NpgsqlRest

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2.14.0 36 11/25/2024
2.13.1 34 11/23/2024
2.13.0 82 11/17/2024
2.12.1 85 11/6/2024
2.12.0 76 10/30/2024
2.11.0 122 9/3/2024
2.10.0 125 8/23/2024
2.9.0 60 8/2/2024
2.8.5 110 6/25/2024
2.8.4 104 6/22/2024
2.8.3 106 6/11/2024
2.8.2 108 6/9/2024
2.8.1 88 5/10/2024
2.8.0 92 5/2/2024
2.7.1 111 4/30/2024
2.7.0 125 4/17/2024
2.6.1 117 4/16/2024
2.6.0 114 4/16/2024
2.5.0 120 4/15/2024
2.4.2 136 4/14/2024
2.4.1 112 4/12/2024
2.4.0 181 4/8/2024
2.3.1 112 4/5/2024
2.3.0 143 4/4/2024
2.2.0 103 4/2/2024
2.1.0 121 3/29/2024
2.0.0 138 3/26/2024
1.6.3 114 2/19/2024
1.6.2 126 2/3/2024
1.6.1 113 2/2/2024
1.6.0 107 1/28/2024
1.5.1 97 1/27/2024
1.5.0 107 1/27/2024
1.4.0 104 1/26/2024
1.3.0 113 1/23/2024
1.2.0 119 1/22/2024
1.1.0 119 1/19/2024
1.0.0 125 1/18/2024
0.0.9 100 1/18/2024