Module: CookieRequirement

Defined in:
lib/cookie_requirement.rb

Overview

CookieRequirement is a Rails plugin that lets you ensure that cookies are enabled. Include the module in a controller, and declare the actions that require cookies with the cookies_required class method.

Example

class UserController

  include CookieRequirement

  cookies_required :login

  # if login is accessed without cookies, handle_cookies_disabled is
  # called
  def 
  end

  def cookie_instructions
    # show some instructions
  end

protected

  # override the default behavior to display instructions
  def handle_cookies_diabled
    redirect_to :action => "cookie_instructions"
  end

end

How It Works

CookieRequirement adds a before_filter to the controller in which it is included. This filter checks if the invoked action requires cookies. If so, it sets a test cookie and redirects to the same action, adding a query parameter to indicate that a test cookie should exist. If the cookie does not exist after the redirection, CookieRequirement concludes that cookies are disabled and calls handle_cookies_disabled, which, by default, raises CookiesDisabled.

Note: CookieRequirement adds the before_filter when it is included. If you want other before_filters to run before CookieRequirement, declare them before including CookieRequirement.

Acknowledgments

CookieRequirement is based on

Defined Under Namespace

Modules: ClassMethods Classes: CookiesDisabled

Constant Summary collapse

"test_cookie"
"tcw"

Class Method Summary collapse

Class Method Details

.included(controller) ⇒ Object



63
64
65
66
# File 'lib/cookie_requirement.rb', line 63

def self.included(controller)
  controller.extend(ClassMethods)
  controller.before_filter(:ensure_cookies)
end