Skip to content

Commit

Permalink
Remove Clearance from UsersController.
Browse files Browse the repository at this point in the history
- it is not used, since it is overridden
  • Loading branch information
simi committed Dec 20, 2023
1 parent bf6aa45 commit 4b449ba
Show file tree
Hide file tree
Showing 5 changed files with 35 additions and 21 deletions.
5 changes: 4 additions & 1 deletion app/controllers/application_controller.rb
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
class ApplicationController < ActionController::Base
include Clearance::Authentication
include Clearance::Authorization
include ApplicationMultifactorMethods
include TraceTagger

Expand Down Expand Up @@ -69,6 +68,10 @@ def redirect_to_signin
redirect_to sign_in_path, alert: t("please_sign_in")
end

def redirect_to_root
redirect_to root_path
end

def find_rubygem
@rubygem = Rubygem.find_by_name(params[:rubygem_id] || params[:id])
return if @rubygem
Expand Down
2 changes: 1 addition & 1 deletion app/controllers/sessions_controller.rb
Original file line number Diff line number Diff line change
Expand Up @@ -111,7 +111,7 @@ def do_login
if status.success?
StatsD.increment "login.success"
set_login_flash
redirect_back_or(url_after_create)
redirect_to(url_after_create)
else
login_failure(status.failure_message)
end
Expand Down
22 changes: 17 additions & 5 deletions app/controllers/users_controller.rb
Original file line number Diff line number Diff line change
@@ -1,14 +1,16 @@
class UsersController < Clearance::UsersController
class UsersController < ApplicationController
before_action :redirect_to_root, if: :signed_in?

def new
@user = user_from_params
@user = User.new
end

def create
@user = user_from_params
@user = User.new(user_params)
if @user.save
Mailer.email_confirmation(@user).deliver_later
flash[:notice] = t(".email_sent")
redirect_back_or url_after_create
redirect_back_or_to root_path
else
render template: "users/new"
end
Expand All @@ -17,6 +19,16 @@ def create
private

def user_params
params.permit(user: Array(User::PERMITTED_ATTRS)).fetch(:user, {})
params.require(:user).permit(
:bio,
:email,
:handle,
:public_email,
:location,
:password,
:website,
:twitter_username,
:full_name
)
end
end
12 changes: 0 additions & 12 deletions app/models/user.rb
Original file line number Diff line number Diff line change
Expand Up @@ -4,18 +4,6 @@ class User < ApplicationRecord
include Gravtastic
is_gravtastic default: "retro"

PERMITTED_ATTRS = %i[
bio
email
handle
public_email
location
password
website
twitter_username
full_name
].freeze

before_save :_generate_confirmation_token_no_reset_unconfirmed_email, if: :will_save_change_to_unconfirmed_email?
before_create :_generate_confirmation_token_no_reset_unconfirmed_email
before_destroy :yank_gems
Expand Down
15 changes: 13 additions & 2 deletions test/functional/users_controller_test.rb
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,17 @@ class UsersControllerTest < ActionController::TestCase
page.assert_text "Sign up"
page.assert_selector "input[type=password][autocomplete=new-password]"
end

context "when logged in" do
setup do
@user = create(:user)
sign_in_as(@user)

get :new
end

should redirect_to("root") { root_path }
end
end

context "on POST to create" do
Expand All @@ -26,9 +37,9 @@ class UsersControllerTest < ActionController::TestCase
end

context "when missing a parameter" do
should "raises parameter missing" do
should "reports validation error" do
assert_no_changes -> { User.count } do
post :create
post :create, params: { user: { password: PasswordHelpers::SECURE_TEST_PASSWORD } }
end
assert_response :ok
assert page.has_content?("Email address is not a valid email")
Expand Down

0 comments on commit 4b449ba

Please sign in to comment.