force_ssl.rb 2.3 KB
Newer Older
1
module ActionController
2
  # This module provides a method which will redirect browser to use HTTPS
3 4 5 6 7
  # protocol. This will ensure that user's sensitive information will be
  # transferred safely over the internet. You _should_ always force browser
  # to use HTTPS when you're transferring sensitive information such as
  # user authentication, account information, or credit card information.
  #
8 9
  # Note that if you are really concerned about your application security,
  # you might consider using +config.force_ssl+ in your config file instead.
10 11 12 13 14 15 16 17 18 19 20
  # That will ensure all the data transferred via HTTPS protocol and prevent
  # user from getting session hijacked when accessing the site under unsecured
  # HTTP protocol.
  module ForceSSL
    extend ActiveSupport::Concern
    include AbstractController::Callbacks

    module ClassMethods
      # Force the request to this particular controller or specified actions to be
      # under HTTPS protocol.
      #
21 22 23 24 25 26 27 28 29 30
      # If you need to disable this for any reason (e.g. development) then you can use
      # an +:if+ or +:unless+ condition.
      #
      #     class AccountsController < ApplicationController
      #       force_ssl :if => :ssl_configured?
      #
      #       def ssl_configured?
      #         !Rails.env.development?
      #       end
      #     end
31 32
      #
      # ==== Options
33
      # * <tt>host</tt>   - Redirect to a different host name
34 35
      # * <tt>only</tt>   - The callback should be run only for this action
      # * <tt>except<tt>  - The callback should be run for all actions except this action
36 37 38 39
      # * <tt>if</tt>     - A symbol naming an instance method or a proc; the callback
      #                     will be called only when it returns a true value.
      # * <tt>unless</tt> - A symbol naming an instance method or a proc; the callback
      #                     will be called only when it returns a false value.
40
      def force_ssl(options = {})
41
        host = options.delete(:host)
42
        before_filter(options) do
43
          unless request.ssl?
44 45
            redirect_options = {:protocol => 'https://', :status => :moved_permanently}
            redirect_options.merge!(:host => host) if host
46
            redirect_options.merge!(:params => request.query_parameters)
47
            flash.keep
48
            redirect_to redirect_options
49 50 51 52 53
          end
        end
      end
    end
  end
54
end