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

cn.herodotus.oss.dialect.minio.service.MinioBucketReplicationService Maven / Gradle / Ivy

The newest version!
/*
 * 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.DeleteBucketReplicationArgs;
import io.minio.GetBucketReplicationArgs;
import io.minio.MinioClient;
import io.minio.SetBucketReplicationArgs;
import io.minio.errors.*;
import io.minio.messages.ReplicationConfiguration;
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: Minio Bucket Replication

* * @author : gengwei.zheng * @date : 2022/6/30 15:55 */ @Service public class MinioBucketReplicationService extends BaseMinioService { private static final Logger log = LoggerFactory.getLogger(MinioBucketPolicyService.class); public MinioBucketReplicationService(MinioClientObjectPool minioClientObjectPool) { super(minioClientObjectPool); } /** * 设置 Bucket 策略 * * @param setBucketReplicationArgs {@link SetBucketReplicationArgs} */ public void setBucketReplication(SetBucketReplicationArgs setBucketReplicationArgs) { String function = "setBucketReplication"; MinioClient minioClient = getClient(); try { minioClient.setBucketReplication(setBucketReplicationArgs); } 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 createBucket.", e); throw new OssXmlParserException(e.getMessage()); } finally { close(minioClient); } } /** * 获取 Bucket 通知配置 * * @param getBucketReplicationArgs {@link GetBucketReplicationArgs} */ public ReplicationConfiguration getBucketReplication(GetBucketReplicationArgs getBucketReplicationArgs) { String function = "getBucketReplication"; MinioClient minioClient = getClient(); try { return minioClient.getBucketReplication(getBucketReplicationArgs); } 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); } } public void deleteBucketReplication(String bucketName) { deleteBucketReplication(DeleteBucketReplicationArgs.builder().bucket(bucketName).build()); } public void deleteBucketReplication(DeleteBucketReplicationArgs deleteBucketReplicationArgs) { String function = "deleteBucketReplication"; MinioClient minioClient = getClient(); try { minioClient.deleteBucketReplication(deleteBucketReplicationArgs); } 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); } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy