Wordpress OAuth2 strategy for Überauth based on ueberauth_discord
For additional documentation on Wordpress's OAuth implementation see wordpress-oauth-server and wp-oauth.com.
-
Add
:ueberauth_wordpress
to your list of dependencies inmix.exs
:def deps do [{:ueberauth_wordpress, "~> 0.0.1"}] end
-
Add the strategy to your applications:
def application do [applications: [:ueberauth_wordpress]] end
-
Add Wordpress to your Überauth configuration:
config :ueberauth, Ueberauth, providers: [ wordpress: {Ueberauth.Strategy.Wordpress, []} ]
-
Update your provider configuration:
config :ueberauth, Ueberauth.Strategy.Wordpress.OAuth, client_id: System.get_env("WORDPRESS_CLIENT_ID"), client_secret: System.get_env("WORDPRESS_CLIENT_SECRET"), host: System.get_env("WORDPRESS_HOST")
-
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.Auth
andUeberauth.Failure
responses.
For an example implementation see the Überauth Example application.
Please see LICENSE for licensing details.