Typetalk OAuth2 Strategy for Überauth
-
Setup your application at Typetalk Developer page.
-
Add ueberauth_typetalk to your list of dependencies in
mix.exs
:
def deps do
[{:ueberauth_typetalk, "~> 0.2"}]
end
- Add the strategy to your applications:
def application do
[application: [:ueberauth_typetalk]]
end
- Add Typetalk to your Überauth configuration:
config :ueberauth, Ueberauth,
providers: [
typetalk: {Ueberauth.Strategy.Typetalk, []}
]
- Update your provider configuration:
config :ueberauth, Ueberauth.Strategy.Typetalk.OAuth,
client_id: System.get_env("TYPETALK_CLIENT_ID")
client_secret: System.get_env("TYPETALK_CLIENT_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", AuthController, :request
get "/:provider/callback", AuthController, :callback
end
- Your controller needs to implement callbacks to deal with
Ueberauth.Auth
andUeberauth.Failure
responses.
For an example implementation see the Example applciation.