providers

package
v0.0.0-...-8e8a5cf Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 24, 2024 License: Apache-2.0 Imports: 15 Imported by: 13

Documentation

Index

Constants

View Source
const (
	S3 = "s3"
	GS = "gs"
	// TODO(danilo-gemoli): complete the implementation since at this time only opener.Writer()
	// is supported
	File = "file"
)
View Source
const S3MinUploadPartSize = 5 * 1024 * 1024 // 5 MiB

Variables

This section is empty.

Functions

func DisplayName

func DisplayName(provider string) string

DisplayName turns canonical provider IDs into displayable names.

func GetBucket

func GetBucket(ctx context.Context, S3Credentials []byte, path string) (*blob.Bucket, error)

GetBucket opens and returns a gocloud blob.Bucket based on credentials and a path. The path is used to discover which storageProvider should be used.

If the storageProvider file is detected, we don't need any credentials and just open a file bucket If no credentials are given, we just fall back to blob.OpenBucket which tries to auto discover credentials e.g. via environment variables. For more details, see: https://gocloud.dev/howto/blob/

If we specify credentials and an 3:// path is used, credentials must be given in one of the following formats:

  • AWS S3 (s3://): { "region": "us-east-1", "s3_force_path_style": true, "access_key": "access_key", "secret_key": "secret_key" }
  • S3-compatible service, e.g. self-hosted Minio (s3://): { "region": "minio", "endpoint": "https://minio-hl-svc.minio-operator-ns:9000", "s3_force_path_style": true, "access_key": "access_key", "secret_key": "secret_key" }

func HasStorageProviderPrefix

func HasStorageProviderPrefix(path string) bool

HasStorageProviderPrefix returns true if the given string starts with any of the known storageProviders and a slash, e.g. * gs/kubernetes-jenkins returns true * kubernetes-jenkins returns false

func ParseStoragePath

func ParseStoragePath(storagePath string) (storageProvider, bucket, relativePath string, err error)

ParseStoragePath parses storagePath and returns the storageProvider, bucket and relativePath For example gs://prow-artifacts/test.log results in (gs, prow-artifacts, test.log) Currently detected storageProviders are GS, S3 and file. Paths with a leading / instead of a storageProvider prefix are treated as file paths for backwards compatibility reasons. File paths are split into a directory and a file. Directory is returned as bucket, file is returned. as relativePath. For all other paths the first part is treated as storageProvider prefix, the second segment as bucket and everything after the bucket as relativePath.

func StoragePath

func StoragePath(bucket, path string) (string, error)

StoragePath is the reverse of ParseStoragePath.

Types

type S3Credentials

type S3Credentials struct {
	Region           string `json:"region"`
	Endpoint         string `json:"endpoint"`
	Insecure         bool   `json:"insecure"`
	S3ForcePathStyle bool   `json:"s3_force_path_style"`
	AccessKey        string `json:"access_key"`
	SecretKey        string `json:"secret_key"`
	SessionToken     string `json:"session_token"`
}

S3Credentials are credentials used to access S3 or an S3-compatible storage service Endpoint is an optional property. Default is the AWS S3 endpoint. If set, the specified endpoint will be used instead.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL