123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127 |
- package minio
- import (
- "context"
- "net/http"
- "net/url"
- "github.com/minio/minio-go/v7/pkg/s3utils"
- )
- func (c Client) BucketExists(ctx context.Context, bucketName string) (bool, error) {
-
- if err := s3utils.CheckValidBucketName(bucketName); err != nil {
- return false, err
- }
-
- resp, err := c.executeMethod(ctx, http.MethodHead, requestMetadata{
- bucketName: bucketName,
- contentSHA256Hex: emptySHA256Hex,
- })
- defer closeResponse(resp)
- if err != nil {
- if ToErrorResponse(err).Code == "NoSuchBucket" {
- return false, nil
- }
- return false, err
- }
- if resp != nil {
- resperr := httpRespToErrorResponse(resp, bucketName, "")
- if ToErrorResponse(resperr).Code == "NoSuchBucket" {
- return false, nil
- }
- if resp.StatusCode != http.StatusOK {
- return false, httpRespToErrorResponse(resp, bucketName, "")
- }
- }
- return true, nil
- }
- func (c Client) StatObject(ctx context.Context, bucketName, objectName string, opts StatObjectOptions) (ObjectInfo, error) {
-
- if err := s3utils.CheckValidBucketName(bucketName); err != nil {
- return ObjectInfo{}, err
- }
- if err := s3utils.CheckValidObjectName(objectName); err != nil {
- return ObjectInfo{}, err
- }
- return c.statObject(ctx, bucketName, objectName, opts)
- }
- func (c Client) statObject(ctx context.Context, bucketName, objectName string, opts StatObjectOptions) (ObjectInfo, error) {
-
- if err := s3utils.CheckValidBucketName(bucketName); err != nil {
- return ObjectInfo{}, err
- }
- if err := s3utils.CheckValidObjectName(objectName); err != nil {
- return ObjectInfo{}, err
- }
- headers := opts.Header()
- if opts.Internal.ReplicationDeleteMarker {
- headers.Set(minIOBucketReplicationDeleteMarker, "true")
- }
- urlValues := make(url.Values)
- if opts.VersionID != "" {
- urlValues.Set("versionId", opts.VersionID)
- }
-
- resp, err := c.executeMethod(ctx, http.MethodHead, requestMetadata{
- bucketName: bucketName,
- objectName: objectName,
- queryValues: urlValues,
- contentSHA256Hex: emptySHA256Hex,
- customHeader: headers,
- })
- defer closeResponse(resp)
- if err != nil {
- return ObjectInfo{}, err
- }
- if resp != nil {
- deleteMarker := resp.Header.Get(amzDeleteMarker) == "true"
- if resp.StatusCode != http.StatusOK && resp.StatusCode != http.StatusPartialContent {
- if resp.StatusCode == http.StatusMethodNotAllowed && opts.VersionID != "" && deleteMarker {
- errResp := ErrorResponse{
- StatusCode: resp.StatusCode,
- Code: "MethodNotAllowed",
- Message: "The specified method is not allowed against this resource.",
- BucketName: bucketName,
- Key: objectName,
- }
- return ObjectInfo{
- VersionID: resp.Header.Get(amzVersionID),
- IsDeleteMarker: deleteMarker,
- }, errResp
- }
- return ObjectInfo{
- VersionID: resp.Header.Get(amzVersionID),
- IsDeleteMarker: deleteMarker,
- }, httpRespToErrorResponse(resp, bucketName, objectName)
- }
- }
- return ToObjectInfo(bucketName, objectName, resp.Header)
- }
|