diaspora/diaspora_federation

View on GitHub
lib/diaspora_federation/entities/related_entity.rb

Summary

Maintainability
A
0 mins
Test Coverage
A
100%
# frozen_string_literal: true

module DiasporaFederation
  module Entities
    # Entity meta informations for a related entity (parent or target of
    # another entity).
    class RelatedEntity < Entity
      # @!attribute [r] author
      #   The diaspora* ID of the author
      #   @see Person#author
      #   @return [String] diaspora* ID
      property :author, :string

      # @!attribute [r] local
      #   +true+ if the owner of the entity is local on the pod
      #   @return [Boolean] is it a like or a dislike
      property :local, :boolean

      # @!attribute [r] public
      #   Shows whether the entity is visible to everyone or only to some aspects
      #   @return [Boolean] is it public
      property :public, :boolean, default: false

      # @!attribute [r] parent
      #   Parent if the entity also has a parent (Comment or Like) or +nil+ if it has no parent
      #   @return [RelatedEntity] parent entity
      entity :parent, Entities::RelatedEntity, default: nil

      # The root entity, this entity is responsible for relaying relayables
      # @return [RelatedEntity] absolute parent entity
      def root
        root = self
        root = root.parent until root.parent.nil?
        root
      end

      # Get related entity from the backend or fetch it from remote if not available locally
      # @return [RelatedEntity] fetched related entity
      def self.fetch(author, type, guid)
        # Try to fetch locally
        entity = DiasporaFederation.callbacks.trigger(:fetch_related_entity, type, guid)
        return entity if entity

        # Fetch and receive entity from remote if not available locally
        Federation::Fetcher.fetch_public(author, type, guid)
        DiasporaFederation.callbacks.trigger(:fetch_related_entity, type, guid)
      end

      # never add {RelatedEntity} to xml
      def to_xml
        nil
      end

      # never add {RelatedEntity} to json
      def to_json(*_args)
        nil
      end
    end
  end
end