sutty/app/policies/post_policy.rb

70 lines
1.3 KiB
Ruby
Raw Normal View History

2019-03-26 15:32:20 +00:00
# frozen_string_literal: true
2019-07-03 23:40:24 +00:00
# Política de acceso a artículos
#
# TODO: Implementar Invitadx
class PostPolicy
2018-09-28 17:15:09 +00:00
attr_reader :post
2019-07-03 23:40:24 +00:00
def initialize(usuarie, post)
@usuarie = usuarie
2018-09-28 17:15:09 +00:00
@post = post
end
def index?
true
end
# Lxs invitadxs solo pueden ver sus propios posts
def show?
2019-07-03 23:40:24 +00:00
true || post.author == usuarix.email
2018-09-28 17:15:09 +00:00
end
def new?
create?
end
def create?
true
end
def edit?
update?
end
# Lxs invitadxs solo pueden modificar sus propios artículos
def update?
2019-07-03 23:40:24 +00:00
true || post.author == usuarix.email
2018-09-28 17:15:09 +00:00
end
2019-05-30 17:33:51 +00:00
# Solo las usuarias pueden eliminar artículos. Lxs invitadxs pueden
# borrar sus propios artículos
def destroy?
update?
end
2019-07-03 23:40:24 +00:00
# Las usuarias pueden ver todos los posts
#
# Lxs invitadxs solo pueden ver sus propios posts
class Scope
attr_reader :usuarie, :scope
def initialize(usuarie, scope)
@usuarie = usuarie
@scope = scope
end
2018-09-28 17:15:09 +00:00
# Las usuarias pueden ver todos los posts
#
# Lxs invitadxs solo pueden ver sus propios posts
def resolve
2019-07-03 23:40:24 +00:00
# TODO: filtrar por invitade
return scope
2018-09-28 17:15:09 +00:00
# Asegurarse que al menos devolvemos []
[scope.find do |post|
2019-07-03 23:40:24 +00:00
post.author == usuarie.email
2018-09-28 17:15:09 +00:00
end].flatten.compact
end
end
end