Package com.atlassian.bitbucket.avatar
Interface CacheableAvatarSupplier
- All Superinterfaces:
AvatarSupplier
,InputSupplier<InputStream>
- All Known Implementing Classes:
DelegatingCacheableAvatarSupplier
Augments the
AvatarSupplier
with timestamp information that can be used to control caching, or to simply
display a modification date indicating when the avatar was last updated.-
Field Summary
Modifier and TypeFieldDescriptionstatic final int
Marker value to be returned bygetTimestamp()
for avatars which cannot be modified.static final int
Marker value to be returned bygetTimestamp()
for avatars whose modification timestamp cannot be determined by the system. -
Method Summary
Modifier and TypeMethodDescriptionlong
The timestamp at which the avatar was last modified, in milliseconds.Methods inherited from interface com.atlassian.bitbucket.avatar.AvatarSupplier
getContentType, open
-
Field Details
-
TIMESTAMP_ETERNAL
static final int TIMESTAMP_ETERNALMarker value to be returned bygetTimestamp()
for avatars which cannot be modified.- See Also:
-
TIMESTAMP_UNKNOWN
static final int TIMESTAMP_UNKNOWNMarker value to be returned bygetTimestamp()
for avatars whose modification timestamp cannot be determined by the system.- See Also:
-
-
Method Details
-
getTimestamp
long getTimestamp()The timestamp at which the avatar was last modified, in milliseconds.To account for differences in avatar repository implementations:
- If timestamp information is not available, implementations shall return
TIMESTAMP_UNKNOWN
. Avatars without timestamps should not be cached, as it may not be possible to reliably detect updates. - If the avatar cannot be updated, implementations shall return
TIMESTAMP_ETERNAL
. Such avatars may be cached more aggressively, as they cannot change.
- Returns:
- the avatar's modification timestamp in milliseconds, or
TIMESTAMP_UNKNOWN
if no modification date is available, orTIMESTAMP_ETERNAL
if the avatar is unmodifiable
- If timestamp information is not available, implementations shall return
-