Interface AvatarRepository

All Known Implementing Classes:
DiskAvatarRepository

public interface AvatarRepository
Since:
9.5
  • Method Summary

    Modifier and Type
    Method
    Description
    void
    delete(@NotNull AvatarType type, @NotNull String id)
    Deletes any stored avatars for the specified object and type.
    int
    delete(@NotNull AvatarType type, @NotNull Set<String> idsToSkip, long lastModificationTimeStamp)
    Deletes any stored avatars for the specified type that IDs are not in the IDs to skip collection and that last modification occurred before the specified timestamp.
    long
    Retrieves the configured file size limit for stored avatars.
    @NotNull Optional<Long>
    getVersionId(@NotNull AvatarType type, @NotNull String id)
    Retrieves a version identifier for the avatar with the specified object and type.
    boolean
    isStored(@NotNull AvatarType type, @NotNull String id)
    Retrieves a flag indicating whether an avatar has been stored for the specified object and type.
    load(@NotNull AvatarType type, @NotNull String id, int size)
    Retrieves the current avatar for the specified object and type, or a null if no avatar has been stored.
    loadDefault(@NotNull AvatarType type, int size)
    Loads a default avatar for the specified type in an approximation of the requested size.
    void
    move(@NotNull AvatarType type, @NotNull String oldId, @NotNull String newId)
    Moves any stored avatars for the specified object and type from the old ID to the new ID.
    void
    store(@NotNull AvatarType type, @NotNull String id, @NotNull AvatarSupplier supplier)
    Stores the provided avatar for the specified object and type.
  • Method Details

    • loadDefault

      @NotNull @NotNull CacheableAvatarSupplier loadDefault(@NotNull @NotNull AvatarType type, int size)
      Loads a default avatar for the specified type in an approximation of the requested size. Default avatars are only available in a fixed set of sizes, and dynamic sizes are not created, so the request size is normalized into that set.
      Parameters:
      type - the type of object to retrieve a default avatar for
      size - the size to retrieve the avatar in
      Returns:
      a supplier for accessing the requested default avatar
    • load

      @Nullable @Nullable CacheableAvatarSupplier load(@NotNull @NotNull AvatarType type, @NotNull @NotNull String id, int size)
      Retrieves the current avatar for the specified object and type, or a null if no avatar has been stored.
      Parameters:
      type - the type of object associated with the provided ID
      id - the object's ID
      size - the size to retrieve the avatar in
      Returns:
      a supplier for accessing the requested avatar
    • store

      void store(@NotNull @NotNull AvatarType type, @NotNull @NotNull String id, @NotNull @NotNull AvatarSupplier supplier)
      Stores the provided avatar for the specified object and type.

      The file size for the avatar image is not checked by the repository. That restriction is expected to be applied at the system's edges (REST, SpringMVC, etc.).

      Parameters:
      type - the type of object associated with the provided ID
      id - the object's ID
      supplier - a supplier providing access to the avatar data
    • isStored

      boolean isStored(@NotNull @NotNull AvatarType type, @NotNull @NotNull String id)
      Retrieves a flag indicating whether an avatar has been stored for the specified object and type.
      Parameters:
      type - the type of object associated with the provided ID
      id - the object's ID
      Returns:
      true if a local avatar exists for the specified object; otherwise, false
    • delete

      void delete(@NotNull @NotNull AvatarType type, @NotNull @NotNull String id)
      Deletes any stored avatars for the specified object and type. This removes the original as well as any scaled copies that have been created based on requested sizes.
      Parameters:
      type - the type of object associated with the provided ID
      id - the object's ID
    • delete

      int delete(@NotNull @NotNull AvatarType type, @NotNull @NotNull Set<String> idsToSkip, long lastModificationTimeStamp)
      Deletes any stored avatars for the specified type that IDs are not in the IDs to skip collection and that last modification occurred before the specified timestamp. This removes the original as well as any scaled copies that have been created based on requested sizes.
      Parameters:
      type - the type of object associated with the provided ID
      idsToSkip - the avatar ids for which the deletion will be skipped
      lastModificationTimeStamp - edge for last modification comparison
      Returns:
      number of removed avatar directories
      Since:
      10.1
    • move

      void move(@NotNull @NotNull AvatarType type, @NotNull @NotNull String oldId, @NotNull @NotNull String newId)
      Moves any stored avatars for the specified object and type from the old ID to the new ID.
      Parameters:
      type - the type of object associated with the provided ID
      oldId - the object's old ID
      newId - the object's new ID
    • getMaxSize

      long getMaxSize()
      Retrieves the configured file size limit for stored avatars. Avatars which are larger than this on disk cannot be stored, and calling store(com.atlassian.bamboo.avatar.AvatarType, java.lang.String, com.atlassian.bamboo.avatar.AvatarSupplier) will result in an AvatarStoreException.
      Returns:
      the configured file size limit for stored avatars
    • getVersionId

      @NotNull @NotNull Optional<Long> getVersionId(@NotNull @NotNull AvatarType type, @NotNull @NotNull String id)
      Retrieves a version identifier for the avatar with the specified object and type.
      Parameters:
      type - the type of the object to retrieve a version for
      id - the Object's ID
      Returns:
      a version identifier for the avatar identified by the id and type, which will change only when the underlying avatar is modified