aboutsummaryrefslogtreecommitdiffstats
path: root/actionpack/lib/action_controller/session
diff options
context:
space:
mode:
authorJeremy Kemper <jeremy@bitsweat.net>2005-07-05 14:50:07 +0000
committerJeremy Kemper <jeremy@bitsweat.net>2005-07-05 14:50:07 +0000
commit1e6603e6e71e6378e1a9f88871344a60757ccd78 (patch)
tree8f3e8c22eab2dea9b2e1da39c48f1405e802ed16 /actionpack/lib/action_controller/session
parent56c3d72aa75dd286e35a220f53297e043e799ab2 (diff)
downloadrails-1e6603e6e71e6378e1a9f88871344a60757ccd78.tar.gz
rails-1e6603e6e71e6378e1a9f88871344a60757ccd78.tar.bz2
rails-1e6603e6e71e6378e1a9f88871344a60757ccd78.zip
r2850@asus: jeremy | 2005-07-05 13:08:32 -0700
Don't be strict about the order in which AR store methods are called. Allow e.g. session close followed by session close. git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@1710 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'actionpack/lib/action_controller/session')
-rw-r--r--actionpack/lib/action_controller/session/active_record_store.rb16
1 files changed, 10 insertions, 6 deletions
diff --git a/actionpack/lib/action_controller/session/active_record_store.rb b/actionpack/lib/action_controller/session/active_record_store.rb
index 4700f2419a..60fd295fe8 100644
--- a/actionpack/lib/action_controller/session/active_record_store.rb
+++ b/actionpack/lib/action_controller/session/active_record_store.rb
@@ -251,24 +251,28 @@ class CGI
# Restore session state. The session model handles unmarshaling.
def restore
- @session.data
+ @session.data if @session
end
# Save session store.
def update
- @session.save!
+ @session.save! if @session
end
# Save and close the session store.
def close
- update
- @session = nil
+ if @session
+ update
+ @session = nil
+ end
end
# Delete and close the session store.
def delete
- @session.destroy rescue nil
- @session = nil
+ if @session
+ @session.destroy rescue nil
+ @session = nil
+ end
end
end