summaryrefslogtreecommitdiff
path: root/lib/aggiedit/roles.ex
blob: e50b53b5b5013dab2caf5d3e643889727115b820 (plain)
1
2
3
4
5
6
7
8
9
10
defmodule Aggiedit.Roles do
  alias Aggiedit.Accounts.User
  alias Aggiedit.Rooms.Post

  def guard?(user, action, object)
  def guard?(%User{role: :admin}, _, _), do: true
  def guard?(%User{room_id: rid}, :show, %Post{room_id: rid}), do: true
  def guard?(%User{id: id, room_id: rid}, action, %Post{user_id: id, room_id: rid}) when action in [:delete, :edit], do: true
  def guard?(_, _, _), do: false
end