download

package
v1.3.26 Latest Latest
Warning

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

Go to latest
Published: Sep 19, 2025 License: MIT Imports: 18 Imported by: 0

Documentation

Index

Constants

View Source
const (
	// MsiDownload404ErrorString describes Msi specific error
	MsiDownload404ErrorString = "please ensure that the blob exists, and the specified Managed Identity has read permissions to the storage blob"

	// MsiDownload403ErrorString describes Msi permission specific error
	MsiDownload403ErrorString = "please ensure that the specified Managed Identity has read permissions to the storage blob"
)

Variables

View Source
var (
	MakeHttpRequest = HttpClientDo
)
View Source
var MockReturnErrorForMockMsiDownloader = false // Used only for test

Functions

func CreateOrReplaceAppendBlob added in v1.2.2

func CreateOrReplaceAppendBlob(blobURI, blobSas string) (*storage.Blob, error)

CreateOrReplaceAppendBlob creates a reference to an append blob. If blob exists - it gets deleted first.

func Download

func Download(ctx *log.Context, downloader Downloader) (int, io.ReadCloser, error)

Download retrieves a response body and checks the response status code to see if it is 200 OK and then returns the response body. It issues a new request every time called. It is caller's responsibility to close the response body.

func GetResourceNameFromBlobUri

func GetResourceNameFromBlobUri(uri string) string

func GetSASBlob

func GetSASBlob(blobURI, blobSas, targetDir string) (string, error)

GetSASBlob download a blob with specified uri and sas authorization and saves it to the target directory Returns the filePath where the blob was downloaded

func GetUriForLogging added in v1.2.2

func GetUriForLogging(uriString string) string

Scrub query. Used to remove the query parts like SAS token.

func HttpClientDo added in v1.3.19

func HttpClientDo(request *http.Request) (*http.Response, error)

func IsAzureStorageBlobUri

func IsAzureStorageBlobUri(url string) bool

func SaveTo

func SaveTo(ctx *log.Context, downloaders []Downloader, dst string, mode os.FileMode) (int64, error)

SaveTo uses given downloader to fetch the resource with retries and saves the given file. Directory of dst is not created by this function. If a file at dst exists, it will be truncated. If a new file is created, mode is used to set the permission bits. Written number of bytes are returned on success.

func WithRetries

func WithRetries(ctx *log.Context, downloaders []Downloader, sf SleepFunc) (io.ReadCloser, error)

WithRetries retrieves a response body using the specified downloader. Any error returned from d will be retried (and retrieved response bodies will be closed on failures). If the retries do not succeed, the last error is returned.

It sleeps in exponentially increasing durations between retries.

Types

type Downloader

type Downloader interface {
	// GetRequest returns a new GET request for the resource.
	GetRequest() (*http.Request, error)
}

Downloader describes a method to download files.

func NewBlobDownload

func NewBlobDownload(accountName, accountKey string, blob blobutil.AzureBlobRef) Downloader

NewBlobDownload creates a new Downloader for a blob hosted in Azure Blob Storage.

func NewBlobWithMsiDownload

func NewBlobWithMsiDownload(url string, msiProvider MsiProvider) Downloader

func NewURLDownload

func NewURLDownload(url string) Downloader

NewURLDownload creates a new downloader with the provided URL

type MockMsiDownloader added in v1.2.2

type MockMsiDownloader struct{} // Used only for test

func (MockMsiDownloader) GetMsiProvider added in v1.2.2

func (mockMsiDownloader MockMsiDownloader) GetMsiProvider(blobUri string) MsiProvider

Mock implementation of GetMsiProvider

func (MockMsiDownloader) GetMsiProviderByClientId added in v1.2.2

func (mockMsiDownloader MockMsiDownloader) GetMsiProviderByClientId(blobUri string, clientId string) MsiProvider

Mock implementation of GetMsiProviderByClientId

func (MockMsiDownloader) GetMsiProviderByObjectId added in v1.2.2

func (mockMsiDownloader MockMsiDownloader) GetMsiProviderByObjectId(blobUri, objectId string) MsiProvider

Mock implementation of GetMsiProviderByObjectId

type MsiDownloader added in v1.2.2

type MsiDownloader interface {
	GetMsiProvider(blobUri string) MsiProvider
	GetMsiProviderByClientId(blobUri, clientId string) MsiProvider
	GetMsiProviderByObjectId(blobUri, objectId string) MsiProvider
}

type MsiProvider

type MsiProvider func() (msi.Msi, error)

type ProdMsiDownloader added in v1.2.2

type ProdMsiDownloader struct{}

func (ProdMsiDownloader) GetMsiProvider added in v1.2.2

func (prodMsiDownloader ProdMsiDownloader) GetMsiProvider(blobUri string) MsiProvider

Uses system identity to get Msi token

func (ProdMsiDownloader) GetMsiProviderByClientId added in v1.2.2

func (prodMsiDownloader ProdMsiDownloader) GetMsiProviderByClientId(blobUri, clientId string) MsiProvider

Get Msi token by clientId

func (ProdMsiDownloader) GetMsiProviderByObjectId added in v1.2.2

func (prodMsiDownloader ProdMsiDownloader) GetMsiProviderByObjectId(blobUri, objectId string) MsiProvider

Get Msi token by objectId

type SleepFunc

type SleepFunc func(d time.Duration)

SleepFunc pauses the execution for at least duration d.

var (
	// ActualSleep uses actual time to pause the execution.
	ActualSleep SleepFunc = time.Sleep
)

Jump to

Keyboard shortcuts

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