Sha256: ecb828ab01f37646be6054becbefb857b1b799071af52cd192dd315d62cce25b

Contents?: true

Size: 990 Bytes

Versions: 2

Compression:

Stored size: 990 Bytes

Contents

# frozen_string_literal: true

module Firebug
  require 'active_record'

  # An ActiveRecord model of the CodeIgniter sessions table.
  class Session < ActiveRecord::Base
    self.table_name = 'default_ci_sessions'

    # @return [Object]
    def user_data
      Firebug.unserialize(super || '')
    end

    # @param [Object] value
    def user_data=(value)
      super(Firebug.serialize(value))
    end

    # @param [String] value
    def user_agent=(value)
      # Pyro seems to truncate the value and since it also uses this value when finding the session, it's important
      # we do the same.
      super(Firebug.configuration.truncate_user_agent ? value[0...120] : value)
    end

    # @return [String]
    def cookie_data
      data = { session_id: session_id, ip_address: ip_address, user_agent: user_agent, last_activity: last_activity }
      Firebug.encrypt_cookie(data)
    end

    private

    def timestamp_attributes_for_update
      ['last_activity']
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
firebug-0.1.9 lib/firebug/session.rb
firebug-0.1.8 lib/firebug/session.rb