Deviseセッションコントローラをオーバーライドして、ユーザーのログイン動作を調整しています。私の場合は、メインユーザーとサブユーザーの2種類のユーザーがいます。サブユーザは、メインユーザがサブユーザのログインアクセスをtrueに設定した場合にのみログインできます。私は、正しい資格 でログインしたときここで、現在のコードでは、私のセッション制御装置Deviseセッションコントローラのオーバーライド
class SessionsController < Devise::SessionsController
def create
logger.info "Attempt to sign in by #{ params[:user][:email] }"
@user = User.find_by_email(params[:user][:email])
if @user != nil
if [email protected]_portal_access?
flash[:notice] = "#{ @user.email } do not have portal access."
redirect_to :controller => 'welcome'
else
super
end
end
end
def destroy
logger.info "#{ current_user.email } signed out"
super
end
end
ここに私のユーザモデル
class User < ActiveRecord::Base
has_many :child_users, :class_name => "User",:foreign_key => "parent_id", :dependent => :destroy
belongs_to :parent, :class_name => "User"
end
されている - それは、メインユーザーである場合。ユーザーログインは正常に終了しました。 - ポータルアクセスのあるサブユーザーの場合サブユーザーのログインに成功しました。 - ポータルアクセスではないサブユーザの場合ユーザーは「ポータルアクセスを持っていない」と歓迎するページにリダイレクトされ、ユーザーにログインを要求します。私が午前
問題がある:私はデータベースに存在しない資格情報を使用してログインしようとすると、私はこのようにする必要があり、「あなたのroutes.rbをで
Template is missing
Missing template users/sessions/create, sessions/create, devise/sessions/create, devise/create, application/create with {:locale=>[:en], :formats=>[:html], :handlers=>[:erb, :builder, :arb, :coffee]}. Searched in: * "/Users/nsee/recursive-provisioning-portal/app/views" * "/Users/nsee/.rvm/gems/ruby-1.9.3-p392/gems/twitter-bootstrap-rails-2.2.6/app/views" * "/Users/nsee/.rvm/gems/ruby-1.9.3-p392/gems/activeadmin-0.5.1/app/views" * "/Users/nsee/.rvm/gems/ruby-1.9.3-p392/gems/kaminari-0.14.1/app/views" * "/Users/nsee/.rvm/gems/ruby-1.9.3-p392/gems/devise-2.2.4/app/views"
は、あなたのセッションは、正しいビューフォルダに工夫のうち、フォルダを表示移動した動作するか確認してください?また、あなたのルートを見ることができれば助けになるかもしれません。あなたはこれを見ましたか? [Getting-started/Configuring-controllers](http://devise.plataformatec.com.br/#getting-started/configuring-controllers) – Stephen