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

com.obs.services.model.SseCHeader Maven / Gradle / Ivy

/**
 * Copyright 2019 Huawei Technologies Co.,Ltd.
 * Licensed under the Apache License, Version 2.0 (the "License"); you may not use
 * this file except in compliance with the License.  You may obtain a copy of the
 * License at
 * 
 * http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software distributed
 * under the License 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.
 */

package com.obs.services.model;

import java.nio.charset.StandardCharsets;
import java.util.Arrays;

/**
 * SSE-C encryption/decryption headers
 */
public class SseCHeader {

    private ServerAlgorithm algorithm;

    private SSEAlgorithmEnum sseAlgorithm = SSEAlgorithmEnum.AES256;

    private byte[] sseCKey;

    private String sseCKeyBase64;

    /**
     * Obtain the encryption algorithm type. Only AES256 is supported. This
     * parameter must be used together with "sseCKey."
     * 
     * @return Encryption algorithm type
     */
    @Deprecated
    public ServerAlgorithm getAlgorithm() {
        return algorithm;
    }

    /**
     * Set the encryption algorithm type. Only AES256 is supported. This
     * parameter must be used together with "sseCKey."
     * 
     * @param algorithm
     *            Encryption algorithm type
     */
    @Deprecated
    public void setAlgorithm(ServerAlgorithm algorithm) {
        this.algorithm = algorithm;
    }

    /**
     * Obtain the encryption algorithm type. Only AES256 is supported. This
     * parameter must be used together with "sseCKey".
     * 
     * @return Encryption algorithm type
     */
    public SSEAlgorithmEnum getSSEAlgorithm() {
        return sseAlgorithm;
    }

    /**
     * Obtain the key used in the SSE-C mode. The key is used to encrypt and
     * decrypt an object. The value is not encoded using Base64.
     * 
     * @return Key used in the SSE-C mode
     */
    public byte[] getSseCKey() {
        if (null != this.sseCKey) {
            return this.sseCKey.clone(); 
        }
        return new byte[0];
    }

    /**
     * Set the key used in the SSE-C mode. The key is used to encrypt and
     * decrypt an object. The value is not encoded using Base64.
     * 
     * @param sseCKey
     *            Key used in the SSE-C mode. The key is used to encrypt and
     *            decrypt an object.
     */
    @Deprecated
    public void setSseCKey(String sseCKey) {
        if (sseCKey != null) {
            this.sseCKey = sseCKey.getBytes(StandardCharsets.ISO_8859_1);
        }
    }

    /**
     * Set the key used in the SSE-C mode. The key is used to encrypt and
     * decrypt an object. The value is not encoded using Base64.
     * 
     * @param sseCKey
     *            Key used in the SSE-C mode. The key is used to encrypt and
     *            decrypt an object.
     */
    public void setSseCKey(byte[] sseCKey) {
        if (null != sseCKey) {
            this.sseCKey = sseCKey.clone();
        } else {
            this.sseCKey = null;
        }
    }

    /**
     * Obtain the key used in the SSE-C mode. The key is used to encrypt and
     * decrypt an object. The value is a Base64-encoded value.
     * 
     * @return Key used in the SSE-C mode
     */
    public String getSseCKeyBase64() {
        return sseCKeyBase64;
    }

    /**
     * Set the key used in the SSE-C mode. The key is used to encrypt and
     * decrypt an object. The value is a Base64-encoded value.
     * 
     * @param sseCKeyBase64
     *            Key used in the SSE-C mode. The key is used to encrypt and
     *            decrypt an object.
     */
    public void setSseCKeyBase64(String sseCKeyBase64) {
        this.sseCKeyBase64 = sseCKeyBase64;
    }

    @Override
    public String toString() {
        return "SseCHeader [algorithm=" + algorithm + ", sseCKey=" + Arrays.toString(sseCKey) + ", sseCKeyBase64="
                + sseCKeyBase64 + "]";
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy