-# Your secret key for verifying cookie session data integrity.
-# If you change this key, all old sessions will become invalid!
-# Make sure the secret is at least 30 characters and all random,
-# no regular words or you'll be exposed to dictionary attacks.
-ActionController::Base.session = {
- :key => '_osm_session',
- :secret => 'd886369b1e709c61d1f9fcb07384a2b96373c83c01bfc98c6611a9fe2b6d0b14215bb360a0154265cccadde5489513f2f9b8d9e7b384a11924f772d2872c2a1f'
-}
+if defined?(MEMCACHE_SERVERS)
+ unless STATUS == :database_offline or STATUS == :database_readonly
+ module Rack
+ module Session
+ class Memcache
+ def get_session(env, sid)
+ with_lock(env, [nil, {}]) do
+ unless sid and session = @pool.get(sid)
+ if sid and s = ActiveRecord::SessionStore::SqlBypass.find_by_session_id(sid)
+ session = s.data
+ s.destroy
+ else
+ sid, session = generate_sid, {}
+ end
+
+ unless /^STORED/ =~ @pool.add(sid, session)
+ raise "Session collision on '#{sid.inspect}'"
+ end
+ end
+ [sid, session]
+ end
+ end
+ end
+ end
+ end
+ end