View Source Spotify.Authentication (spotify_ex v2.4.0)
Authenticates the Spotify user.
After your app is authorized, the user must be authenticated. A redirect
URL is specified in the config folder. This is the URL that Spotify
redirects to after authorization, and should ultimately end up hitting
this module's authenticate function. If the authorization is successful,
the param code will be present.
If a refresh token still exists, the client will refresh the access token.
You have the option to pass either a Plug.Conn or a Spotify.Credentials struct into these functions. If you pass Conn, the auth tokens will be saved in cookies. If you pass Credentials, you will be responsible for persisting the auth tokens between requests.
Link to this section Summary
Functions
Authenticates the user
Attempts to refresh your access token if the refresh token exists. Returns
:unauthorized if there is no refresh token.
Checks for refresh and access tokens
Link to this section Functions
Authenticates the user
The authorization code must be present from spotify or an exception will be raised. The token will be refreshed if possible, otherwise the app will request new access and request tokens.
example
Example:
Spotify.authenticate(conn, %{"code" => code})
# {:ok, conn}
Spotify.authenticate(conn, %{"not_a_code" => invalid})
# AuthenticationError, "No code provided by Spotify. Authorize your app again"
Spotify.authenticate(auth, params)
# {:ok, auth}
Attempts to refresh your access token if the refresh token exists. Returns
:unauthorized if there is no refresh token.
Checks for refresh and access tokens
example
Example:
defmodule PlayListController do
plug :check_tokens
def check_tokens do
unless Spotify.Authentication.tokens_present?(conn) do
redirect conn, to: authorization_path(:authorize)
end
end
end