fixed routes, fixed become/revert

This commit is contained in:
jomo
2014-05-01 20:56:03 +02:00
parent c2b9b1fdd7
commit c85364fdd1
4 changed files with 57 additions and 46 deletions

View File

@@ -39,7 +39,50 @@ class SessionsController < ApplicationController
end end
def destroy def destroy
session.delete(:user_id) if original_user = User.find_by_id(session[:original_user_id])
redirect_to login_path, :notice => "Logged out!" logout_user = current_user
session[:user_id] = original_user.try(:id)
session.delete(:original_user_id)
flash[:notice] = "You are no longer #{logout_user.name}!"
redirect_to original_user
else
session.delete(:user_id)
redirect_to login_path, :notice => "Logged out!"
end
end
def become
original_user = current_user
new_user = User.find_by_id(params[:user])
if original_user && new_user && admin? && current_user.role >= new_user.role
if original_user == new_user
flash[:alert] = "You are already \"#{new_user.name}\"!"
else
if session[:original_user_id]
flash[:alert] = "Please revert to your account first"
else
session[:original_user_id] = original_user.id
session[:user_id] = new_user.id
flash[:notice] = "You are now \"#{new_user.name}\"!"
end
end
else
flash[:alert] = "You are not allowed to become this user"
end
redirect_to new_user
end
def revert
if old_user = current_user
original_user = User.find_by_id(session[:original_user_id])
if original_user && original_user.try(:admin?)
session.delete(:original_user_id)
session[:user_id] = original_user.try(:id)
flash[:notice] = "You are no longer '#{old_user.name}'!"
end
redirect_to old_user
else
redirect_to login_path
end
end end
end end

View File

@@ -200,36 +200,6 @@ class UsersController < ApplicationController
end end
end end
def become
original_user = current_user
new_user = User.find(params[:id])
if admin? && current_user.role >= new_user.role
if original_user == new_user
flash[:alert] = "You are already \"#{new_user.name}\"!"
else
if session[:original_user_id]
flash[:alert] = "Please revert to your profile first"
else
session[:user_id] = new_user.id
session[:original_user_id] = original_user.id
flash[:notice] = "You are now \"#{new_user.name}\"!"
end
end
end
redirect_to new_user
end
def unbecome
old_user = current_user
original_user = User.find(session[:original_user_id])
if old_user && original_user && original_user.admin?
session.delete(:original_user_id)
session[:user_id] = original_user.id
flash[:notice] = "You are no longer '#{old_user.name}'!"
end
redirect_to old_user
end
private private

View File

@@ -6,9 +6,9 @@
<% end %> <% end %>
<div class="profile-action" > <div class="profile-action" >
<% if !session[:original_user_id] && admin? %> <% if !session[:original_user_id] && admin? %>
<%= link_to "become this user", become_user_path(@user), :class => "btn blue" %> <%= link_to "become this user", become_path(user: @user), :class => "btn blue" %>
<% elsif session[:original_user_id] %> <% elsif session[:original_user_id] %>
<%= link_to "revert", unbecome_users_path, :class => "btn blue" %> <%= link_to "revert", revert_path, :class => "btn blue" %>
<% end %> <% end %>
</div> </div>
<div class="clear"></div> <div class="clear"></div>

View File

@@ -4,7 +4,7 @@ Site::Application.routes.draw do
resources :comments resources :comments
end end
resources :statics, only: [:index, :donate], path: '' do resources :statics, only: [:index, :donate], path: '/' do
collection do collection do
get 'donate' get 'donate'
get 'index' get 'index'
@@ -15,26 +15,24 @@ Site::Application.routes.draw do
resources :users do resources :users do
member do member do
get 'become'
get 'confirm' get 'confirm'
end end
collection do
get 'unbecome'
end
end end
resources :forumgroups, path: 'forums/groups' resources :forumgroups, path: '/forums/groups'
resources :forums, path: 'forums' resources :forums, path: '/forums'
resources :forumthreads, path: '/forums/threads' do resources :forumthreads, path: '/forums/threads' do
resources :threadreplies, path: '/forums/threads/replies' resources :threadreplies, path: 'replies'
end end
# get '/status' => 'status#show' # get '/status' => 'status#show'
get 'login' => 'sessions#new' get 'login' => 'sessions#new'
post 'login' => 'sessions#create' post 'login' => 'sessions#create'
get "logout" => 'sessions#destroy' get 'become' => 'sessions#become'
get 'signup' => 'users#new' get 'revert' => 'sessions#revert'
get 'logout' => 'sessions#destroy'
get 'signup' => 'users#new'
# post 'paypal' => 'paypal#create' # post 'paypal' => 'paypal#create'