Interface AttachmentManager
- All Known Subinterfaces:
- AttachmentManagerInternal
- All Known Implementing Classes:
- DefaultAttachmentManager,- ReadThroughCachingAttachmentManager
- 
Method SummaryModifier and TypeMethodDescriptionvoidcopyAttachment(Attachment attachment, ContentEntityObject destinationContent) Copy specified attachment to specified destination content.voidcopyAttachments(ContentEntityObject sourceContent, ContentEntityObject destinationContent) Copy the latest version of all the attachments on the sourceContent to the destinationContent.voidcopyAttachments(ContentEntityObject sourceContent, ContentEntityObject destinationContent, SaveContext saveContext) Copy the latest version of all the attachments on the sourceContent to the destinationContent.intReturns a count of the number of latest versions of attachmentsintcountLatestVersionsOfAttachmentsOnPageSince(ContentEntityObject content, Date since) Fetches number of attachments changed on a page since a specific timestampintReturns a count of the number of latest versions of attachments (including trashed)voiddeepAttachmentDelete(AttachmentDeleteOptions attachmentDeleteOptions) Support delete multiple attachments in batchfindAttachmentForDownloadPath(String downloadPath) Find anAttachmentfor the givendownloadPath.getAllVersions(Attachment attachment) Get all versions of an attachment, starting with the current versionReturns a list of all attachments, old and new.getAttachment(long id) Deprecated.getAttachment(ContentEntityObject content, String attachmentFileName) Deprecated.since 7.5.0, useAttachmentServiceinstead in plugins, or useAttachmentManagerInternalin core where applicablegetAttachment(ContentEntityObject content, String attachmentFileName, int version) Deprecated.since 7.5.0, useAttachmentServiceinstead in plugins, or useAttachmentManagerInternalin core where applicablegetAttachmentData(Attachment attachment) Retrieve the data for attachmentgetAttachmentData(Attachment attachment, Optional<RangeRequest> range) Retrieve the specified range of data for attachmentgetAttachmentDownloadPath(ContentEntityObject content, String attachmentFileName) Get the download path for the most recent version of an attachment with the given name for some contentgetAttachments(List<Long> ids) Deprecated.since 7.5.0, useAttachmentServiceinstead in plugins, or useAttachmentManagerInternalin core where applicableFetches statistics about attachmentsReturns the currently active storage type.getLastAddedVersionsOf(Attachment attachment) Retrieves all the last added versions for each user who has added a version of the attachment That is, if a user has added multiple versions, only the latest added version will be added to the list returned.Returns a list of only latest versions of attachments.getLatestVersionsOfAttachmentsForMultipleCeos(Iterable<? extends ContentEntityObject> contentEntityObjects) Returns a list of all the latest versions of attachments for all the CEOs providedReturns a list of only latest versions of attachments (including trashed).getPreviousVersions(Attachment attachment) Get all non-current versions of an attachment, not including the current version.Gets a list of remapped attachment IDs.voidmoveAttachment(Attachment latestVersion, String fileName, ContentEntityObject newContent) voidremoveAttachmentFromServer(Attachment attachment) Removes an Attachment and its data from the server and data store.voidremoveAttachments(List<? extends Attachment> attachments) Removes the contents of attachments from the servervoidremoveAttachmentVersionFromServer(Attachment attachment) Removes the given version of the Attachment and its data from the server and data store.voidRemoves the given version of the Attachment and its data from the server and data store while suppressing notifications.voidremoveAttachmentWithoutNotifications(Attachment attachment) Removes an Attachment and its data from the server while suppressing notifications.voidrestore(Attachment attachment) Restores an attachment from trash.voidsaveAttachment(Attachment attachment, @Nullable Attachment previousVersion, InputStream attachmentData) Saves an Attachment and its datavoidsaveAttachment(Attachment attachment, @Nullable Attachment previousVersion, InputStream attachmentData, SaveContext saveContext) Saves an Attachment and its data, taking aSaveContextto allow more useful event handling.voidsaveAttachments(List<SavableAttachment> savableAttachments) Saves multiple attachment and their datavoidsaveAttachments(List<SavableAttachment> savableAttachments, SaveContext saveContext) Saves multiple attachment and their datavoidsetAttachmentData(Attachment attachment, InputStream attachmentData) Set the data belonging to attachmentvoidtrash(Attachment attachment) Moves an attachment to the trash.
- 
Method Details- 
deepAttachmentDeleteSupport delete multiple attachments in batch- Parameters:
- attachmentDeleteOptions-
- Since:
- 7.17.0
 
- 
getAttachmentDeprecated.since 7.5.0, useAttachmentServiceinstead in plugins, or useAttachmentManagerInternalin core where applicable- Parameters:
- id-
- Returns:
- attachment with id
 
- 
getAttachmentsDeprecated.since 7.5.0, useAttachmentServiceinstead in plugins, or useAttachmentManagerInternalin core where applicableReturns a list of attachments matching the given list of IDs. Returns an empty list if no such attachments exist. In the case where some IDs exist and some don't, only the existing Attachments will be returned.- Parameters:
- ids- list of IDs to retrieve.
- Returns:
- attachments matching ids in the list
 
- 
getAllVersionsOfAttachments@Transactional(readOnly=true) List<Attachment> getAllVersionsOfAttachments(ContentEntityObject content) Returns a list of all attachments, old and new.
- 
getLatestVersionsOfAttachments@Transactional(readOnly=true) List<Attachment> getLatestVersionsOfAttachments(ContentEntityObject content) Returns a list of only latest versions of attachments.
- 
getLatestVersionsOfAttachmentsForMultipleCeos@Transactional(readOnly=true) List<Attachment> getLatestVersionsOfAttachmentsForMultipleCeos(Iterable<? extends ContentEntityObject> contentEntityObjects) Returns a list of all the latest versions of attachments for all the CEOs provided- Parameters:
- contentEntityObjects-
- Since:
- 5.9.2
 
- 
getLatestVersionsOfAttachmentsWithAnyStatus@Transactional(readOnly=true) List<Attachment> getLatestVersionsOfAttachmentsWithAnyStatus(ContentEntityObject content) Returns a list of only latest versions of attachments (including trashed).
- 
countLatestVersionsOfAttachmentsReturns a count of the number of latest versions of attachments
- 
countLatestVersionsOfAttachmentsWithAnyStatusReturns a count of the number of latest versions of attachments (including trashed)
- 
countLatestVersionsOfAttachmentsOnPageSinceFetches number of attachments changed on a page since a specific timestamp- Parameters:
- content- the content object
- since- the date of earliest change
- Returns:
- the number of attachments on a content object (including trashed) changed since
- Since:
- 7.3.0
 
- 
getAttachmentStatisticsFetches statistics about attachments- Returns:
- an AttachmentStatisticsDTO object with statistics about attachments such as total and current count
- Since:
- 6.11.0
 
- 
getAttachmentData@Transactional(readOnly=true, noRollbackFor=java.lang.IllegalArgumentException.class) InputStream getAttachmentData(Attachment attachment) Retrieve the data for attachment- Parameters:
- attachment- the Attachment the data belongs to
- Returns:
- InputStream representing the data
- Throws:
- RuntimeException- if the data could not be found
 
- 
getAttachmentData@Transactional(readOnly=true, noRollbackFor=java.lang.IllegalArgumentException.class) InputStream getAttachmentData(Attachment attachment, Optional<RangeRequest> range) Retrieve the specified range of data for attachment- Parameters:
- attachment- the Attachment the data belongs to
- range- the range of data to retrieve. See- invalid reference- com.atlassian.filestore.client.api.entity.ByteRanges
- Returns:
- InputStream representing the data
- Throws:
- RuntimeException- if the data could not be found
- Since:
- 5.10
 
- 
removeAttachmentFromServerRemoves an Attachment and its data from the server and data store.- Parameters:
- attachment- the Attachment to remove
 
- 
removeAttachmentWithoutNotificationsRemoves an Attachment and its data from the server while suppressing notifications. This is useful when you don't want to send notifications when removing the file.- Since:
- 5.8
 
- 
removeAttachmentVersionFromServerRemoves the given version of the Attachment and its data from the server and data store.In case of the given attachment being the latest version, the previous version (if any) gets removed and the given object impersonates the previous version as the latest version. - Parameters:
- attachment- the Attachment to remove
- Since:
- 4.3
 
- 
removeAttachmentVersionFromServerWithoutNotificationsRemoves the given version of the Attachment and its data from the server and data store while suppressing notifications. This is useful when you don't want to send notifications when removing the file.In case of the given attachment being the latest version, the previous version (if any) gets removed and the given object impersonates the previous version as the latest version. - Parameters:
- attachment- the Attachment to remove
 
- 
removeAttachmentsRemoves the contents of attachments from the server- Parameters:
- attachments- a List of Attachments
- See Also:
 
- 
moveAttachment- Parameters:
- latestVersion- The attachment to be moved
- fileName- New name of the file
- newContent- The new contentEntiityObject which will be parent to the attachment
 
- 
copyAttachmentsvoid copyAttachments(ContentEntityObject sourceContent, ContentEntityObject destinationContent, SaveContext saveContext) throws IOException Copy the latest version of all the attachments on the sourceContent to the destinationContent.- Parameters:
- sourceContent- the content with attachments to be copied.
- destinationContent- the content to copy the attachments to.
- saveContext- details the circumstances under which the attachments are being copied.
- Throws:
- IOException- if there are problems reading or writing attachment data during the copy.
- Since:
- 5.10
 
- 
copyAttachmentsvoid copyAttachments(ContentEntityObject sourceContent, ContentEntityObject destinationContent) throws IOException Copy the latest version of all the attachments on the sourceContent to the destinationContent.- Parameters:
- sourceContent- the content with attachments to be copied.
- destinationContent- the content to copy the attachments to.
- Throws:
- IOException- if there are problems reading or writing attachment data during the copy.
 
- 
copyAttachmentvoid copyAttachment(Attachment attachment, ContentEntityObject destinationContent) throws IOException Copy specified attachment to specified destination content.- Parameters:
- attachment- the attachment
- destinationContent- the destination
- Throws:
- IOException
 
- 
getAttachment@Deprecated @Transactional(readOnly=true) Attachment getAttachment(ContentEntityObject content, String attachmentFileName, int version) Deprecated.since 7.5.0, useAttachmentServiceinstead in plugins, or useAttachmentManagerInternalin core where applicableRetrieve a named attachment from a page- Parameters:
- content- the page the attachment is attached to
- attachmentFileName- the filename of the attachment to retrieve
- version- the version of the attachment to retrieve. If you provide a version of 0 or less, you'll get the most recent version, but you should probably use #getAttachment(AbstractPage, String) instead for that purpose instead
- Returns:
- the requested attachment, or null if the requested attachment does not exist.
 
- 
getAttachment@Deprecated @Transactional(readOnly=true) Attachment getAttachment(ContentEntityObject content, String attachmentFileName) Deprecated.since 7.5.0, useAttachmentServiceinstead in plugins, or useAttachmentManagerInternalin core where applicableGet the most recent version of an attachment with a given name for a particular page- Parameters:
- content- the page the attachment is attached to
- attachmentFileName- the filename of the attachment to be retrieved
- Returns:
- the appropriate attachment, or null if no such attachment exists
 
- 
getAttachmentDownloadPath@Transactional(readOnly=true) String getAttachmentDownloadPath(ContentEntityObject content, String attachmentFileName) Get the download path for the most recent version of an attachment with the given name for some content- Parameters:
- content- the content the attachment is attached to
- attachmentFileName- the filename of the attachment to be retrieved
- Returns:
- the appropriate attachment download path, or null if no such attachment exists
- Since:
- 4.3
 
- 
saveAttachmentvoid saveAttachment(Attachment attachment, @Nullable Attachment previousVersion, InputStream attachmentData, SaveContext saveContext) throws IOException Saves an Attachment and its data, taking aSaveContextto allow more useful event handling.- Parameters:
- attachment- the modified version of the Attachment
- previousVersion- the original version of the Attachment (null if new)
- attachmentData- an InputStream representing the data of the Attachment
- saveContext- provides more information about the circumstances of the save
- Throws:
- IOException
- IllegalArgumentException- if attachment's content is not set
 
- 
saveAttachmentvoid saveAttachment(Attachment attachment, @Nullable Attachment previousVersion, InputStream attachmentData) throws IOException Saves an Attachment and its data- Parameters:
- attachment- the modified version of the Attachment
- previousVersion- the original version of the Attachment (null if new)
- attachmentData- an InputStream representing the data of the Attachment
- Throws:
- IOException
- IllegalArgumentException- if attachment's content is not set
 
- 
saveAttachmentsvoid saveAttachments(List<SavableAttachment> savableAttachments, SaveContext saveContext) throws IOException Saves multiple attachment and their data- Parameters:
- savableAttachments- the modified version of the Attachment
- saveContext- provides more details about saving. If in doubt pass- DefaultSaveContext.DEFAULT.
- Throws:
- IOException
- IllegalArgumentException- if attachment's content is not set
 
- 
saveAttachmentsSaves multiple attachment and their data- Parameters:
- savableAttachments- the modified version of the Attachment
- Throws:
- IOException
- IllegalArgumentException- if attachment's content is not set
 
- 
setAttachmentDatavoid setAttachmentData(Attachment attachment, InputStream attachmentData) throws AttachmentDataExistsException Set the data belonging to attachmentThis method can be used when there is missing data for an Attachment (e.g. during imports) and the data needs to be set manually. - Parameters:
- attachment- Attachment the data belongs to
- attachmentData- the data to be saved
- Throws:
- AttachmentDataExistsException- if data for attachment already exists
 
- 
getAllVersionsGet all versions of an attachment, starting with the current version
- 
getPreviousVersionsGet all non-current versions of an attachment, not including the current version. (ordered from most recent)- Parameters:
- attachment- the attachment to get all non-current versions for.
 
- 
getLastAddedVersionsOfRetrieves all the last added versions for each user who has added a version of the attachment That is, if a user has added multiple versions, only the latest added version will be added to the list returned. Result will be sorted with the earliest version coming first.- Parameters:
- attachment- attachment (must be the latest version)
- Returns:
- the last added versions for each user who has added a version of the attachment
- Throws:
- IllegalArgumentException- if the attachment is not the latest version or null
 
- 
getBackingStorageTypeReturns the currently active storage type.- Since:
- 4.3
- See Also:
 
- 
findAttachmentForDownloadPathFind anAttachmentfor the givendownloadPath.The path must at least contain the segment produced by Attachment.getDownloadPath(), that is /download/attachments/<contentId>/<fileName> where <contentId> identifies a validContentEntityObjectand <fileName> identifies a validAttachmentattached to thatContentEntityObject.- Parameters:
- downloadPath- the download path identifying an- Attachment.This value is expected to be url encoded, with spaces converted to %20 instead of a '+'
- Returns:
- maybe the attachment if the given download path matches the criteria as described above and the referenced objects are known to the system
- Since:
- 7.0.1
- See Also:
 
- 
getRemappedAttachmentIdsGets a list of remapped attachment IDs. The key is the old ID and the value is the new ID.- Returns:
- A map where the key is the original ID and the value is the new ID.
- Since:
- 5.7.1
 
- 
trashMoves an attachment to the trash.- Parameters:
- attachment- the attachment to be trashed
- Since:
- 5.8
 
- 
restoreRestores an attachment from trash.- Parameters:
- attachment- the attachment to restore
- Since:
- 5.8
 
 
- 
AttachmentServiceinstead in plugins, or useAttachmentManagerInternalin core where applicable