Bexio OAuth2 strategy for Überauth.
-
Setup your application at Bexio Developer.
-
Add
:ueberauth_bexioto your list of dependencies inmix.exs:def deps do [ {:ueberauth_bexio, "~> 0.3.0"} ] end
-
Add Bexio to your Überauth configuration:
config :ueberauth, Ueberauth, providers: [ bexio: {Ueberauth.Strategy.Bexio, []} ]
-
Update your provider configuration:
Use that if you want to read client ID/secret from the environment variables in the compile time:
config :ueberauth, Ueberauth.Strategy.Bexio.OAuth, client_id: System.get_env("BEXIO_CLIENT_ID"), client_secret: System.get_env("BEXIO_CLIENT_SECRET")
Use that if you want to read client ID/secret from the environment variables in the run time:
config :ueberauth, Ueberauth.Strategy.Bexio.OAuth, client_id: {System, :get_env, ["BEXIO_CLIENT_ID"]}, client_secret: {System, :get_env, ["BEXIO_CLIENT_SECRET"]}
-
Include the Überauth plug in your controller:
defmodule MyApp.AuthController do use MyApp.Web, :controller plug Ueberauth ... end
-
Create the request and callback routes if you haven't already:
scope "/auth", MyApp do pipe_through :browser get "/:provider", AuthController, :request get "/:provider/callback", AuthController, :callback end
-
Your controller needs to implement callbacks to deal with
Ueberauth.AuthandUeberauth.Failureresponses.
For an example implementation see the Überauth Example application.
Depending on the configured url you can initiate the request through:
/auth/bexio
Or with options:
/auth/bexio?scope=email%20profile
By default the requested scope is "email". Scope can be configured either explicitly as a scope query value on the request path or in your configuration:
config :ueberauth, Ueberauth,
providers: [
bexio: {Ueberauth.Strategy.Bexio, [default_scope: "openid email profile company_profile"]}
]TODO: decide what we want to write here!
To guard against client-side request modification, it's important to still check the domain in info.urls[:website] within the Ueberauth.Auth struct if you want to limit sign-in to a specific domain.
Copyright (c) 2024 Smart Software Engineering SRL
Released under the MIT License, which can be found in the repository in LICENSE.