Так же, как отказ от ответственности, я новичок в rails и программировании в целом, поэтому извиняюсь за недопонимание чего-то очевидного.
У меня есть Authlogic с активацией и работает. Поэтому для моего сайта я хотел бы, чтобы мои пользователи, которые вошли в систему, могли регистрировать других пользователей. Новый пользователь выберет свой логин и пароль в электронном письме для активации, но существующий пользователь должен ввести их по электронной почте, должности и парочке других атрибутов. Я хочу, чтобы это сделал существующий пользователь.
Проблема, с которой я сталкиваюсь, если я вхожу в систему, а затем пытаюсь создать нового пользователя, он просто пытается обновить существующего пользователя и не создает нового. Я не уверен, есть ли способ исправить это, запустив еще один сеанс ??? Если это даже правильно / возможно, я бы не знал, как это реализовать.
Я понимаю, что, не зная полностью о своем приложении, может быть сложно ответить на этот вопрос, но звучит ли это как правильный способ сделать это? Я что-то упустил?
Контроллер пользователей:
class UsersController < ApplicationController
before_filter :require_no_user, :only => [:new, :create]
before_filter :require_user, :only => [:show, :edit, :update]
def new
@user = User.new
end
def create
@user = User.new
if @user.signup!(params)
@user.deliver_activation_instructions!
flash[:notice] = "Your account has been created. Please check your e-mail for your account activation instructions!"
redirect_to profile_url
else
render :action => :new
end
end
def show
@user = @current_user
end
def edit
@user = @current_user
end
def update
@user = @current_user # makes our views "cleaner" and more consistent
if @user.update_attributes(params[:user])
flash[:notice] = "Account updated!"
redirect_to profile_url
else
render :action => :edit
end
end
end
Мой контроллер User_Session:
class UserSessionsController < ApplicationController
before_filter :require_no_user, :only => [:new, :create]
before_filter :require_user, :only => :destroy
def new
@user_session = UserSession.new
end
def create
@user_session = UserSession.new(params[:user_session])
if @user_session.save
flash[:notice] = "Login successful!"
if @user_session.user.position == 'Battalion Commander' : redirect_to battalion_path(@user_session.user.battalion_id)
else
end
else
render :action => :new
end
end
def destroy
current_user_session.destroy
flash[:notice] = "Logout successful!"
redirect_back_or_default new_user_session_url
end
end