Hello,

I am lil bit confused.
Will this help on returning back to the admin user again?

On Thursday, September 27, 2012 9:54:20 AM UTC+5:30, Walter Lee Davis wrote:
>
> On Sep 26, 2012, at 11:52 PM, Avi wrote: 
>
> > Currently I am using CanCan. 
> > Can you please explain a bit more on your solution? 
>
> #users_controller.rb 
>   before_filter :authenticate_impersonator!, :only => [:index, 
> :impersonate, :stop_impersonating] 
>
>   def impersonate 
>     session[:impersonating] = params[:practice_id] 
>     redirect_to( '/calendar' ) 
>   end 
>   
>   def stop_impersonating 
>     session[:impersonating] = nil 
>     redirect_to( '/users/index' ) 
>   end 
>
>   def authenticate_impersonator! 
>     redirect_to(:root) unless (can? :impersonate, User) 
>   end 
>
> #application_controller.rb 
>   helper_method :current_practice 
>   def current_practice 
>     if session[:impersonating] 
>       Practice.find session[:impersonating] 
>     else 
>       current_user.practice 
>     end 
>   end 
>
> #views/layouts/index.html.erb 
>
> <%- if session[:impersonating] -%> 
> <div id="impersonating"> 
>         <p>Currently impersonating <strong><%= 
> current_practice.name%></strong> <%= link_to "Stop Impersonating", 
> "/users/stop_impersonating", 
> :class => "form_button delete" %></p> 
> </div> 
> <%- end -%> 
>
>
> Everything in this solution centers around the current_practice helper, 
> which is where I used the session to side-step the current user and pretend 
> to be another. 
>
> Walter 
>
> > 
> > On Wednesday, September 26, 2012 6:51:43 PM UTC+5:30, Walter Lee Davis 
> wrote: 
> > 
> > On Sep 26, 2012, at 4:58 AM, Avi wrote: 
> > 
> > > Hello, 
> > > 
> > > I have an interesting requirement. Don't know how to do it. 
> > > I have an Admin, which can see a list of users. 
> > > All the users will have a button (Login). 
> > > The Admin can click on the Login button to to access the user's 
> account. 
> > > If Admin does this he will be logged out of his account. But how to 
> access back his own account if he tries to come out of that user's account? 
> > > 
> > 
> > What method are you using for authentication? I did something similar in 
> Devise, where I allowed the admin to impersonate another user. I hooked 
> into the current_user method and allowed an admin user to assume the 
> identity of another user without logging out. Since admins were allowed to 
> see everything anyway (in CanCan) I didn't need to do anything special 
> besides store the ID of the account I was impersonating in the session. 
> > 
> > Walter 
> > 
> > 
> > -- 
> > You received this message because you are subscribed to the Google 
> Groups "Ruby on Rails: Talk" group. 
> > To post to this group, send email to 
> > rubyonra...@googlegroups.com<javascript:>. 
>
> > To unsubscribe from this group, send email to 
> rubyonrails-ta...@googlegroups.com <javascript:>. 
> > To view this discussion on the web visit 
> https://groups.google.com/d/msg/rubyonrails-talk/-/udMtXUaASAoJ. 
> > For more options, visit https://groups.google.com/groups/opt_out. 
> >   
> >   
>
>

-- 
You received this message because you are subscribed to the Google Groups "Ruby 
on Rails: Talk" group.
To post to this group, send email to rubyonrails-talk@googlegroups.com.
To unsubscribe from this group, send email to 
rubyonrails-talk+unsubscr...@googlegroups.com.
To view this discussion on the web visit 
https://groups.google.com/d/msg/rubyonrails-talk/-/WJ-3bA_74CsJ.
For more options, visit https://groups.google.com/groups/opt_out.


Reply via email to