Spotify OAuth2 strategy for Überauth.
-
Setup your application at the Spotify Developer Console.
-
Add
:ueberauth_spotifyto your list of dependencies inmix.exs:def deps do [{:ueberauth_spotify, "0.2.1"}] end
-
Add the strategy to your applications in
mix.exs::def application do [applications: [:ueberauth_spotify]] end
-
Fetch the dependencies
mix deps.get
-
Add Spotify to your Überauth configuration in
config/config.exs::config :ueberauth, Ueberauth, providers: [ spotify: {Ueberauth.Strategy.Spotify, []} ]
-
Update your provider configuration in
config/[dev|test|prod].exs. Make sure to add your JSON serlializer of choice:config :ueberauth, Ueberauth.Strategy.Spotify.OAuth, client_id: System.get_env("SPOTIFY_CLIENT_ID"), client_secret: System.get_env("SPOTIFY_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 initial the request through:
/auth/spotify
Or with options:
/auth/spotify?scope=...&show_dialog=true
By default the requested scope is "user-read-email". Scope can be configured either explicitly as a scope query value on the request path or in your configuration:
config :ueberauth, Ueberauth,
providers: [
spotify: {Ueberauth.Strategy.Spotify, [default_scope: "user-read-email,user-read-private"]}
]Please see LICENSE for licensing details.