cn.herodotus.oss.dialect.minio.service.MinioBucketVersioningService Maven / Gradle / Ivy
/*
* Copyright (c) 2020-2030 码匠君
*
* Dante Cloud 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
*
*
*
* 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.
*
* Dante OSS 采用APACHE LICENSE 2.0开源协议,您在使用过程中,需要注意以下几点:
*
* 1.请不要删除和修改根目录下的LICENSE文件。
* 2.请不要删除和修改 Dante Cloud 源码头部的版权声明。
* 3.请保留源码和相关描述文件的项目出处,作者声明等。
* 4.分发源码时候,请注明软件出处
* 5.在修改包名,模块名称,项目代码等时,请注明软件出处
* 6.若您的项目无法满足以上几点,可申请商业授权
*/
package cn.herodotus.oss.dialect.minio.service;
import cn.herodotus.oss.dialect.core.exception.*;
import cn.herodotus.oss.dialect.minio.definition.pool.MinioClientObjectPool;
import cn.herodotus.oss.dialect.minio.definition.service.BaseMinioService;
import io.minio.GetBucketVersioningArgs;
import io.minio.MinioClient;
import io.minio.SetBucketVersioningArgs;
import io.minio.errors.*;
import io.minio.messages.VersioningConfiguration;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Service;
import java.io.IOException;
import java.net.ConnectException;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
/**
* Description: Bucket 版本控制
*
* 若开启了多版本控制,上传对象时,OBS自动为每个对象创建唯一的版本号。上传同名的对象将以不同的版本号同时保存在OBS中。
*
* 若未开启多版本控制,向同一个文件夹中上传同名的对象时,新上传的对象将覆盖原有的对象。
*
* 某些功能(例如版本控制、对象锁定和存储桶复制)需要使用擦除编码分布式部署 MinIO。开启了版本控制后,允许在同一密钥下保留同一对象的多个版本。
*
* @author : gengwei.zheng
* @date : 2022/6/30 16:01
*/
@Service
public class MinioBucketVersioningService extends BaseMinioService {
private static final Logger log = LoggerFactory.getLogger(MinioBucketVersioningService.class);
public MinioBucketVersioningService(MinioClientObjectPool minioClientObjectPool) {
super(minioClientObjectPool);
}
/**
* 开启 Bucket 版本控制
*
* @param bucketName bucketName
*/
public void enabledBucketVersioning(String bucketName) {
setBucketVersioning(bucketName, VersioningConfiguration.Status.ENABLED);
}
/**
* 开启 Bucket 版本控制
*
* @param bucketName bucketName
* @param region region
*/
public void enabledBucketVersioning(String bucketName, String region) {
setBucketVersioning(bucketName, region, VersioningConfiguration.Status.ENABLED);
}
/**
* 暂停 Bucket 版本控制
*
* @param bucketName bucketName
*/
public void suspendedBucketVersioning(String bucketName) {
setBucketVersioning(bucketName, VersioningConfiguration.Status.SUSPENDED);
}
/**
* 暂停 Bucket 版本控制
*
* @param bucketName bucketName
* @param region region
*/
public void suspendedBucketVersioning(String bucketName, String region) {
setBucketVersioning(bucketName, region, VersioningConfiguration.Status.SUSPENDED);
}
/**
* 关闭 Bucket 版本控制
*
* @param bucketName bucketName
*/
public void offBucketVersioning(String bucketName) {
setBucketVersioning(bucketName, VersioningConfiguration.Status.OFF);
}
/**
* 关闭 Bucket 版本控制
*
* @param bucketName bucketName
* @param region region
*/
public void offBucketVersioning(String bucketName, String region) {
setBucketVersioning(bucketName, region, VersioningConfiguration.Status.OFF);
}
/**
* 设置 Bucket 版本控制
*
* @param bucketName bucketName
* @param status {@link VersioningConfiguration.Status}
*/
public void setBucketVersioning(String bucketName, VersioningConfiguration.Status status) {
setBucketVersioning(bucketName, status, null);
}
/**
* 设置 Bucket 版本控制
*
* @param bucketName bucketName
* @param status {@link VersioningConfiguration.Status}
* @param mfaDelete mfaDelete
*/
public void setBucketVersioning(String bucketName, VersioningConfiguration.Status status, Boolean mfaDelete) {
setBucketVersioning(bucketName, new VersioningConfiguration(status, mfaDelete));
}
/**
* 设置 Bucket 版本控制
*
* @param bucketName bucketName
* @param versioningConfiguration {@link VersioningConfiguration}
*/
public void setBucketVersioning(String bucketName, VersioningConfiguration versioningConfiguration) {
setBucketVersioning(SetBucketVersioningArgs.builder().bucket(bucketName).config(versioningConfiguration).build());
}
/**
* 设置 Bucket 版本控制
*
* @param bucketName bucketName
* @param region region
* @param status {@link VersioningConfiguration.Status}
*/
public void setBucketVersioning(String bucketName, String region, VersioningConfiguration.Status status) {
setBucketVersioning(bucketName, region, status, null);
}
/**
* 设置 Bucket 版本控制
*
* @param bucketName bucketName
* @param region region
* @param status {@link VersioningConfiguration.Status}
* @param mfaDelete mfaDelete
*/
public void setBucketVersioning(String bucketName, String region, VersioningConfiguration.Status status, Boolean mfaDelete) {
setBucketVersioning(bucketName, region, new VersioningConfiguration(status, mfaDelete));
}
/**
* 设置 Bucket 版本控制
*
* @param bucketName bucketName
* @param region region
* @param versioningConfiguration {@link VersioningConfiguration}
*/
public void setBucketVersioning(String bucketName, String region, VersioningConfiguration versioningConfiguration) {
setBucketVersioning(SetBucketVersioningArgs.builder().bucket(bucketName).region(region).config(versioningConfiguration).build());
}
/**
* 设置 Bucket 版本控制
*
* @param setBucketVersioningArgs {@link SetBucketVersioningArgs}
*/
public void setBucketVersioning(SetBucketVersioningArgs setBucketVersioningArgs) {
String function = "setBucketVersioning";
MinioClient minioClient = getClient();
try {
minioClient.setBucketVersioning(setBucketVersioningArgs);
} catch (ErrorResponseException e) {
log.error("[Herodotus] |- Minio catch ErrorResponseException in [{}].", function, e);
throw new OssErrorResponseException(e.getMessage());
} catch (InsufficientDataException e) {
log.error("[Herodotus] |- Minio catch InsufficientDataException in [{}].", function, e);
throw new OssInsufficientDataException(e.getMessage());
} catch (InternalException e) {
log.error("[Herodotus] |- Minio catch InternalException in [{}].", function, e);
throw new OssInternalException(e.getMessage());
} catch (InvalidKeyException e) {
log.error("[Herodotus] |- Minio catch InvalidKeyException in [{}].", function, e);
throw new OssInvalidKeyException(e.getMessage());
} catch (InvalidResponseException e) {
log.error("[Herodotus] |- Minio catch InvalidResponseException in [{}].", function, e);
throw new OssInvalidResponseException(e.getMessage());
} catch (IOException e) {
log.error("[Herodotus] |- Minio catch IOException in [{}].", function, e);
if (e instanceof ConnectException) {
throw new OssConnectException(e.getMessage());
} else {
throw new OssIOException(e.getMessage());
}
} catch (NoSuchAlgorithmException e) {
log.error("[Herodotus] |- Minio catch NoSuchAlgorithmException in [{}].", function, e);
throw new OssNoSuchAlgorithmException(e.getMessage());
} catch (ServerException e) {
log.error("[Herodotus] |- Minio catch ServerException in [{}].", function, e);
throw new OssServerException(e.getMessage());
} catch (XmlParserException e) {
log.error("[Herodotus] |- Minio catch XmlParserException in [{}].", function, e);
throw new OssXmlParserException(e.getMessage());
} finally {
close(minioClient);
}
}
/**
* 获取 Bucket 版本配置
*
* @param bucketName bucketName
* @return {@link VersioningConfiguration}
*/
public VersioningConfiguration getBucketVersioning(String bucketName) {
return getBucketVersioning(GetBucketVersioningArgs.builder().bucket(bucketName).build());
}
/**
* 获取 Bucket 版本配置
*
* @param bucketName bucketName
* @param region region
* @return {@link VersioningConfiguration}
*/
public VersioningConfiguration getBucketVersioning(String bucketName, String region) {
return getBucketVersioning(GetBucketVersioningArgs.builder().bucket(bucketName).region(region).build());
}
/**
* 获取 Bucket 版本配置
*
* @param getBucketVersioningArgs {@link GetBucketVersioningArgs}
* @return {@link VersioningConfiguration}
*/
public VersioningConfiguration getBucketVersioning(GetBucketVersioningArgs getBucketVersioningArgs) {
String function = "getBucketVersioning";
MinioClient minioClient = getClient();
try {
return minioClient.getBucketVersioning(getBucketVersioningArgs);
} catch (ErrorResponseException e) {
log.error("[Herodotus] |- Minio catch ErrorResponseException in [{}].", function, e);
throw new OssErrorResponseException(e.getMessage());
} catch (InsufficientDataException e) {
log.error("[Herodotus] |- Minio catch InsufficientDataException in [{}].", function, e);
throw new OssInsufficientDataException(e.getMessage());
} catch (InternalException e) {
log.error("[Herodotus] |- Minio catch InternalException in [{}].", function, e);
throw new OssInternalException(e.getMessage());
} catch (InvalidKeyException e) {
log.error("[Herodotus] |- Minio catch InvalidKeyException in [{}].", function, e);
throw new OssInvalidKeyException(e.getMessage());
} catch (InvalidResponseException e) {
log.error("[Herodotus] |- Minio catch InvalidResponseException in [{}].", function, e);
throw new OssInvalidResponseException(e.getMessage());
} catch (IOException e) {
log.error("[Herodotus] |- Minio catch IOException in [{}].", function, e);
if (e instanceof ConnectException) {
throw new OssConnectException(e.getMessage());
} else {
throw new OssIOException(e.getMessage());
}
} catch (NoSuchAlgorithmException e) {
log.error("[Herodotus] |- Minio catch NoSuchAlgorithmException in [{}].", function, e);
throw new OssNoSuchAlgorithmException(e.getMessage());
} catch (ServerException e) {
log.error("[Herodotus] |- Minio catch ServerException in [{}].", function, e);
throw new OssServerException(e.getMessage());
} catch (XmlParserException e) {
log.error("[Herodotus] |- Minio catch XmlParserException [{}].", function, e);
throw new OssXmlParserException(e.getMessage());
} finally {
close(minioClient);
}
}
}