Skip to content

Latest commit

 

History

History
189 lines (150 loc) · 8.25 KB

trash.md

File metadata and controls

189 lines (150 loc) · 8.25 KB

Trash

Under normal circumstances, when an item in Box is deleted, it is not actually erased immediately. Instead, it is moved to the Trash. The Trash allows you to recover files and folders that have been deleted. By default, items in the Trash will be purged after 30 days.

Get Trashed Items

The BoxTrash implements Iterable<BoxItem.Info>, so to get the collection of items currently in the trash, simply iterate over it.

BoxTrash trash = new BoxTrash(api);
for (BoxItem.Info itemInfo : trash) {
  // Process the item
}

Alternatively you can specify sort order, limit, use marker based pagination or specify which fields you want to extract with BoxTrash#items.

To use sorting you have to use offset based pagination:

BoxTrash trash = new BoxTrash(api);
Iterable<BoxItem.Info> trashEntries = trash.items(
  SortParameters.ascending("name"),
  PagingParameters.offset(0, 500)
);
for (BoxItem.Info trashEntry : trashEntries) {
  // Process the item
}

If you have a lot of items in trash and offset value is in tens of thousands it is better to use marker based pagination. However, marker based pagination cannot be used with sorting. To disable sorting use SortParameters.none():

BoxTrash trash = new BoxTrash(api);
Iterable<BoxItem.Info> trashEntries = trash.items(
  SortParameters.none(),
  PagingParameters.marker(500)
);
for (BoxItem.Info trashEntry : trashEntries) {
  // Process the item
}

Get Trashed File Information

Ordinarily, trying to call getInfo() on a file that is in the trash will return a 404 error. To get the information of a file in the trash, you must instead call BoxTrash#getFileInfo(String fileID) with the ID of the trashed file. You can optionally pass a specific list of fields to retrieve to getFileInfo(String fileID, String... fields), which will return only the specified fields to reduce payload size.

String fileID = "9873459";
BoxTrash trash = new BoxTrash(api);
BoxFile.Info fileInfo = trash.getFileInfo(fileID);

Get Trashed Folder Information

Ordinarily, trying to call [getInfo()][folder-get-info] on a folder that is in the trash will return a 404 error. To get the information of a folder in the trash, you must instead call BoxTrash#getFolderInfo(String fileID) with the ID of the trashed folder. You can optionally pass a specific list of fields to retrieve to getFileInfo(String folderID, String... fields), which will return only the specified fields to reduce payload size.

String folderID = "2345343";
BoxTrash trash = new BoxTrash(api);
BoxFolder.Info folderInfo = trash.getFolderInfo(folderInfo);

Permanently Delete File From Trash

To delete a file from the trash, call BoxTrash#deleteFile(String fileID) with the ID of the file to delete.

Note: This will permanently delete the file, and cannot be undone.

String fileID = "87398";
BoxTrash trash = new BoxTrash(api);
trash.deleteFile(fileID);

Permanently Delete Folder From Trash

To delete a folder from the trash, call BoxTrash#deleteFolder(String fileID) with the ID of the folder to delete.

Note: This will permanently delete the folder, and cannot be undone.

String folder = "123456";
BoxTrash trash = new BoxTrash(api);
trash.deleteFolder(folderID);

Restore a File from the Trash

To restore a file from the trash, effectively undeleting it, call BoxTrash#restoreFile(String fileID) with the ID of the file. To avoid scenarios where the parent folder that previously contained the file is no longer available, the user does not have permission to create items in that folder, or that folder has an item with the same name as the one being restored; you can pass a new parent folder ID and/or file name to BoxTrash#restoreFile(String fileID, String newName, String newParentID). The new name and parent will only be used if a conflict is encountered while trying to restore the file to its original location.

String fileID = "125367";
String newName = "Presentation 2018 ORIGINAL.pptx";
String newParentID = "98765";

BoxTrash trash = new BoxTrash(api);
// Avoid conflicts at the original location
trash.restoreFile(fileID, newName, newParentID);

Restore a Folder from the Trash

To restore a folder from the trash, effectively undeleting it, call BoxTrash#restoreFolder(String folderID) with the ID of the folder. To avoid scenarios where the parent folder that previously contained the folder to be restored is no longer available, the user does not have permission to create items in that folder, or that folder has an item with the same name as the one being restored; you can pass a new parent folder ID and/or folder name to BoxTrash#restoreFolder(String folderID, String newName, String newParentID). The new name and parent will only be used if a conflict is encountered while trying to restore the folder to its original location.

String folderID = "125367";
String newName = "My Documents ORIGINAL";
String newParentID = "98765";

BoxTrash trash = new BoxTrash(api);
// Avoid conflicts at the original location
trash.restoreFolder(folderID, newName, newParentID);