module AuthenticatedSystem protected # Returns true or false if the user is logged in. # Preloads @current_user with the user model if they're logged in. def logged_in? (@current_user ||= session[:user] ? User.find_by_id(session[:user]) : :false).is_a?(User) end # Accesses the current user from the session. def current_user @current_user if logged_in? end # Store the given user in the session. def current_user=(new_user) session[:last] = Time.now.to_i session[:user] = new_user.nil? ? nil : new_user.id @current_user = new_user end # Check if the user is authorized. # # Override this method in your controllers if you want to restrict access # to only a few actions or if you want to check if the user # has the correct rights. # # Example: # # # only allow nonbobs # def authorize?(user) # user.login != "bob" # end def authorized?(user) true end # Check whether or not to protect an action. # # Override this method in your controllers if you only want to protect # certain actions. # # Example: # # # don't protect the login and the about method # def protect?(action) # if ['action', 'about'].include?(action) # return false # else # return true # end # end def protect?(action) true end # Filter method to enforce a login requirement. # # To require logins for all actions, use this in your controllers: # # before_filter :login_required # # To require logins for specific actions, use this in your controllers: # # before_filter :login_required, :only => [ :edit, :update ] # # To skip this in a subclassed controller: # # skip_before_filter :login_required # def login_required # Skip this filter if the requested action is not protected return true unless protect?(action_name) # Check if user is logged in and authorized if logged_in? and authorized?(current_user) if session[:last] and session[:last] < 10.minutes.ago.to_i notify :notice, 'Te caducó la sesión' self.current_user = User.logout(self.current_user) session[:last] = nil else self.current_user.online = true self.current_user.save! session[:last] = Time.now.to_i return true end end # Store current location so that we can redirect back after login store_location # Call access_denied for an appropriate redirect and stop the filter # chain here access_denied and return false end # Redirect as appropriate when an access request fails. # # The default action is to redirect to the login screen. # # Override this method in your controllers if you want to have special # behavior in case the user is not authorized # to access the requested action. For example, a popup window might # simply close itself. def access_denied redirect_to :controller => '/account', :action => 'login' end # Store the URI of the current request in the session. # # We can return to this location by calling #redirect_back_or_default. def store_location session[:return_to] = request.request_uri end # Redirect to the URI stored by the most recent store_location call or # to the passed default. def redirect_back_or_default(default) session[:return_to] ? redirect_to_url(session[:return_to]) : redirect_to(default) session[:return_to] = nil end # Inclusion hook to make #current_user and #logged_in? # available as ActionView helper methods. def self.included(base) base.send :helper_method, :current_user, :logged_in? end end