Class: ActionController::RequestForgeryProtection::CookieStore
- Defined in:
 - actionpack/lib/action_controller/metal/request_forgery_protection.rb
 
Instance Method Summary collapse
- #fetch(request) ⇒ Object
 - 
  
    
      #initialize(cookie = :csrf_token)  ⇒ CookieStore 
    
    
  
  
  
    constructor
  
  
  
  
  
  
  
    
A new instance of CookieStore.
 - #reset(request) ⇒ Object
 - #store(request, csrf_token) ⇒ Object
 
Constructor Details
#initialize(cookie = :csrf_token) ⇒ CookieStore
Returns a new instance of CookieStore.
      334 335 336  | 
    
      # File 'actionpack/lib/action_controller/metal/request_forgery_protection.rb', line 334 def initialize( = :csrf_token) @cookie_name = end  | 
  
Instance Method Details
#fetch(request) ⇒ Object
      338 339 340 341 342 343 344 345 346 347 348  | 
    
      # File 'actionpack/lib/action_controller/metal/request_forgery_protection.rb', line 338 def fetch(request) contents = request..encrypted[@cookie_name] return nil if contents.nil? value = JSON.parse(contents) return nil unless value.dig("session_id", "public_id") == request.session.id_was&.public_id value["token"] rescue JSON::ParserError nil end  | 
  
#reset(request) ⇒ Object
      361 362 363  | 
    
      # File 'actionpack/lib/action_controller/metal/request_forgery_protection.rb', line 361 def reset(request) request..delete(@cookie_name) end  | 
  
#store(request, csrf_token) ⇒ Object
      350 351 352 353 354 355 356 357 358 359  | 
    
      # File 'actionpack/lib/action_controller/metal/request_forgery_protection.rb', line 350 def store(request, csrf_token) request..encrypted.permanent[@cookie_name] = { value: { token: csrf_token, session_id: request.session.id, }.to_json, httponly: true, same_site: :lax, } end  |