Twitter strategy for Überauth.
Note: Sessions are required for this strategy.
-
Setup your application at Twitter Developers.
-
Add
:ueberauth_twitterto your list of dependencies inmix.exs:def deps do [ {:ueberauth_twitter, "~> 0.3"} ] end
-
Add Twitter to your Überauth configuration:
config :ueberauth, Ueberauth, providers: [ twitter: {Ueberauth.Strategy.Twitter, [authorize_url: "/oauth/authenticate"]} ]
The request url can be overridden via the "authorize_url" opt, without the override the url defaults to "/oauth/authorize"
-
Update your provider configuration:
config :ueberauth, Ueberauth.Strategy.Twitter.OAuth, consumer_key: System.get_env("TWITTER_CONSUMER_KEY"), consumer_secret: System.get_env("TWITTER_CONSUMER_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/twitter
Query parameters such as force_login and screen_name will be forwarded to the OAuth endpoint. For example, to always ask for a user name and password (even if logged in to Twitter), initiate the request through:
/auth/twitter?force_login=true
As noted when registering your application on the Twitter Developer site, you need to explicitly specify the oauth_callback url. While in development, this is an example url you need to enter.
Website - http://127.0.0.1
Callback URL - http://127.0.0.1:4000/auth/twitter/callback
Please see LICENSE for licensing details.