debian-mirror-gitlab/app/controllers/registrations_controller.rb

70 lines
1.5 KiB
Ruby
Raw Normal View History

2014-09-02 18:07:02 +05:30
class RegistrationsController < Devise::RegistrationsController
2015-09-11 14:41:01 +05:30
before_action :signup_enabled?
include Recaptcha::Verify
2014-09-02 18:07:02 +05:30
2015-04-26 12:48:37 +05:30
def new
redirect_to(new_user_session_path)
end
def create
if !Gitlab::Recaptcha.load_configurations! || verify_recaptcha
2016-01-29 22:53:50 +05:30
if Gitlab::IpCheck.new(request.remote_ip).spam?
flash[:alert] = 'Could not create an account. This IP is listed for spam.'
return render action: 'new'
end
super
else
flash[:alert] = "There was an error with the reCAPTCHA code below. Please re-enter the code."
flash.delete :recaptcha_error
render action: 'new'
end
end
2014-09-02 18:07:02 +05:30
def destroy
2015-09-11 14:41:01 +05:30
DeleteUserService.new(current_user).execute(current_user)
2014-09-02 18:07:02 +05:30
respond_to do |format|
format.html { redirect_to new_user_session_path, notice: "Account successfully removed." }
end
end
protected
def build_resource(hash=nil)
super
end
2015-04-26 12:48:37 +05:30
def after_sign_up_path_for(_resource)
2014-09-02 18:07:02 +05:30
new_user_session_path
end
2015-04-26 12:48:37 +05:30
def after_inactive_sign_up_path_for(_resource)
2014-09-02 18:07:02 +05:30
new_user_session_path
end
private
def signup_enabled?
2015-04-26 12:48:37 +05:30
unless current_application_settings.signup_enabled?
redirect_to(new_user_session_path)
end
2014-09-02 18:07:02 +05:30
end
def sign_up_params
params.require(:user).permit(:username, :email, :name, :password, :password_confirmation)
end
def resource_name
:user
end
def resource
@resource ||= User.new(sign_up_params)
end
def devise_mapping
@devise_mapping ||= Devise.mappings[:user]
end
2014-09-02 18:07:02 +05:30
end