All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.qcloud.cos.model.PutInstructionFileRequest Maven / Gradle / Ivy

/*
 * Copyright 2010-2019 Amazon.com, Inc. or its affiliates. All Rights Reserved.
 *
 * Licensed under the Apache License, Version 2.0 (the "License").
 * You may not use this file except in compliance with the License.
 * A copy of the License is located at
 *
 *  http://aws.amazon.com/apache2.0
 *
 * or in the "license" file accompanying this file. This file is distributed
 * on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
 * express or implied. See the License for the specific language governing
 * permissions and limitations under the License.
 
 * According to cos feature, we modify some class,comment, field name, etc.
 */


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