ご閲覧いただきまして、ありがとうございます。
Devise
でメールによるサインアップを試みているのですが、パスワードを入力せずにサインアップが完了してしまいます。パスワードなしでユーザー編集をできるような仕様にしてしまったことも原因の一つとして考えられるのですが、Devise
でパスワードなしでプロフィール更新は可能にして、かつメールサインアップ時にはパスワードを要求するためにはどのようにすればよいでしょうか?
オーバーライドなど試してみたのですが、どうもうまくいかず、お知恵を拝借させていただければと思います。
apps/views/registrations/new.html.erb
ruby
1 <div class="signForm"> 2 <p>Email</p> 3 <%= f.email_field :email, autofocus: true, autocomplete: "email" %> 4 </div> 5 <div class="signForm"> 6 <p>Username</p> 7 <%= f.text_field :username %> 8 </div> 9 <div class="signForm"> 10 <p>Password</p> 11 <%= f.password_field :password, autocomplete: "new-password", placeholder: "***********" %> 12 </div> 13 <div class="signForm"> 14 <p>Confirmation Password</p> 15 <%= f.password_field :password_confirmation, autocomplete: "new-password", placeholder: "***********" %> 16 </div> 17 <div class="signForm"> 18 <%= f.submit "Sign up" %> 19 </div>
config/routes.rb
ruby
1devise_for :users, controllers: { 2 omniauth_callbacks: 'omniauth_callbacks', 3 confirmations: 'confirmations', 4 registrations: 'registrations' 5}
apps/controllers/confirmations_controller.rb
Ruby
1class ConfirmationsController < Devise::ConfirmationsController 2 def show 3 self.resource = resource_class.confirm_by_token(params[:confirmation_token]) 4 yield resource if block_given? 5 6 if resource.errors.empty? 7 set_flash_message(:notice, :confirmed) if is_flashing_format? 8 9 sign_in(resource) 10 11 respond_with_navigational(resource){ redirect_to after_confirmation_path_for(resource_name, resource) } 12 else 13 respond_with_navigational(resource.errors, :status => :unprocessable_entity){ render :new } 14 end 15 end 16end
apps/controllers/registrations_controller.rb
ruby
1class RegistrationsController < Devise::RegistrationsController 2 3 protected 4 5 def update_resource(resource, params) 6 resource.update_without_password(params) 7 end 8 9 def account_update_params 10 devise_parameter_sanitizer.sanitize(:account_update) 11 end 12end
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。