Sha256: 545fe472826acb1cfd0139233a6e80c0e5426e98ba21ce97e8eaddf01a1a69ae

Contents?: true

Size: 1.54 KB

Versions: 1

Compression:

Stored size: 1.54 KB

Contents

require 'bundler/setup'
require 'sinatra/base'
require 'omniauth-duodealer-oauth2'

SCOPE = 'read_products,read_orders,read_customers,write_shipping'
DUODEALER_API_KEY = ENV['DUODEALER_API_KEY']
DUODEALER_SHARED_SECRET = ENV['DUODEALER_SHARED_SECRET']

unless DUODEALER_API_KEY && DUODEALER_SHARED_SECRET
  abort("DUODEALER_API_KEY and DUODEALER_SHARED_SECRET environment variables must be set")
end

class App < Sinatra::Base
  get '/' do
    <<-HTML
    <html>
    <head>
      <title>DuoDealer Oauth2</title>
    </head>
    <body>
      <form action="/auth/duodealer" method="get">
      <label for="shop">Enter your store's URL:</label>
      <input type="text" name="shop" placeholder="your-shop-url.duodealer.com">
      <button type="submit">Log In</button>
      </form>
    </body>
    </html>
    HTML
  end

  get '/auth/:provider/callback' do
    <<-HTML
    <html>
    <head>
      <title>DuoDealer Oauth2</title>
    </head>
    <body>
      <h3>Authorized</h3>
      <p>Shop: #{request.env['omniauth.auth'].uid}</p>
      <p>Token: #{request.env['omniauth.auth']['credentials']['token']}</p>
    </body>
    </html>
    HTML
  end

  get '/auth/failure' do
    <<-HTML
    <html>
    <head>
      <title>DuoDealer Oauth2</title>
    </head>
    <body>
      <h3>Failed Authorization</h3>
      <p>Message: #{params[:message]}</p>
    </body>
    </html>
    HTML
  end
end

use Rack::Session::Cookie, secret: SecureRandom.hex(64)

use OmniAuth::Builder do
  provider :duodealer, DUODEALER_API_KEY, DUODEALER_SHARED_SECRET, :scope => SCOPE
end

run App.new

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
omniauth-duodealer-oauth2-1.0.0 example/config.ru