Class: ShopifyApp::SessionsController

Inherits:
ActionController::Base
  • Object
show all
Includes:
LoginProtection
Defined in:
app/controllers/shopify_app/sessions_controller.rb

Overview

rubocop:disable Metrics/ClassLength

Instance Method Summary collapse

Methods included from LoginProtection

#login_again_if_different_shop, #shop_session, #shopify_session

Instance Method Details

#createObject



14
15
16
# File 'app/controllers/shopify_app/sessions_controller.rb', line 14

def create
  authenticate
end

#destroyObject



45
46
47
48
49
# File 'app/controllers/shopify_app/sessions_controller.rb', line 45

def destroy
  reset_session
  flash[:notice] = I18n.t('.logged_out')
  redirect_to 
end

#enable_cookiesObject



18
19
20
21
22
23
24
25
26
27
28
29
# File 'app/controllers/shopify_app/sessions_controller.rb', line 18

def enable_cookies
  return unless validate_shop

  render(:enable_cookies, layout: false, locals: {
    does_not_have_storage_access_url: top_level_interaction_path(
      shop: sanitized_shop_name
    ),
    has_storage_access_url: (top_level: true),
    app_home_url: granted_storage_access_path(shop: sanitized_shop_name),
    current_shopify_domain: current_shopify_domain,
  })
end

#granted_storage_accessObject



36
37
38
39
40
41
42
43
# File 'app/controllers/shopify_app/sessions_controller.rb', line 36

def granted_storage_access
  return unless validate_shop

  session['shopify.granted_storage_access'] = true

  params = { shop: @shop }
  redirect_to "#{ShopifyApp.configuration.root_url}?#{params.to_query}"
end

#newObject



10
11
12
# File 'app/controllers/shopify_app/sessions_controller.rb', line 10

def new
  authenticate if sanitized_shop_name.present?
end

#top_level_interactionObject



31
32
33
34
# File 'app/controllers/shopify_app/sessions_controller.rb', line 31

def top_level_interaction
  @url = (top_level: true)
  validate_shop
end