Login via third party authentication services.

Easily add a "Login with Github" button your Matomo instance. You can also setup any other service to do the authentication for you.


View and download this plugin for a specific Matomo version:

What is the callback url?

http(s)://<YOUR_MATOMO_URL>/index.php?module=LoginOIDC&action=callback&provider=oidc

Which providers can I use?

I tested the plugin with Auth0, Github and Keycloak, which work fine. If your provider does not seem to work, leave an issue on Github.

How can I unlink all users?

The easiest way is to fully uninstall the plugin and reinstall afterwards. Otherwise you can delete data from matomo_loginoidc_provider in your sql database.

If you change the OAuth provider and there could be user id collisions, you should make sure to unlink all users beforehand.

Can I embed the Login button on another website?

You have to uncheck the Disable direct login url option in the settings. Afterwards you can link to http(s)://<YOUR_MATOMO_URL>/index.php?module=LoginOIDC&action=signin&provider=oidc and Matomo will redirect the client accordingly.

Can I setup more than one provider?

Currently that is not possible. But you can use services like Auth0, which support multiple providers.

I get a Can't create table error when installing the plugin

Most likely you are using a very old Piwik installation, which still uses MyISAM tables. Learn here on how to update the database engine: https://matomo.org/faq/troubleshooting/faq_25610/

What are the settings for ...?

  • Github:

    • Authorize URL: https://github.com/login/oauth/authorize
    • Token URL: https://github.com/login/oauth/access_token
    • Userinfo URL: https://api.github.com/user
    • Userinfo ID: id
    • OAuth Scopes: <EMPTY>
  • Auth0:

    • Authorize URL: https://<USERNAME>.eu.auth0.com/authorize
    • Token URL: https://<USERNAME>.eu.auth0.com/oauth/token
    • Userinfo URL: https://<USERNAME>.eu.auth0.com/userinfo
    • Userinfo ID: sub
    • OAuth Scopes: openid email
  • Keycloak:

    • Authorize URL: http(s)://<YOUR_KEYCLOAK_URL>/auth/realms/<REALM>/protocol/openid-connect/auth
    • Token URL: http(s)://<YOUR_KEYCLOAK_URL>/auth/realms/<REALM>/protocol/openid-connect/token
    • Userinfo URL: http(s)://<YOUR_KEYCLOAK_URL>/auth/realms/<REALM>/protocol/openid-connect/userinfo
    • Userinfo ID: sub
    • OAuth Scopes: openid email
  • Gitlab (self-hosted Community Edition 12.6.2):

    • Authorize URL: http(s)://<YOUR_GITLAB_URL>/oauth/authorize
    • Token URL: http(s)://<YOUR_GITLAB_URL>/oauth/token
    • Userinfo URL: http(s)://<YOUR_GITLAB_URL>/oauth/userinfo
    • Userinfo ID: sub
    • OAuth Scopes: openid email
  • Unikname Connect:

    • Name: Connect with your private @unikname
    • Authorize URL: https://connect.unikname.com/oidc/authorize
    • Token URL: https://connect.unikname.com/oidc/accessToken
    • Userinfo URL: https://connect.unikname.com/oidc/profile
    • Userinfo ID: sub
    • OAuth Scopes: openid email
  • Microsoft Azure AD

    • Authorize URL: https://login.microsoftonline.com/<TENANT_ID>/oauth2/v2.0/authorize
    • Token URL: https://login.microsoftonline.com/<TENANT_ID>/oauth2/v2.0/token
    • Userinfo URL: https://graph.microsoft.com/oidc/userinfo
    • Userinfo ID: sub
    • OAuth Scopes: openid email
  • LoginOIDC Admin Settings

  • LoginOIDC Github Authorize Consent

  • LoginOIDC Sign In

  • LoginOIDC User Settings Link

  • LoginOIDC User Settings Unlink

Download for Matomo On-Premise This plugin is not available for Matomo for WordPress

View and download this plugin for a specific Matomo version:


Please share