return
end
- @user_block = UserBlock.new(:user_id => @this_user.id,
- :creator_id => @user.id,
- :reason => params[:user_block][:reason],
- :ends_at => Time.now.getutc() + @block_period.hours,
- :needs_view => params[:user_block][:needs_view])
+ @user_block = UserBlock.new({
+ :user_id => @this_user.id,
+ :creator_id => @user.id,
+ :reason => params[:user_block][:reason],
+ :ends_at => Time.now.getutc() + @block_period.hours,
+ :needs_view => params[:user_block][:needs_view]
+ }, :without_protection => true)
if @user_block.save
flash[:notice] = t('user_block.create.flash', :name => @this_user.display_name)
end
if @user_block.creator_id != @user.id
- flash[:notice] = t('user_block.update.only_creator_can_edit')
+ flash[:error] = t('user_block.update.only_creator_can_edit')
redirect_to :action => "edit"
return
end
if @user_block.update_attributes({ :ends_at => Time.now.getutc() + @block_period.hours,
:reason => params[:user_block][:reason],
- :needs_view => params[:user_block][:needs_view] })
+ :needs_view => params[:user_block][:needs_view] }, :without_protection => true)
flash[:notice] = t('user_block.update.success')
redirect_to(@user_block)
else
private
##
# require that the user is a moderator, or fill out a helpful error message
- # and return them to the login screen where they might be able to login as
- # a moderator.
+ # and return them to the blocks index.
def require_moderator
unless @user.moderator?
- flash[:notice] = t('user_block.filter.not_a_moderator')
+ flash[:error] = t('user_block.filter.not_a_moderator')
redirect_to :action => 'index'
end
end
# ensure that there is a "this_user" instance variable
def lookup_this_user
@this_user = User.find_by_display_name(params[:display_name])
+ rescue ActiveRecord::RecordNotFound
+ redirect_to :controller => 'user', :action => 'view', :display_name => params[:display_name] unless @this_user
end
##
# ensure that there is a "user_block" instance variable
def lookup_user_block
@user_block = UserBlock.find(params[:id])
+ rescue ActiveRecord::RecordNotFound
+ render :action => "not_found", :status => :not_found
end
##
@valid_params = false
if !UserBlock::PERIODS.include?(@block_period)
- flash[:notice] = t('user_block.filter.block_period')
+ flash[:error] = t('user_block.filter.block_period')
elsif @user_block and !@user_block.active?
- flash[:notice] = t('user_block.filter.block_expired')
+ flash[:error] = t('user_block.filter.block_expired')
else
@valid_params = true