:form_action => %w[accounts.google.com *.facebook.com login.live.com github.com meta.wikimedia.org]
)
- if params[:user] && params[:user][:display_name] && params[:user][:description]
+ if request.post?
if params[:user][:auth_provider].blank? ||
(params[:user][:auth_provider] == current_user.auth_provider &&
params[:user][:auth_uid] == current_user.auth_uid)
redirect_to user_account_url(current_user) if current_user.errors.count.zero?
else
session[:new_user_settings] = params
- redirect_to auth_url(params[:user][:auth_provider], params[:user][:auth_uid])
+ redirect_to auth_url(params[:user][:auth_provider], params[:user][:auth_uid]), :status => :temporary_redirect
end
elsif errors = session.delete(:user_errors)
errors.each do |attribute, error|
def lost_password
@title = t "users.lost_password.title"
- if params[:email]
+ if request.post?
user = User.visible.find_by(:email => params[:email])
if user.nil?
end
def login
+ append_content_security_policy_directives(
+ :form_action => %w[accounts.google.com *.facebook.com login.live.com github.com meta.wikimedia.org]
+ )
+
session[:referer] = safe_referer(params[:referer]) if params[:referer]
- if params[:username].present? && params[:password].present?
+ if request.post?
session[:remember_me] ||= params[:remember_me]
password_authentication(params[:username], params[:password])
end