Shopify OAuth2 strategy for Überauth.
-
Setup your application at Shopify.
-
Add
:ueberauth_shopifyto your list of dependencies inmix.exs:def deps do [{:ueberauth_shopify, "~> 0.1"}] end
-
Add the strategy to your applications:
def application do [applications: [:ueberauth_shopify]] end
-
Add Shopify to your Überauth configuration:
config :ueberauth, Ueberauth, providers: [ shopify: {Ueberauth.Strategy.Shopify, []} ]
-
Update your provider configuration:
config :ueberauth, Ueberauth.Strategy.Shopify.OAuth, client_id: System.get_env("SHOPIFY_API_KEY"), client_secret: System.get_env("SHOPIFY_SECRET")
-
If you haven't already, create a pipeline and setup routes for your callback handler:
pipeline :auth do Ueberauth.plug "/auth" end scope "/auth" do pipe_through [:browser, :auth] get "/:provider/callback", AuthController, :callback end
-
Create an endpoint for the callback where you will handle the
Ueberauth.Authstruct:defmodule MyApp.AuthController do use MyApp.Web, :controller def callback_phase(%{ assigns: %{ ueberauth_failure: fails } } = conn, _params) do # do things with the failure end def callback_phase(%{ assigns: %{ ueberauth_auth: auth } } = conn, params) do # do things with the auth end 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/shopify
Or with options:
/auth/shopify?scope=read_orders%20read_products
By default the requested scope is "read_products,read_customers,read_orders". Scope can be configured either explicitly as a scope query value on the request path or in your configuration:
config :ueberauth, Ueberauth,
providers: [
shopify: { Ueberauth.Strategy.Shopify, [default_scope: "read_products,read_customers,read_orders"] }
]Please see LICENSE for licensing details.