Interface MetadataStore<T>


public interface MetadataStore<T>
  • Method Summary

    Modifier and Type
    Method
    Description
    getMetadata​(T subject, String metadataKey)
    Returns all metadata values attached to an object.
    boolean
    hasMetadata​(T subject, String metadataKey)
    Tests to see if a metadata attribute has been set on an object.
    void
    invalidateAll​(Plugin owningPlugin)
    Invalidates all metadata in the metadata store that originates from the given plugin.
    void
    removeMetadata​(T subject, String metadataKey, Plugin owningPlugin)
    Removes a metadata item owned by a plugin from a subject.
    void
    setMetadata​(T subject, String metadataKey, MetadataValue newMetadataValue)
    Adds a metadata value to an object.
  • Method Details

    • setMetadata

      void setMetadata(@NotNull T subject, @NotNull String metadataKey, @NotNull MetadataValue newMetadataValue)
      Adds a metadata value to an object.
      Parameters:
      subject - The object receiving the metadata.
      metadataKey - A unique key to identify this metadata.
      newMetadataValue - The metadata value to apply.
      Throws:
      IllegalArgumentException - If value is null, or the owning plugin is null
    • getMetadata

      @NotNull List<MetadataValue> getMetadata(@NotNull T subject, @NotNull String metadataKey)
      Returns all metadata values attached to an object. If multiple plugins have attached metadata, each will value will be included.
      Parameters:
      subject - the object being interrogated.
      metadataKey - the unique metadata key being sought.
      Returns:
      A list of values, one for each plugin that has set the requested value.
    • hasMetadata

      boolean hasMetadata(@NotNull T subject, @NotNull String metadataKey)
      Tests to see if a metadata attribute has been set on an object.
      Parameters:
      subject - the object upon which the has-metadata test is performed.
      metadataKey - the unique metadata key being queried.
      Returns:
      the existence of the metadataKey within subject.
    • removeMetadata

      void removeMetadata(@NotNull T subject, @NotNull String metadataKey, @NotNull Plugin owningPlugin)
      Removes a metadata item owned by a plugin from a subject.
      Parameters:
      subject - the object to remove the metadata from.
      metadataKey - the unique metadata key identifying the metadata to remove.
      owningPlugin - the plugin attempting to remove a metadata item.
      Throws:
      IllegalArgumentException - If plugin is null
    • invalidateAll

      void invalidateAll(@NotNull Plugin owningPlugin)
      Invalidates all metadata in the metadata store that originates from the given plugin. Doing this will force each invalidated metadata item to be recalculated the next time it is accessed.
      Parameters:
      owningPlugin - the plugin requesting the invalidation.
      Throws:
      IllegalArgumentException - If plugin is null