Sha256: ab9d2b53c16590f153e47f524144ecb28b0c2b14fb22593240fd8e10c29ef489
Contents?: true
Size: 1.23 KB
Versions: 3
Compression:
Stored size: 1.23 KB
Contents
class SessionsController < ApplicationController def new authenticate if params[:shop].present? end def create authenticate end def show if response = request.env['omniauth.auth'] sess = ShopifyAPI::Session.new(params[:shop], response['credentials']['token']) session[:shopify] = sess flash[:notice] = "Logged in" redirect_to return_address else flash[:error] = "Could not log in to Shopify store." redirect_to :action => 'new' end end def destroy session[:shopify] = nil flash[:notice] = "Successfully logged out." redirect_to :action => 'new' end protected def authenticate if shop_name = sanitize_shop_param(params) redirect_to "/auth/shopify?shop=#{shop_name}" else redirect_to return_address end end def return_address session[:return_to] || root_url end def sanitize_shop_param(params) return unless params[:shop].present? name = params[:shop].to_s.strip name += '.myshopify.com' if !name.include?("myshopify.com") && !name.include?(".") name.sub('https://', '').sub('http://', '') u = URI("http://#{name}") u.host.ends_with?("myshopify.com") ? u.host : nil end end
Version data entries
3 entries across 3 versions & 1 rubygems