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"