Can I set a default scope to a model based on the current user?

204 Views Asked by At

Currently I have a User model that uses acts as taggable on to give users "roles". So I would have for instance a tag for Member, Admin, Moderator. Every user has a relationship for Reports. However, a Member should only be able to see their reports, a Moderator should be able to see their reports and any Member's reports, and finally the Admin should be able to see everything.

Currently I take care of this on each controller page that accesses reports through an if statement but this seems like an awful way of doing that will eventually lead to someone seeing reports they shouldn't. So this got me thinking would it be possible to set some sort of restriction on the Model's file to take care of this in one spot.

1

There are 1 best solutions below

0
On

You can use the request_store gem and a before_filter in applicationController to make current_user accessible in model. But remember that request is not always there, so account for possible nils