cn.herodotus.oss.dialect.minio.service.MinioBucketLifecycleService 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.DeleteBucketLifecycleArgs;
import io.minio.GetBucketLifecycleArgs;
import io.minio.MinioClient;
import io.minio.SetBucketLifecycleArgs;
import io.minio.errors.*;
import io.minio.messages.LifecycleConfiguration;
import io.minio.messages.LifecycleRule;
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;
import java.util.List;
/**
* Description: Bucket 生命周期配置服务
*
* 生命周期管理可适用于以下典型场景:
* · 周期性上传的日志文件,可能只需要保留一个星期或一个月。到期后要删除它们。
* · 某些文档在一段时间内经常访问,但是超过一定时间后便可能不再访问了。这些文档需要在一定时间后转化为低频访问存储,归档存储或者删除
*
* @author : gengwei.zheng
* @date : 2022/6/30 15:39
*/
@Service
public class MinioBucketLifecycleService extends BaseMinioService {
private static final Logger log = LoggerFactory.getLogger(MinioBucketLifecycleService.class);
public MinioBucketLifecycleService(MinioClientObjectPool minioClientObjectPool) {
super(minioClientObjectPool);
}
/**
* 设置 Bucket 生命周期配置
*
* @param bucketName bucketName
* @param lifecycleRules {@link LifecycleRule}
*/
public void setBucketLifecycle(String bucketName, List lifecycleRules) {
setBucketLifecycle(bucketName, new LifecycleConfiguration(lifecycleRules));
}
/**
* 置 Bucket 生命周期配置
*
* @param bucketName bucketName
* @param region region
* @param lifecycleRules {@link LifecycleRule}
*/
public void setBucketLifecycle(String bucketName, String region, List lifecycleRules) {
setBucketLifecycle(bucketName, region, new LifecycleConfiguration(lifecycleRules));
}
/**
* 设置 Bucket 生命周期
*
* @param bucketName bucketName
* @param lifecycleConfiguration {@link LifecycleConfiguration}
*/
public void setBucketLifecycle(String bucketName, LifecycleConfiguration lifecycleConfiguration) {
setBucketLifecycle(SetBucketLifecycleArgs.builder().bucket(bucketName).config(lifecycleConfiguration).build());
}
/**
* 设置 Bucket 生命周期
*
* @param bucketName bucketName
* @param region region
* @param lifecycleConfiguration @link LifecycleConfiguration}
*/
public void setBucketLifecycle(String bucketName, String region, LifecycleConfiguration lifecycleConfiguration) {
setBucketLifecycle(SetBucketLifecycleArgs.builder().bucket(bucketName).region(region).config(lifecycleConfiguration).build());
}
/**
* 设置 Bucket 生命周期
*
* @param setBucketLifecycleArgs {@link SetBucketLifecycleArgs}
*/
public void setBucketLifecycle(SetBucketLifecycleArgs setBucketLifecycleArgs) {
String function = "setBucketLifecycle";
MinioClient minioClient = getClient();
try {
minioClient.setBucketLifecycle(setBucketLifecycleArgs);
} 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 LifecycleConfiguration}
*/
public LifecycleConfiguration getBucketLifecycle(String bucketName) {
return getBucketLifecycle(GetBucketLifecycleArgs.builder().bucket(bucketName).build());
}
/**
* 获取 Bucket 生命周期配置
*
* @param bucketName bucketName
* @param region region
* @return {@link LifecycleConfiguration}
*/
public LifecycleConfiguration getBucketLifecycle(String bucketName, String region) {
return getBucketLifecycle(GetBucketLifecycleArgs.builder().bucket(bucketName).region(region).build());
}
/**
* 获取 Bucket 生命周期配置
*
* @param getBucketLifecycleArgs {@link GetBucketLifecycleArgs}
*/
public LifecycleConfiguration getBucketLifecycle(GetBucketLifecycleArgs getBucketLifecycleArgs) {
String function = "getBucketLifecycle";
MinioClient minioClient = getClient();
try {
return minioClient.getBucketLifecycle(getBucketLifecycleArgs);
} 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
*/
public void deleteBucketLifecycle(String bucketName) {
deleteBucketLifecycle(DeleteBucketLifecycleArgs.builder().bucket(bucketName).build());
}
/**
* 删除 Bucket 生命周期配置
*
* @param bucketName bucketName
* @param region region
*/
public void deleteBucketLifecycle(String bucketName, String region) {
deleteBucketLifecycle(DeleteBucketLifecycleArgs.builder().bucket(bucketName).region(region).build());
}
/**
* 删除 Bucket 生命周期配置
*
* @param deleteBucketLifecycleArgs {@link DeleteBucketLifecycleArgs}
*/
public void deleteBucketLifecycle(DeleteBucketLifecycleArgs deleteBucketLifecycleArgs) {
String function = "deleteBucketLifecycle";
MinioClient minioClient = getClient();
try {
minioClient.deleteBucketLifecycle(deleteBucketLifecycleArgs);
} 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);
}
}
}