Ruby on rails 如何使用电子邮件跳过omniauth(社交身份验证)的用户确认

Ruby on rails 如何使用电子邮件跳过omniauth(社交身份验证)的用户确认,ruby-on-rails,ruby,ruby-on-rails-3,ruby-on-rails-4,Ruby On Rails,Ruby,Ruby On Rails 3,Ruby On Rails 4,我的omniauth\u回调\u controller.rb class OmniauthCallbacksController < Devise::OmniauthCallbacksController def facebook @user = User.from_omniauth(request.env["omniauth.auth"]) if @user.persisted? sign_in_and_redirect @user, :eve

我的omniauth\u回调\u controller.rb

class OmniauthCallbacksController < Devise::OmniauthCallbacksController

def facebook
    @user = User.from_omniauth(request.env["omniauth.auth"])    

    if @user.persisted?
        sign_in_and_redirect @user, :event => :authentication
        set_flash_message(:notice, :success, :kind => "Facebook") if is_navigational_format?
    else
        session["devise.facebook_data"] = request.env["omniauth.auth"]
        redirect_to new_user_registration_url
    end
end

def google_oauth2
    @user = User.from_omniauth(request.env['omniauth.auth'])

    if @user.persisted?
      sign_in_and_redirect @user, :event => :authentication
      set_flash_message(:notice, :success, :kind => "Google") if is_navigational_format?
    else
        session["devise.google_oauth2_data"] = request.env["omniauth.auth"]
        redirect_to new_user_registration_url
    end
  end
结束


我想跳过facebook和google用户的确认,我可以把用户放在哪里。跳过确认!提前感谢

添加它的理想位置是在您的
用户中。从\u omniauth
工厂方法,因为在控制器中设置它会导致额外的更新查询

def self.from_omniauth(auth)
  where(provider: auth.provider, uid: auth.uid).first_or_create do |user|
    user.fullname = auth.info.name
    user.provider = auth.provider
    user.uid = auth.uid
    user.email = auth.info.email
    user.image = auth.info.image
    user.password = Devise.friendly_token[0,20]
    user.skip_confirmation! unless user.confirmed?
  end
end

除非user.confirm?
仅确保用户每次登录时不会更新
confirm\u at

添加它的理想位置是在您的
用户中。从\u omniauth
工厂方法,因为在控制器中设置它会导致额外的更新查询

def self.from_omniauth(auth)
  where(provider: auth.provider, uid: auth.uid).first_or_create do |user|
    user.fullname = auth.info.name
    user.provider = auth.provider
    user.uid = auth.uid
    user.email = auth.info.email
    user.image = auth.info.image
    user.password = Devise.friendly_token[0,20]
    user.skip_confirmation! unless user.confirmed?
  end
end
除非用户已确认?
仅确保用户每次登录时都不会更新位于的
已确认