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]
 
  63       UserMailer.signup_confirm(user, user.generate_token_for(:new_user)).deliver_later
 
  64       flash[:notice] = { :partial => "confirmations/resend_success_flash", :locals => { :email => user.email, :sender => Settings.email_from } }
 
  67     redirect_to login_path
 
  72       self.current_user = User.find_by_token_for(:new_email, params[:confirm_string])
 
  74       if current_user&.new_email?
 
  75         current_user.email = current_user.new_email
 
  76         current_user.new_email = nil
 
  77         current_user.email_valid = true
 
  78         gravatar_enabled = current_user.gravatar_enable!
 
  80           flash[:notice] = if gravatar_enabled
 
  81                              "#{t('.success')} #{gravatar_status_message(current_user)}"
 
  86           flash[:errors] = current_user.errors
 
  88         session[:user] = current_user.id
 
  89         session[:fingerprint] = current_user.fingerprint
 
  91         flash[:error] = t ".failure"
 
  93         flash[:error] = t ".unknown_token"
 
  96       redirect_to account_path
 
 103   # display a message about the current status of the Gravatar setting
 
 104   def gravatar_status_message(user)
 
 105     if user.image_use_gravatar
 
 106       t ".gravatar.enabled"
 
 108       t ".gravatar.disabled"