summaryrefslogtreecommitdiff
path: root/shrine/utils/storage/storage.go
blob: d071149f955966d97981d7434c24f333ea3bcf87 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
package storage

import (
	"context"
	"errors"
	"io"
	"shrine/config"
	"shrine/messages"
	"shrine/utils/logger"
	"strings"

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

var Client *minio.Client

func init() {
	if config.Storage.AccessKey == "" || config.Storage.SecretKey == "" {
		logger.Infof("Storage", "MinIO credentials not configured, storage disabled")
		return
	}

	var err error
	Client, err = minio.New(config.Storage.Endpoint, &minio.Options{
		Creds:  credentials.NewStaticV4(config.Storage.AccessKey, config.Storage.SecretKey, ""),
		Secure: config.Storage.UseSSL,
	})
	if err != nil {
		logger.Fatalf("Storage", "Failed to initialize MinIO client: %v", err)
	}

	logger.Successf("Storage", "MinIO client initialized for %s", config.Storage.Endpoint)
}

func Upload(path string, reader io.Reader, size int64, contentType string) error {
	if Client == nil {
		return errors.New(messages.StorageNotConfigured)
	}
	_, err := Client.PutObject(context.Background(), config.Storage.Bucket, path, reader, size, minio.PutObjectOptions{
		ContentType: contentType,
	})
	return err
}

func Delete(path string) error {
	if Client == nil {
		return errors.New(messages.StorageNotConfigured)
	}
	return Client.RemoveObject(context.Background(), config.Storage.Bucket, path, minio.RemoveObjectOptions{})
}

func ResolveCDN(path string) string {
	if path == "" {
		return ""
	}
	return strings.TrimRight(config.Storage.CDN, "/") + "/" + config.Storage.Bucket + "/" + path
}

func PathFromCDN(cdnURL string) string {
	prefix := strings.TrimRight(config.Storage.CDN, "/") + "/" + config.Storage.Bucket + "/"
	if !strings.HasPrefix(cdnURL, prefix) {
		return ""
	}
	return strings.TrimPrefix(cdnURL, prefix)
}