Skip to content

Latest commit

 

History

History
182 lines (137 loc) · 8.05 KB

legal_holds.md

File metadata and controls

182 lines (137 loc) · 8.05 KB

Legal Holds Policy

Legal Hold Policy information describes the basic characteristics of the Policy, such as name, description, and filter dates.

Get Legal Hold Policy

Calling getInfo(String...) will return a BoxLegalHoldPolicy.Info object containing information about the legal hold policy. If necessary to retrieve limited set of fields, it is possible to specify them using param.

BoxLegalHoldPolicy policy = new BoxLegalHoldPolicy(api, id);
BoxLegalHoldPolicy.Info policyInfo = policy.getInfo();

Get List of Legal Hold Policies

Calling the static getAll(BoxAPIConnection) will return an iterable that will page through all of the legal hold policies. It is possible to specify name of legal hold policy, maximum number of items per response and fields to retrieve by calling the static getAll(BoxAPIConnection, String, int, String...) method.

Iterable<BoxLegalHoldPolicy.Info> policies = BoxLegalHoldPolicy.getAll(api);
for (BoxLegalHoldPolicy.Info policyInfo : policies) {
    // Do something with the legal hold policy.
}

Create New Legal Hold Policy

The static create(BoxAPIConnection, String) method will let you create a new legal hold policy with a specified name. The static [create(BoxAPIConnection, String, String, Date, Date)][create-new- legal-hold-policy-with-dates] method will let you create a new legal hold policy with a specified name, description, start and end dates.

BoxLegalHoldPolicy.Info policyInfo = BoxLegalHoldPolicy.create(api, name, description, startedAt, endedAt);

Update Existing Legal Hold Policy

Updating a legal hold policy's information is done by calling updateInfo(BoxLegalHoldPolicy.Info).

BoxLegalHoldPolicy policy = new BoxLegalHoldPolicy(api, id);
BoxLegalHoldPolicy.Info policyInfo = policy.new Info();
info.addPendingChange("description", "new description");
policy.updateInfo(info);

Delete Legal Hold Policy

A legal hold policy can be deleted by calling the delete() method.

BoxLegalHoldPolicy policy = new BoxLegalHoldPolicy(api, id);
policy.delete();

Get Assignment

Calling getInfo(String...) will return a BoxLegalHoldAssignment.Info object containing information about the legal hold policy assignment.

BoxLegalHoldAssignment assignment = new BoxLegalHoldAssignment(api, id);
BoxLegalHoldAssignment.Info info = assignment.getInfo("assigned_by");

Get List of Assignments

Calling the static getAssignments(String...) will return an iterable that will page through all of the assignments of the legal hold policy. It is possible to specify filters for type and id, maximum number of items per single response and fields to retrieve by calling getAssignments(String, String, int, String...).

BoxLegalHoldPolicy policy = new BoxLegalHoldPolicy(api, id);
Iterable<BoxLegalHoldAssignment.Info> assignments = policy.getAssignments(BoxResource.getResourceType(BoxFolder.class), null, 50, "assigned_at");
for (BoxLegalHoldAssignment.Info assignmentInfo : assignments) {
	// Do something with the legal hold policy assignment.
}

Create New Assignment

To create new legal hold policy assignment call assignTo(BoxResource) method. Currently only BoxFile, BoxFileVersion, BoxFolder and BoxUser objects are supported as a parameter.

BoxLegalHoldPolicy policy = new BoxLegalHoldPolicy(api, policyID);
BoxFolder folder = new BoxFolder(api, folderID);
policy.assignTo(folder);

Delete Assignment

A legal hold policy assignment can be deleted by calling the delete() method of BoxLegalHoldAssignment object.

BoxLegalHoldAssignment assignment = new BoxLegalHoldAssignment(api, id);
assignment.delete();

Get File Version Legal Hold

Calling getInfo(String...) will return a BoxFileVersionLegalHold.Info object containing information about the file version legal hold policy.

BoxFileVersionLegalHold hold = new BoxFileVersionLegalHold(api, id);
hold.getInfo("file");

Get List of File Version Legal Holds

To get an iterable with all non-deleted file version legal holds for current legal hold policy, call getFileVersionHolds(String...). It is possible to specify maximum number of items per single response by calling getFileVersionHolds(int, String...).

BoxLegalHoldPolicy policy = new BoxLegalHoldPolicy(api, id);
Iterable<BoxFileVersionLegalHold.Info> fileVersionHolds = policy.getFileVersionHolds();
for (BoxFileVersionLegalHold.Info fileVersionHold : fileVersionHolds) {
	// Do something with the file version legal hold.
}