tuitio/README.md

68 lines
3.4 KiB
Markdown
Raw Permalink Normal View History

# Tuitio
2022-11-27 02:57:21 +02:00
Tuitio is a simple identity server implementation focused strictly on the needs of my home lab.
At the moment it has a simple API consisting of only three methods:
* ```/account/login``` - handles user authentication using credentials and generates an access token.
* ```/account/logout``` - handles user logout.
* ```/connect/authorize``` - manages the authorization process for a token, including verification of its existence, validity, and authenticity.
***Tuitio*** is a latin word that encompasses meanings such as supervision, safeguarding, defense, guard duty, and protection.
## Database
Currently, the database server supported by the system is only Microsoft SQL Server. In the following versions, the system will also be compatible with PostgreSQL and SQLite.
## Logging
The logging functionality is managed with Serilog, and its configuration is done in the ```appsettings.json``` file. In addition to its standard configuration, Tuitio also has a preconfigured area where two destinations for logs are available: SqlServer database and Seq. Each of the destinations can be activated or not. If logging in the console is sufficient, all additional logging destinations can be disabled.
This configuration area is:
```
"Logs": {
"SqlServer": {
"Enabled": false,
"Connection": "Server=<server>;Database=<database>;User Id=<user>;Password=<password>;"
},
"Seq": {
"Enabled": false,
"Url": "",
"ApiKey": ""
}
}
```
## Hosting
The only hosting environment tested for this service is Docker, but considering that .NET 6 is cross platform, it can most likely be hosted in any environment.
2022-11-27 02:57:21 +02:00
## Stack
* .NET (C#)
* EntityFramework
* SQL Server
* Swagger
* Docker
2023-02-11 04:50:19 +02:00
* Seq
## Integrations
### Javascript
Tuitio can be integrated with any system written in javascript through the npm package [tuitio-client](https://lab.code-rove.com/gitea/bricks/tuitio-client#readme).
2023-02-14 01:09:38 +02:00
**Source code:** https://lab.code-rove.com/gitea/bricks/tuitio-client
**Registry:** https://lab.code-rove.com/public-node-registry/-/web/detail/@flare/tuitio-client
2023-02-11 04:50:19 +02:00
### React
2023-02-15 01:21:48 +02:00
Tuitio can be integrated with an application written in React both through the above package and through [tuitio-client-react](https://lab.code-rove.com/gitea/bricks/tuitio-client-react).
2023-02-11 04:50:19 +02:00
2023-02-15 01:21:48 +02:00
Tuitio client react uses [tuitio-client](https://lab.code-rove.com/gitea/bricks/tuitio-client#readme) internally and adds state management through a react context and various react hooks through which the user has access to data and actions.
2023-02-11 04:50:19 +02:00
2023-02-15 01:21:48 +02:00
**Source code:** https://lab.code-rove.com/gitea/bricks/tuitio-client-react
**Registry:** https://lab.code-rove.com/public-node-registry/-/web/detail/@flare/tuitio-client-react
2023-02-11 04:50:19 +02:00
### C#
2023-03-02 18:53:30 +02:00
Tuitio can be integrated in any .NET API through the [Netmash.Security.Authentication.Tuitio](https://lab.code-rove.com/gitea/bricks/netmash/src/branch/master/src/security/authentication/Netmash.Security.Authentication.Tuitio) NuGet package.
**Source code:** https://lab.code-rove.com/gitea/bricks/netmash/src/branch/master/src/security/authentication/Netmash.Security.Authentication.Tuitio
**Registry:** https://lab.code-rove.com/public-nuget-server/packages/netmash.security.authentication.tuitio
Netmash.Security.Authentication.Tuitio uses internally two packages exposed by Tuitio:
2023-03-02 18:56:46 +02:00
* [Tuitio.PublishedLanguage](https://lab.code-rove.com/public-nuget-server/packages/tuitio.publishedlanguage)
2023-03-02 18:53:30 +02:00
* [Tuitio.Wrapper](https://lab.code-rove.com/public-nuget-server/packages/tuitio.wrapper)