Feishu OAuth2 strategy for Überauth.
-
Add
:ueberauth_feishu
to your list of dependencies inmix.exs
:def deps do [{:ueberauth_feishu, github: "edwardzhou/ueberauth_feishu"}] end
-
Add the strategy to your applications:
def application do [applications: [:ueberauth_feishu]] end
-
Add Wechat to your Überauth configuration:
config :ueberauth, Ueberauth, providers: [ feishu: {Ueberauth.Strategy.Feishu, []} ]
-
Update your provider configuration:
config :ueberauth, Ueberauth.Strategy.Feishu.OAuth, client_id: System.get_env("FEISHU_APPID"), client_secret: System.get_env("FEISHU_SECRET")
-
Include the Überauth plug in your controller:
defmodule MyApp.AuthController do use MyApp.Web, :controller pipeline :browser do plug Ueberauth ... end end
-
Create the request and callback routes if you haven't already:
scope "/auth", MyApp do pipe_through :browser get "/:provider/callback", AuthController, :callback post "/:provider/callback", AuthController, :callback end
-
You controller needs to implement callbacks to deal with
Ueberauth.Auth
andUeberauth.Failure
responses.
For an example implementation see the Überauth Example application.
get or post
/auth/feishu/callback?code=<auth_code>
Authorization can be mock in unit test, with specific code "test_code".
** Example: **
describe "new github authentication" do
test "create new user", %{conn: conn} do
assert Accounts.find_authentication(@github_params.uid) == nil
conn =
conn
|> assign(:ueberauth_auth, @github_params)
|> get(auth_path(conn, :callback, :github), %{"code" => "test_code"})
assert html_response(conn, 302)
assert Accounts.find_authentication(@github_params.uid) != nil
end
end