Boruta is the core of an OAuth 2.0 and OpenID Connect provider implementing according business rules. A generator is provided to create phoenix controllers, views and templates to have a basic provider up and running.
It is intended to follow RFCs:
- RFC 6749 - The OAuth 2.0 Authorization Framework
- RFC 7662 - OAuth 2.0 Token Introspection
- RFC 7009 - OAuth 2.0 Token Revocation
- RFC 7636 - Proof Key for Code Exchange by OAuth Public Clients
And specification from OpenID Connect:
This package is meant to help to provide authorization into Elixir applications. With it, you can perform part or all of authorization code, implicit, hybrid, client credentials, or resource owner password credentials grants flows. It also helps introspecting and revoking tokens.
Master branch documentation can be found here
Stable documentation is hosted on hexdocs.pm
An example of integration can be found here
This package passed succesfully basic and implicit OpenID Profiles certification as of May 1st, 2022 for its version 2.1.0. This certification was performed with the above example server which followed documented integration steps listed in the below guides section.
Here are some guides helping the integration of OAuth/OpenID Connect in your systems:
- Basic OAuth/OpenID Connect provider integration
- How to create an OAuth client
- Client request authorization
- Notes about pkce
It is a work in progress, all feedbacks / feature requests / improvements are welcome