com.qcloud.cos.model.PutInstructionFileRequest Maven / Gradle / Ivy
package com.qcloud.cos.model;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;
import com.qcloud.cos.internal.CosServiceRequest;
import com.qcloud.cos.internal.crypto.EncryptionMaterials;
import com.qcloud.cos.internal.crypto.EncryptionMaterialsFactory;
/**
* Used to create a new instruction file, typically used to share an encrypted COS object with
* partners via re-encrypting the CEK of the specified COS object with a partner-specific public
* key.
*/
public class PutInstructionFileRequest extends CosServiceRequest
implements MaterialsDescriptionProvider, EncryptionMaterialsFactory {
/**
* The COS object id of the respective COS object to which this instruction file is used.
*/
private final COSObjectId cosObjectId;
/**
* Material to be used in the instruction file.
*/
private final EncryptionMaterials encryptionMaterials;
/**
* Material description to be stored in the instruction file; applicable only if
* {@link #encryptionMaterials} is not specified.
*/
private final Map matDesc;
/**
* Suffix to be used for the instruction file. If suffix is null, the default suffix will be
* used.
*/
private final String suffix;
/**
* An optional pre-configured access control policy to use for the new object. Ignored in favor
* of accessControlList, if present.
*/
private CannedAccessControlList cannedAcl;
/**
* An optional access control list to apply to the new object. If specified, cannedAcl will be
* ignored.
*/
private AccessControlList accessControlList;
/** The optional redirect location about an object */
private String redirectLocation;
/**
* The optional COS storage class to use when storing the new object. If not specified, the
* default, standard storage class will be used.
*/
private String storageClass;
/**
* @param COSObjectId id of the corresponding cos object.
* @param matDesc material description of the instruction file
* @param suffix suffix of the instruction file to be put
*/
public PutInstructionFileRequest(COSObjectId cosObjectId, Map matDesc,
String suffix) {
if (cosObjectId == null || cosObjectId instanceof InstructionFileId)
throw new IllegalArgumentException("Invalid cos object id");
if (suffix == null || suffix.trim().isEmpty())
throw new IllegalArgumentException("suffix must be specified");
this.cosObjectId = cosObjectId;
@SuppressWarnings("unchecked")
Map md = matDesc == null ? Collections.EMPTY_MAP
: Collections.unmodifiableMap(new HashMap(matDesc));
this.matDesc = md;
this.suffix = suffix;
this.encryptionMaterials = null;
}
/**
* @param cosObjectId id of the corresponding cos object.
* @param encryptionMaterials encryption materials to be used for the instruction file
* @param suffix suffix of the instruction file to be put
*/
public PutInstructionFileRequest(COSObjectId cosObjectId,
EncryptionMaterials encryptionMaterials, String suffix) {
if (cosObjectId == null || cosObjectId instanceof InstructionFileId)
throw new IllegalArgumentException("Invalid cos object id");
if (suffix == null || suffix.trim().isEmpty())
throw new IllegalArgumentException("suffix must be specified");
if (encryptionMaterials == null)
throw new IllegalArgumentException("encryption materials must be specified");
this.cosObjectId = cosObjectId;
this.suffix = suffix;
this.encryptionMaterials = encryptionMaterials;
this.matDesc = null;
}
/**
* Returns the COS object id for which the new instruction file will be created. This is not the
* instruction file id.
*/
public COSObjectId getCOSObjectId() {
return cosObjectId;
}
/**
* Returns the material description for the new instruction file.
*/
@Override
public Map getMaterialsDescription() {
return matDesc == null ? encryptionMaterials.getMaterialsDescription() : matDesc;
}
/**
* Returns the encryption materials if specified; or null if not.
*/
@Override
public EncryptionMaterials getEncryptionMaterials() {
return encryptionMaterials;
}
/**
* Returns the suffix for the new instruction file.
*/
public String getSuffix() {
return suffix;
}
/**
* Gets the optional pre-configured access control policy to use for the new object.
*
* @return The optional pre-configured access control policy to use for the new object.
*
* @see PutObjectRequest#setCannedAcl(CannedAccessControlList)
* @see PutObjectRequest#withCannedAcl(CannedAccessControlList)
*/
public CannedAccessControlList getCannedAcl() {
return cannedAcl;
}
/**
* Sets the optional pre-configured access control policy to use for the new object.
*
* @param cannedAcl The optional pre-configured access control policy to use for the new object.
*
* @see PutObjectRequest#getCannedAcl()
* @see PutObjectRequest#withCannedAcl(CannedAccessControlList)
*/
public void setCannedAcl(CannedAccessControlList cannedAcl) {
this.cannedAcl = cannedAcl;
}
/**
* Sets the optional pre-configured access control policy to use for the new object. Returns
* this {@link PutObjectRequest}, enabling additional method calls to be chained together.
*
* @param cannedAcl The optional pre-configured access control policy to use for the new object.
*
* @return This {@link PutObjectRequest}, enabling additional method calls to be chained
* together.
*
* @see PutObjectRequest#getCannedAcl()
* @see PutObjectRequest#setCannedAcl(CannedAccessControlList)
*/
public PutInstructionFileRequest withCannedAcl(CannedAccessControlList cannedAcl) {
setCannedAcl(cannedAcl);
return this;
}
/**
* Returns the optional access control list for the new object. If specified, cannedAcl will be
* ignored.
*/
public AccessControlList getAccessControlList() {
return accessControlList;
}
/**
* Sets the optional access control list for the new object. If specified, cannedAcl will be
* ignored.
*
* @param accessControlList The access control list for the new object.
*/
public void setAccessControlList(AccessControlList accessControlList) {
this.accessControlList = accessControlList;
}
/**
* Sets the optional access control list for the new object. If specified, cannedAcl will be
* ignored. Returns this {@link PutObjectRequest}, enabling additional method calls to be
* chained together.
*
* @param accessControlList The access control list for the new object.
*/
public PutInstructionFileRequest withAccessControlList(AccessControlList accessControlList) {
setAccessControlList(accessControlList);
return this;
}
/**
* Gets the optional redirect location for the new object.
*/
public String getRedirectLocation() {
return this.redirectLocation;
}
/**
* Sets the optional redirect location for the new object.
*
* @param redirectLocation The redirect location for the new object.
*/
public void setRedirectLocation(String redirectLocation) {
this.redirectLocation = redirectLocation;
}
/**
* Sets the optional redirect location for the new object.Returns this {@link PutObjectRequest},
* enabling additional method calls to be chained together.
*
* @param redirectLocation The redirect location for the new object.
*/
public PutInstructionFileRequest withRedirectLocation(String redirectLocation) {
this.redirectLocation = redirectLocation;
return this;
}
/**
* Gets the optional COS storage class to use when storing the new object. If not specified, the
* default standard storage class is used when storing the object.
*
* For more information on available COS storage classes, see the {@link StorageClass}
* enumeration.
*
*
* @return The COS storage class to use when storing the newly copied object.
*
* @see #setStorageClass(String)
* @see #setStorageClass(StorageClass)
* @see #withStorageClass(StorageClass)
* @see #withStorageClass(String)
*/
public String getStorageClass() {
return storageClass;
}
/**
* Sets the optional COS storage class to use when storing the new object. If not specified, the
* default standard storage class will be used when storing the new object.
*
* For more information on COS storage classes and available values, see the
* {@link StorageClass} enumeration.
*
*
* @param storageClass The storage class to use when storing the new object.
*
* @see #getStorageClass()
* @see #setStorageClass(String)
* @see #withStorageClass(StorageClass)
* @see #withStorageClass(String)
*/
public void setStorageClass(String storageClass) {
this.storageClass = storageClass;
}
/**
* Sets the optional COS storage class to use when storing the new object. Returns this
* {@link PutObjectRequest}, enabling additional method calls to be chained together. If not
* specified, the default standard storage class will be used when storing the object.
*
* For more information on COS storage classes and available values, see the
* {@link StorageClass} enumeration.
*
*
* @param storageClass The storage class to use when storing the new object.
*
* @return This {@link PutObjectRequest}, enabling additional method calls to be chained
* together.
*
* @see #getStorageClass()
* @see #setStorageClass(StorageClass)
* @see #setStorageClass(String)
* @see #withStorageClass(StorageClass)
*/
public PutInstructionFileRequest withStorageClass(String storageClass) {
setStorageClass(storageClass);
return this;
}
/**
* Sets the optional COS storage class to use when storing the new object. If not specified, the
* default standard storage class will be used when storing the object.
*
* For more information on COS storage classes and available values, see the
* {@link StorageClass} enumeration.
*
*
* @param storageClass The storage class to use when storing the new object.
*
* @see #getStorageClass()
* @see #setStorageClass(String)
*/
public void setStorageClass(StorageClass storageClass) {
this.storageClass = storageClass.toString();
}
/**
* Sets the optional COS storage class to use when storing the new object. Returns this
* {@link PutObjectRequest}, enabling additional method calls to be chained together. If not
* specified, the default standard storage class will be used when storing the object.
*
* For more information on COS storage classes and available values, see the
* {@link StorageClass} enumeration.
*
*
* @param storageClass The storage class to use when storing the new object.
*
* @return This {@link PutObjectRequest}, enabling additional method calls to be chained
* together.
*
* @see #getStorageClass()
* @see #setStorageClass(StorageClass)
* @see #setStorageClass(String)
* @see #withStorageClass(String)
*/
public PutInstructionFileRequest withStorageClass(StorageClass storageClass) {
setStorageClass(storageClass);
return this;
}
/**
* Creates and returns a {@link PutObjectRequest} for the instruction file with the specified
* suffix.
*/
public PutObjectRequest createPutObjectRequest(COSObject cosObject) {
if (!cosObject.getBucketName().equals(cosObjectId.getBucket())
|| !cosObject.getKey().equals(cosObjectId.getKey())) {
throw new IllegalArgumentException(
"cosObject passed inconsistent with the instruction file being created");
}
InstructionFileId ifid = cosObjectId.instructionFileId(suffix);
return new PutObjectRequest(ifid.getBucket(), ifid.getKey(), null)
.withRedirectLocation(redirectLocation).withAccessControlList(accessControlList)
.withCannedAcl(cannedAcl).withStorageClass(storageClass)
.withGeneralProgressListener(getGeneralProgressListener());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy