Sha256: ab9fbda1f059456517135c782a7fcb103744b5353af3dfb706eb7fd97365781f

Contents?: true

Size: 1.15 KB

Versions: 3

Compression:

Stored size: 1.15 KB

Contents

module ShopifyApp
  module LoginProtection
    extend ActiveSupport::Concern

    included do
      rescue_from ActiveResource::UnauthorizedAccess, :with => :close_session
    end

    def shopify_session
      if shop_session
        begin
          ShopifyAPI::Base.activate_session(shop_session)
          yield
        ensure
          ShopifyAPI::Base.clear_session
        end
      else
        redirect_to_login
      end
    end

    def shop_session
      return unless session[:shopify]
      @shop_session ||= ShopifyApp::SessionRepository.retrieve(session[:shopify])
    end

    def login_again_if_different_shop
      if shop_session && params[:shop] && params[:shop].is_a?(String) && shop_session.url != params[:shop]
        redirect_to_login
      end
    end

    protected

    def redirect_to_login
      session[:return_to] = request.fullpath if request.get?
      redirect_to login_path(shop: params[:shop])
    end

    def close_session
      session[:shopify] = nil
      redirect_to login_path
    end

    def login_path(params = {})
      main_app.login_path(params)
    rescue NoMethodError => e
      shopify_app.login_path(params)
    end

  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
shopify_app-6.1.2 lib/shopify_app/login_protection.rb
shopify_app-6.1.1 lib/shopify_app/login_protection.rb
shopify_app-6.1.0 lib/shopify_app/login_protection.rb