2013-03-12 15 views
0

Я работаю над реализацией учетной записи верхнего уровня с множеством пользователей.Разработка аутентификации с учетными записями и пользователями

Я отработкой решение этого вопроса: Use both Account and User tables with Devise

Что работает:

После пользователь отправляет регистрационную форму (ниже) пользователя и учетная запись будет создана по желанию.

Что не работает:

Пользователь не аутентифицирован до redirect_to accounts_path. Чтобы аутентифицироваться, пользователь должен щелкнуть логин и ввести учетные данные, с которыми они только что зарегистрировались. Вместо этого мне нужно, чтобы пользователь был аутентифицирован перед перенаправлением.

Я работаю над этим в течение нескольких часов, пробовал несколько подходов, но ничего не работает.

Может ли кто-нибудь помочь мне с кодом для аутентификации пользователя после успешного создания учетной записи пользователя/учетной записи. БЛАГОДАРЯ!

Модели

class Account < ActiveRecord::Base 
    has_many :users, :inverse_of => :account, :dependent => :destroy 
    accepts_nested_attributes_for :users 
    attr_accessible :name, :users_attributes 
end 

class User < ActiveRecord::Base 
    belongs_to :account, :inverse_of => :users 
    validates :account, :presence => true 
    devise :database_authenticatable, :registerable, 
     :recoverable, :rememberable, :trackable, :validatable, 
     :confirmable, :lockable, :timeoutable 
    attr_accessible :email, :password, :password_confirmation, :remember_me 
end 

Маршруты

resources :accounts, :only => [:index, :new, :create, :destroy] 
controllers/accounts_controller.rb 

Контроллеры

class AccountsController < ApplicationController 

    def new 
    @account = Account.new 
    @account.users.build # build a blank user or the child form won't display 
    end 

    def create 
    @account = Account.new(params[:account]) 
    if @account.save 
     flash[:success] = "Account created" 
     redirect_to accounts_path 
    else 
     render 'new' 
    end 
    end 

end 

просмотров/счета/вид new.html.erb

<h2>Create Account</h2> 

<%= form_for(@account) do |f| %> 
    <%= render 'shared/error_messages', :object => f.object %> 
    <div class="field"> 
    <%= f.label :name %><br /> 
    <%= f.text_field :name %> 
    </div> 

    <%= f.fields_for :users do |user_form| %> 
    <div class="field"><%= user_form.label :email %><br /> 
    <%= user_form.email_field :email %></div> 
    <div class="field"><%= user_form.label :password %><br /> 
    <%= user_form.password_field :password %></div> 
    <div class="field"><%= user_form.label :password_confirmation %><br /> 
    <%= user_form.password_field :password_confirmation %></div> 
    <% end %> 

    <div class="actions"> 
    <%= f.submit "Create account" %> 
    </div> 
<% end %> 

ответ

1

Вам нужно вручную подписать пользователя в. В контроллере счета вам нужно sign_in(user), где user является фактической User модели записи, которую вы хотите подписать in

Проблема в том, что у вас есть одна учетная запись для многих пользователей. Таким образом, вы должны будете получить доступ к одному пользователю каким-то образом, например:

def create 
    @account = Account.new(params[:account]) 
    if @account.save 
     sign_in(@account.users.first) 
     flash[:success] = "Account created" 
     redirect_to accounts_path 
    else 
     render 'new' 
    end 
    end 
+0

Большое вам спасибо. Я наклеил, вероятно, две дюжины комбайнов method/param прямо там, но, похоже, не смог найти нужного пользователя. Это сработало отлично. – Eric

1

Вам нужно добавить

before_filter :authenticate_user!, :except => [:new,:create] 

к контроллеру счета для того, чтобы обеспечить аутентификацию остальных действий

Смежные вопросы