website/_posts/2021-09-04-portainer-oauth-authentication.md
Sthope becd731912
All checks were successful
continuous-integration/drone/push Build is passing
initial commit
2021-09-09 15:18:45 +02:00

4.1 KiB

layout title description author image categories comments pic01 pic02 pic03 pic04 pic05 pic06 pic07 pic08 pic09 pic10
post Portainer OAuth Authentication Login into Portainer using your Github account or even better.. your private Gitea account (with 2FA) sthope
Docker
Portainer
OAuth
true /assets/images/portainer_oauth/1.png /assets/images/portainer_oauth/2.png /assets/images/portainer_oauth/3.png /assets/images/portainer_oauth/4.png /assets/images/portainer_oauth/5.png /assets/images/portainer_oauth/6.png /assets/images/portainer_oauth/7.png /assets/images/portainer_oauth/8.png /assets/images/portainer_oauth/9.png /assets/images/portainer_oauth/10.png

Github

Login into Github and go to https://github.com/settings/profile on the right side menu near the end enter Developer settings and select OAuth Apps

Create your app details Application name: Whatever you wanna call it
Homepage URL: eg: http://IP:9000
Application description: can be empty
Authorization callback URL: eg: http://IP:9000


After Github creates the application click on Generate a new client secret and copy Client ID and the Secret it created.
This is it Github Part is finish!

Portainer

Open Portainer UI and go to Settings on the right side menu then click on Authentication under it.

Now choose this options, you can use other Session lifetime if you want Automatic user provisioning: If set ON anyone with Github account will be able to login and Portainer will automaticily create the user without authorizations, better leave it off and handle the users creation/allowance to you.

OAuth Configuration

| :-------------------- | :------------------------------------------ | | Client ID | ClientID you copied from Github | | Client secret | Secret you copied from Github | | Authorization URL | https://github.com/login/oauth/authozize | | Access token URL | https://github.com/login/oauth/access_token | | Resource URL | https://api.github.com/user | | Redirect URL | your Portainer URL eg: http://IP:9000 | | Logout URL | leave empty | | User identifier | login | | Scopes | id,email,name |

Remember Gitea Username and Portainer Username need to math otherwise create a new username in Portainer with same name or enable Automatic user provisioning and then after login disable it again



Gitea

For Gitea instead of Github, enter your user Settings and go to Applications and create a new one.

`Redirect URL`= use your Portainer URL, eg: http://IP:9000

After that is created, Gitea will give you the ClientID and Secret you should save to use with Portainer.

Now for Gitea the configs are a little different, follow:

| :-------------------- | :---------------------------------------- | | Client ID | ClientID you copied from Gitea | | Client secret | Secret you copied from Gitea | | Authorization URL | http://GITEA_URL/login/oauth/authorize | | Access token URL | http://GITEA_URL/login/oauth/access_token | | Resource URL | http://GITEA_URL/login/oauth/userinfo | | Redirect URL | your Portainer URL eg: http://IP:9000 | | Logout URL | leave empty | | User identifier | preferred_username | | Scopes | leave empty |

Should now be configured and you should be able to login using your Gitea Account

Remember Gitea Username and Portainer Username need to math otherwise create a new username in Portainer with same name or enable Automatic user provisioning and then after login disable it again