1 # frozen_string_literal: true
3 class ConfirmationsController < ApplicationController
9 before_action :authorize_web
10 before_action :set_locale
11 before_action :check_database_readable
13 authorize_resource :class => false
15 before_action :check_database_writable, :only => [:confirm, :confirm_email]
16 before_action :require_cookies, :only => [:confirm]
20 user = User.find_by_token_for(:new_user, params[:confirm_string])
23 flash[:error] = t(".unknown token")
24 redirect_to :action => "confirm"
26 flash[:error] = t(".already active")
27 redirect_to login_path
29 render_unknown_user user.display_name
32 user.email_valid = true
33 flash[:notice] = gravatar_status_message(user) if user.gravatar_enable!
35 cookies.delete :_osm_anonymous_notes_count
36 referer = safe_referer(params[:referer]) if params[:referer]
38 pending_user = session.delete(:pending_user)
40 if user.id == pending_user
41 session[:user] = user.id
42 session[:fingerprint] = user.fingerprint
44 redirect_to referer || welcome_path
46 flash[:notice] = t(".success")
47 redirect_to login_path(:referer => referer)
51 user = User.visible.find_by(:display_name => params[:display_name])
53 redirect_to root_path if user.nil? || user.active?
58 user = User.visible.find_by(:display_name => params[:display_name])
60 if user.nil? || user.id != session[:pending_user]
61 flash[:error] = t ".failure", :name => params[:display_name]
65 :token => user.generate_token_for(:new_user)
66 ).signup_confirm.deliver_later
67 flash[:notice] = { :partial => "confirmations/resend_success_flash", :locals => { :email => user.email, :sender => Settings.email_from } }
70 redirect_to login_path
75 self.current_user = User.find_by_token_for(:new_email, params[:confirm_string])
77 if current_user&.new_email?
78 current_user.email = current_user.new_email
79 current_user.new_email = nil
80 current_user.email_valid = true
81 gravatar_enabled = current_user.gravatar_enable!
83 flash[:notice] = if gravatar_enabled
84 "#{t('.success')} #{gravatar_status_message(current_user)}"
89 flash[:errors] = current_user.errors
91 session[:user] = current_user.id
92 session[:fingerprint] = current_user.fingerprint
94 flash[:error] = t ".failure"
96 flash[:error] = t ".unknown_token"
99 redirect_to account_path
106 # display a message about the current status of the Gravatar setting
107 def gravatar_status_message(user)
108 if user.image_use_gravatar
109 t ".gravatar.enabled"
111 t ".gravatar.disabled"