/
sessions_controller.rb
49 lines (41 loc) · 1.14 KB
/
sessions_controller.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
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://', '')
end
end