Skip to content

Commit

Permalink
Add a new function to create the Azure backend storage with the provi…
Browse files Browse the repository at this point in the history
…ded client

Add a new function to create the Azure backend storage with the provided client so that we can wrap and reuse the storage implementation on Velero side

Signed-off-by: Wenkai Yin(尹文开) <[email protected]>
  • Loading branch information
ywk253100 authored and Lyndon-Li committed Dec 2, 2024
1 parent c70f1a1 commit 83d4a47
Showing 1 changed file with 34 additions and 0 deletions.
34 changes: 34 additions & 0 deletions repo/blob/azure/patch.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
package azure

import (
"context"
"fmt"

"github.com/Azure/azure-sdk-for-go/sdk/storage/azblob"
"github.com/kopia/kopia/internal/clock"
"github.com/kopia/kopia/repo/blob"
"github.com/kopia/kopia/repo/blob/retrying"
"github.com/pkg/errors"
)

// NewWithClient creates new Azure backend storage with the specified client
func NewWithClient(ctx context.Context, opt *Options, client *azblob.Client) (blob.Storage, error) {
raw := &azStorage{
Options: *opt,
container: opt.Container,
service: client,
}

az := retrying.NewWrapper(raw)

// verify Azure connection is functional by listing blobs in a bucket, which will fail if the container
// does not exist. We list with a prefix that will not exist, to avoid iterating through any objects.
nonExistentPrefix := fmt.Sprintf("kopia-azure-storage-initializing-%v", clock.Now().UnixNano())
if err := raw.ListBlobs(ctx, blob.ID(nonExistentPrefix), func(md blob.Metadata) error {
return nil
}); err != nil {
return nil, errors.Wrap(err, "unable to list from the bucket")
}

return az, nil
}

0 comments on commit 83d4a47

Please sign in to comment.