GoToSocial/vendor/github.com/minio/minio-go/v7
Dominik Süß 9d0df426da
[feature] S3 support (#674)
* feat: vendor minio client

* feat: introduce storage package with s3 support

* feat: serve s3 files directly

this saves a lot of bandwith as the files are fetched from the object
store directly

* fix: use explicit local storage in tests

* feat: integrate s3 storage with the main server

* fix: add s3 config to cli tests

* docs: explicitly set values in example config

also adds license header to the storage package

* fix: use better http status code on s3 redirect

HTTP 302 Found is the best fit, as it signifies that the resource
requested was found but not under its presumed URL

307/TemporaryRedirect would mean that this resource is usually located
here, not in this case

303/SeeOther indicates that the redirection does not link to the
requested resource but to another page

* refactor: use context in storage driver interface
2022-07-03 12:08:30 +02:00
..
pkg [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
.gitignore [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
.golangci.yml [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-bucket-encryption.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-bucket-lifecycle.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-bucket-notification.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-bucket-policy.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-bucket-replication.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-bucket-tagging.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-bucket-versioning.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-compose-object.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-copy-object.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-datatypes.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-error-response.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-get-object-acl.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-get-object-file.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-get-object.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-get-options.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-list.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-object-legal-hold.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-object-lock.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-object-retention.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-object-tagging.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-presigned.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-put-bucket.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-put-object-common.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-put-object-file-context.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-put-object-multipart.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-put-object-streaming.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-put-object.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-putobject-snowball.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-remove.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-restore.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-s3-datatypes.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-select.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api-stat.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
api.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
bucket-cache.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
CNAME [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
code_of_conduct.md [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
constants.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
CONTRIBUTING.md [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
core.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
functional_tests.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
hook-reader.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
LICENSE [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
MAINTAINERS.md [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
Makefile [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
NOTICE [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
post-policy.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
README_zh_CN.md [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
README.md [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
retry-continous.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
retry.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
s3-endpoints.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
s3-error.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
transport.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00
utils.go [feature] S3 support (#674) 2022-07-03 12:08:30 +02:00

MinIO Go Client SDK for Amazon S3 Compatible Cloud Storage Slack Sourcegraph Apache V2 License

The MinIO Go Client SDK provides simple APIs to access any Amazon S3 compatible object storage.

This quickstart guide will show you how to install the MinIO client SDK, connect to MinIO, and provide a walkthrough for a simple file uploader. For a complete list of APIs and examples, please take a look at the Go Client API Reference.

This document assumes that you have a working Go development environment.

Download from Github

go get github.com/minio/minio-go/v7

Initialize MinIO Client

MinIO client requires the following four parameters specified to connect to an Amazon S3 compatible object storage.

Parameter Description
endpoint URL to object storage service.
minio.Options All the options such as credentials, custom transport etc.
package main

import (
	"log"

	"github.com/minio/minio-go/v7"
	"github.com/minio/minio-go/v7/pkg/credentials"
)

func main() {
	endpoint := "play.min.io"
	accessKeyID := "Q3AM3UQ867SPQQA43P2F"
	secretAccessKey := "zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG"
	useSSL := true

	// Initialize minio client object.
	minioClient, err := minio.New(endpoint, &minio.Options{
		Creds:  credentials.NewStaticV4(accessKeyID, secretAccessKey, ""),
		Secure: useSSL,
	})
	if err != nil {
		log.Fatalln(err)
	}

	log.Printf("%#v\n", minioClient) // minioClient is now set up
}

Quick Start Example - File Uploader

This example program connects to an object storage server, creates a bucket and uploads a file to the bucket.

We will use the MinIO server running at https://play.min.io in this example. Feel free to use this service for testing and development. Access credentials shown in this example are open to the public.

FileUploader.go

package main

import (
	"context"
	"log"

	"github.com/minio/minio-go/v7"
	"github.com/minio/minio-go/v7/pkg/credentials"
)

func main() {
	ctx := context.Background()
	endpoint := "play.min.io"
	accessKeyID := "Q3AM3UQ867SPQQA43P2F"
	secretAccessKey := "zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG"
	useSSL := true

	// Initialize minio client object.
	minioClient, err := minio.New(endpoint, &minio.Options{
		Creds:  credentials.NewStaticV4(accessKeyID, secretAccessKey, ""),
		Secure: useSSL,
	})
	if err != nil {
		log.Fatalln(err)
	}

	// Make a new bucket called mymusic.
	bucketName := "mymusic"
	location := "us-east-1"

	err = minioClient.MakeBucket(ctx, bucketName, minio.MakeBucketOptions{Region: location})
	if err != nil {
		// Check to see if we already own this bucket (which happens if you run this twice)
		exists, errBucketExists := minioClient.BucketExists(ctx, bucketName)
		if errBucketExists == nil && exists {
			log.Printf("We already own %s\n", bucketName)
		} else {
			log.Fatalln(err)
		}
	} else {
		log.Printf("Successfully created %s\n", bucketName)
	}

	// Upload the zip file
	objectName := "golden-oldies.zip"
	filePath := "/tmp/golden-oldies.zip"
	contentType := "application/zip"

	// Upload the zip file with FPutObject
	info, err := minioClient.FPutObject(ctx, bucketName, objectName, filePath, minio.PutObjectOptions{ContentType: contentType})
	if err != nil {
		log.Fatalln(err)
	}

	log.Printf("Successfully uploaded %s of size %d\n", objectName, info.Size)
}

Run FileUploader

go run file-uploader.go
2016/08/13 17:03:28 Successfully created mymusic
2016/08/13 17:03:40 Successfully uploaded golden-oldies.zip of size 16253413

mc ls play/mymusic/
[2016-05-27 16:02:16 PDT]  17MiB golden-oldies.zip

API Reference

The full API Reference is available here.

API Reference : Bucket Operations

API Reference : Bucket policy Operations

API Reference : Bucket notification Operations

API Reference : File Object Operations

API Reference : Object Operations

API Reference : Presigned Operations

API Reference : Client custom settings

Full Examples

Full Examples : Bucket Operations

Full Examples : Bucket policy Operations

Full Examples : Bucket lifecycle Operations

Full Examples : Bucket encryption Operations

Full Examples : Bucket replication Operations

Full Examples : Bucket notification Operations

Full Examples : File Object Operations

Full Examples : Object Operations

Full Examples : Encrypted Object Operations

Full Examples : Presigned Operations

Explore Further

Contribute

Contributors Guide

License

This SDK is distributed under the Apache License, Version 2.0, see LICENSE and NOTICE for more information.