Formula.SimpleAPI
1.0.3.4
See the version list below for details.
dotnet add package Formula.SimpleAPI --version 1.0.3.4
NuGet\Install-Package Formula.SimpleAPI -Version 1.0.3.4
<PackageReference Include="Formula.SimpleAPI" Version="1.0.3.4" />
paket add Formula.SimpleAPI --version 1.0.3.4
#r "nuget: Formula.SimpleAPI, 1.0.3.4"
// Install Formula.SimpleAPI as a Cake Addin #addin nuget:?package=Formula.SimpleAPI&version=1.0.3.4 // Install Formula.SimpleAPI as a Cake Tool #tool nuget:?package=Formula.SimpleAPI&version=1.0.3.4
Formula.SimpleAPI
Easy API's for .Net
Constrainable Resources
One of the main goals of this project was to provide an easy way to expose "resources" in a database through a RESTful API. This is accomplished by building upon the Formula.SimpleRepo project.
In addition to common CRUD operations against resources, you can easily perform queries through a JSON expressions.
Example.. If you have a resource that has a column called Color, from the REST query endpoint you can constrain results by the color red.
{color:'red'}
The items that you can constrain by aren't limited to columns, but can by dynamic attributes you can define on your repository. This allows you to define how business concepts translate to constrainable concepts on your models.
{color:'red',highAvailability:true}
In order to expose a resource, you must define a model and repository (see Formula.SimpleRepo ) Then create a Resource Controller
using System;
using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.Logging;
using Formula.SimpleAPI;
using MyApi.Data.Repositories;
using MyApi.Data.Models;
namespace MyApi.Controllers
{
[ApiController]
[Route("[controller]")]
public class TodoController : ResourceControllerBase<TodoController, Todo, TodoRepository>
{
public TodoController(ILogger<TodoController> logger, TodoRepository repository) : base(logger, repository)
{
}
}
}
This controller alone provides the following fetch type routes
- GetList - /todo = Returns all Todo records
- Get - /todo/1 = Returns the Todo record with the id of 1
- Query - /todo/query/{'type':'chores','deleted':false} = would return all todo items that are of type chore that have not been deleted
CORS Support via config file
A simple wrapper for CORS support can be supplied by a config file as a wrapper around the standard .net core utilities, allowing you to load your configuration from a config file.
To implement, modify your Startup.cs to include the following.
Add the following using;
using Formula.SimpleAPI;
Startup.cs - ConfigureServices
Some extension methods have been provided for you register your configuration. Within the ConfigureServices function of Startup.cs you can call services.AddSimpleCors providing it with an implementation of ICorsConfig.
This can be done by creating your own class that implements the ICorsConfig contract, manually, however a more common way to provide configuration is via a JSON configuration file within the project using the CorsConfigDefinition.
CoresConfigDefition with origins as null will allow CORS from any origin, otherwise, an array of origins may be proviced.
services.AddSimpleCors(CorsConfigLoader.Get("corsConfig.json"));
You may also provide some defaults using a delegate.
// Load CORS config from file first, then via custom means
services.AddSimpleCors(CorsConfigLoader.Get("corsConfig.json", () =>
{
var def = new CorsConfigDefinition();
def.Origins = null; // By default, null origins means any origin
// See if we have have been given instructions from appsettings
// or passed into us from the environment
var corsOrigins = Configuration.GetSection("CorsOrigins").Value;
if (String.IsNullOrWhiteSpace(corsOrigins) == false)
{
def.Origins = corsOrigins.Split(',');
}
return def;
}));
This allows us to load our CORS Origins through either 1 of 3 options, via a
corsConfig.json
, viaappSettings.json
through aCorsConfig
section, or finally via the environment (via k8s deployment). (SeeConfigLoader
in Formula.SimpleCore for details on how this functionality may be leveraged for other task)
Startup.cs - Configure
In the configure section of your app, you may call;
app.UseSimpleCors();
Model State Errors
Good API's should guard data, return verbose information for failures (of all kinds, bad data or exceptions). To help with this, SimpleAPI provides mechanisms for returning a consistent envelope
of data on errors or bad data.
In your Startup.cs
add the following to the ConfigureServices
function.
services.AddSimpleModelValidation();
You can now decorate models with annotations;
public class HelloWorldModel
{
[System.ComponentModel.DataAnnotations.Required]
[StringLength(10)]
public string Name { get; set; }
public string Message { get; set; }
}
And create a controller that uses the model. If the model isn't valid, or if an error occurrs, the response will be wrapped with useful, consistent information.
[HttpPost]
public TypedStatusBuilder<HelloWorldModel> Post(HelloWorldModel model)
{
var output = new TypedStatusBuilder<HelloWorldModel>();
try
{
var message = new HelloWorldModel();
// Passing the name of "fail" will throw an error
if ("fail".Equals(model.Name.ToLower()))
{
int i = 0;
int j = 1;
int k = j / i;
message.Message = $"Hello {model.Name} did you know that {j} / {i} = {k}";
}
// Else give a normal response
else
{
message.Message = $"Hello {model.Name}!";
}
output.SetData(message);
}
catch (Exception ex)
{
output.RecordFailure(ex.Message);
}
return output;
}
You API's will start returning consistent data such as;
{
"isSuccessful": true,
"message": null,
"data": {
"name": null,
"message": "Hello World!"
},
"details": null
}
or
{
"isSuccessful": false,
"message": "One or more validation errors occurred.",
"data": "One or more validation errors occurred.",
"details": {
"Name": "The field Name must be a string with a maximum length of 10."
}
}
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. net9.0 was computed. 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. |
.NET Core | netcoreapp3.1 is compatible. |
-
.NETCoreApp 3.1
- Formula.SimpleCore (>= 1.0.2)
- Formula.SimpleRepo (>= 1.0.3)
- Microsoft.AspNetCore.Mvc (>= 2.2.0)
- Newtonsoft.Json (>= 12.0.3)
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.8.0 | 9,277 | 3/28/2024 |
1.6.0 | 33,378 | 8/22/2022 |
1.2.4 | 2,279 | 8/3/2022 |
1.2.3 | 825 | 7/28/2022 |
1.2.0 | 16,092 | 8/2/2021 |
1.1.6 | 2,042 | 8/2/2021 |
1.1.4 | 660 | 7/15/2021 |
1.1.3 | 451 | 7/14/2021 |
1.1.2 | 1,206 | 5/27/2021 |
1.1.1 | 447 | 5/27/2021 |
1.1.0 | 436 | 5/25/2021 |
1.0.3.4 | 2,171 | 10/6/2020 |
1.0.3 | 620 | 8/21/2020 |
1.0.2 | 591 | 5/24/2020 |
1.0.1 | 541 | 4/3/2020 |
1.0.0 | 654 | 2/22/2020 |