Documentation
      ¶
    
    
  
    
  
    Overview ¶
Example (Lease_ContainerClient_AcquireLease) ¶
This example shows how to perform various lease operations on a container. The same lease operations can be performed on individual blobs as well. A lease on a container prevents it from being deleted by others, while a lease on a blob protects it from both modifications and deletions.
//go:build go1.18
// +build go1.18
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License. See License.txt in the project root for license information.
package main
import (
	"context"
	"fmt"
	"log"
	"os"
	"github.com/Azure/azure-sdk-for-go/sdk/azcore/to"
	"github.com/Azure/azure-sdk-for-go/sdk/storage/azblob"
	"github.com/Azure/azure-sdk-for-go/sdk/storage/azblob/container"
	"github.com/Azure/azure-sdk-for-go/sdk/storage/azblob/lease"
)
func handleError(err error) {
	if err != nil {
		log.Fatal(err.Error())
	}
}
// This example shows how to perform various lease operations on a container.
// The same lease operations can be performed on individual blobs as well.
// A lease on a container prevents it from being deleted by others, while a lease on a blob
// protects it from both modifications and deletions.
func main() {
	// From the Azure portal, get your Storage account's name and account key.
	accountName, accountKey := os.Getenv("AZURE_STORAGE_ACCOUNT_NAME"), os.Getenv("AZURE_STORAGE_ACCOUNT_KEY")
	// Use your Storage account's name and key to create a credential object; this is used to access your account.
	credential, err := azblob.NewSharedKeyCredential(accountName, accountKey)
	handleError(err)
	// Create an containerClient object that wraps the container's URL and a default pipeline.
	containerURL := fmt.Sprintf("https://%s.blob.core.windows.net/mycontainer", accountName)
	containerClient, err := container.NewClientWithSharedKeyCredential(containerURL, credential, nil)
	handleError(err)
	// Create a unique ID for the lease
	// A lease ID can be any valid GUID string format. To generate UUIDs, consider the github.com/google/uuid package
	leaseID := "36b1a876-cf98-4eb2-a5c3-6d68489658ff"
	containerLeaseClient, err := lease.NewContainerClient(containerClient,
		&lease.ContainerClientOptions{LeaseID: to.Ptr(leaseID)})
	handleError(err)
	// Now acquire a lease on the container.
	// You can choose to pass an empty string for proposed ID so that the service automatically assigns one for you.
	duration := int32(60)
	acquireLeaseResponse, err := containerLeaseClient.AcquireLease(context.TODO(), duration, nil)
	handleError(err)
	fmt.Println("The container is leased for delete operations with lease ID", *acquireLeaseResponse.LeaseID)
	// The container cannot be deleted without providing the lease ID.
	_, err = containerClient.Delete(context.TODO(), nil)
	if err == nil {
		log.Fatal("delete should have failed")
	}
	fmt.Println("The container cannot be deleted while there is an active lease")
	// _, err = containerClient.Delete(context.TODO(), &container.DeleteOptions{
	// 	AccessConditions: &container.AccessConditions{
	// 		LeaseAccessConditions: &container.LeaseAccessConditions{LeaseID: acquireLeaseResponse.LeaseID},
	// 	},
	// })
	// We can release the lease now and the container can be deleted.
	_, err = containerLeaseClient.ReleaseLease(context.TODO(), nil)
	handleError(err)
	fmt.Println("The lease on the container is now released")
	// AcquireLease a lease again to perform other operations.
	// Duration is still 60
	acquireLeaseResponse, err = containerLeaseClient.AcquireLease(context.TODO(), duration, nil)
	handleError(err)
	fmt.Println("The container is leased again with lease ID", *acquireLeaseResponse.LeaseID)
	// We can change the ID of an existing lease.
	newLeaseID := "6b3e65e5-e1bb-4a3f-8b72-13e9bc9cd3bf"
	changeLeaseResponse, err := containerLeaseClient.ChangeLease(context.TODO(), newLeaseID, nil)
	handleError(err)
	fmt.Println("The lease ID was changed to", *changeLeaseResponse.LeaseID)
	// The lease can be renewed.
	renewLeaseResponse, err := containerLeaseClient.RenewLease(context.TODO(), nil)
	handleError(err)
	fmt.Println("The lease was renewed with the same ID", *renewLeaseResponse.LeaseID)
	// Finally, the lease can be broken, and we could prevent others from acquiring a lease for a period of time
	_, err = containerLeaseClient.BreakLease(context.TODO(), &lease.ContainerBreakOptions{BreakPeriod: to.Ptr(int32(60))})
	handleError(err)
	fmt.Println("The lease was broken, and nobody can acquire a lease for 60 seconds")
}
Index ¶
- Constants
 - type AccessConditions
 - type BlobAcquireOptions
 - type BlobAcquireResponse
 - type BlobBreakOptions
 - type BlobBreakResponse
 - type BlobChangeOptions
 - type BlobChangeResponse
 - type BlobClient
 - func (c *BlobClient) AcquireLease(ctx context.Context, duration int32, o *BlobAcquireOptions) (BlobAcquireResponse, error)
 - func (c *BlobClient) BreakLease(ctx context.Context, o *BlobBreakOptions) (BlobBreakResponse, error)
 - func (c *BlobClient) ChangeLease(ctx context.Context, proposedLeaseID string, o *BlobChangeOptions) (BlobChangeResponse, error)
 - func (c *BlobClient) LeaseID() *string
 - func (c *BlobClient) ReleaseLease(ctx context.Context, o *BlobReleaseOptions) (BlobReleaseResponse, error)
 - func (c *BlobClient) RenewLease(ctx context.Context, o *BlobRenewOptions) (BlobRenewResponse, error)
 
- type BlobClientOptions
 - type BlobReleaseOptions
 - type BlobReleaseResponse
 - type BlobRenewOptions
 - type BlobRenewResponse
 - type ContainerAcquireOptions
 - type ContainerAcquireResponse
 - type ContainerBreakOptions
 - type ContainerBreakResponse
 - type ContainerChangeOptions
 - type ContainerChangeResponse
 - type ContainerClient
 - func (c *ContainerClient) AcquireLease(ctx context.Context, duration int32, o *ContainerAcquireOptions) (ContainerAcquireResponse, error)
 - func (c *ContainerClient) BreakLease(ctx context.Context, o *ContainerBreakOptions) (ContainerBreakResponse, error)
 - func (c *ContainerClient) ChangeLease(ctx context.Context, proposedLeaseID string, o *ContainerChangeOptions) (ContainerChangeResponse, error)
 - func (c *ContainerClient) LeaseID() *string
 - func (c *ContainerClient) ReleaseLease(ctx context.Context, o *ContainerReleaseOptions) (ContainerReleaseResponse, error)
 - func (c *ContainerClient) RenewLease(ctx context.Context, o *ContainerRenewOptions) (ContainerRenewResponse, error)
 
- type ContainerClientOptions
 - type ContainerReleaseOptions
 - type ContainerReleaseResponse
 - type ContainerRenewOptions
 - type ContainerRenewResponse
 - type DurationType
 - type ModifiedAccessConditions
 - type StateType
 - type StatusType
 
Examples ¶
Constants ¶
const BreakNaturally = -1
    BreakNaturally tells ContainerClient's or BlobClient's BreakLease method to break the lease using service semantics.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type AccessConditions ¶
type AccessConditions = generated.LeaseAccessConditions
AccessConditions contains a group of parameters for specifying lease access conditions.
type BlobAcquireOptions ¶
type BlobAcquireOptions struct {
	ModifiedAccessConditions *ModifiedAccessConditions
}
    BlobAcquireOptions contains the optional parameters for the LeaseClient.AcquireLease method.
type BlobAcquireResponse ¶
type BlobAcquireResponse = generated.BlobClientAcquireLeaseResponse
BlobAcquireResponse contains the response from method BlobClient.AcquireLease.
type BlobBreakOptions ¶
type BlobBreakOptions struct {
	// For a break operation, proposed Duration the lease should continue before it is broken, in seconds, between 0 and 60. This
	// break period is only used if it is shorter than the time remaining on the lease. If longer, the time remaining on the lease
	// is used. A new lease will not be available before the break period has expired, but the lease may be held for longer than
	// the break period. If this header does not appear with a break operation, a fixed-Duration lease breaks after the remaining
	// lease period elapses, and an infinite lease breaks immediately.
	BreakPeriod              *int32
	ModifiedAccessConditions *ModifiedAccessConditions
}
    BlobBreakOptions contains the optional parameters for the LeaseClient.BreakLease method.
type BlobBreakResponse ¶
type BlobBreakResponse = generated.BlobClientBreakLeaseResponse
BlobBreakResponse contains the response from method BlobClient.BreakLease.
type BlobChangeOptions ¶
type BlobChangeOptions struct {
	ModifiedAccessConditions *ModifiedAccessConditions
}
    BlobChangeOptions contains the optional parameters for the LeaseClient.ChangeLease method.
type BlobChangeResponse ¶
type BlobChangeResponse = generated.BlobClientChangeLeaseResponse
BlobChangeResponse contains the response from method BlobClient.ChangeLease.
type BlobClient ¶
type BlobClient struct {
	// contains filtered or unexported fields
}
    BlobClient provides lease functionality for the underlying blob client.
func NewBlobClient ¶
func NewBlobClient[T appendblob.Client | blob.Client | blockblob.Client | pageblob.Client](client *T, options *BlobClientOptions) (*BlobClient, error)
NewBlobClient creates a blob lease client for the provided blob client.
- client - an instance of a blob client
 - options - client options; pass nil to accept the default values
 
func (*BlobClient) AcquireLease ¶
func (c *BlobClient) AcquireLease(ctx context.Context, duration int32, o *BlobAcquireOptions) (BlobAcquireResponse, error)
AcquireLease acquires a lease on the blob for write and delete operations. The lease Duration must be between 15 and 60 seconds, or infinite (-1). For more information, see https://docs.microsoft.com/rest/api/storageservices/lease-blob.
func (*BlobClient) BreakLease ¶
func (c *BlobClient) BreakLease(ctx context.Context, o *BlobBreakOptions) (BlobBreakResponse, error)
BreakLease breaks the blob's previously-acquired lease (if it exists). Pass the LeaseBreakDefault (-1) constant to break a fixed-Duration lease when it expires or an infinite lease immediately. For more information, see https://docs.microsoft.com/rest/api/storageservices/lease-blob.
func (*BlobClient) ChangeLease ¶
func (c *BlobClient) ChangeLease(ctx context.Context, proposedLeaseID string, o *BlobChangeOptions) (BlobChangeResponse, error)
ChangeLease changes the blob's lease ID. For more information, see https://docs.microsoft.com/rest/api/storageservices/lease-blob.
func (*BlobClient) LeaseID ¶
func (c *BlobClient) LeaseID() *string
LeaseID returns leaseID of the client.
func (*BlobClient) ReleaseLease ¶
func (c *BlobClient) ReleaseLease(ctx context.Context, o *BlobReleaseOptions) (BlobReleaseResponse, error)
ReleaseLease releases the blob's previously-acquired lease. For more information, see https://docs.microsoft.com/rest/api/storageservices/lease-blob.
func (*BlobClient) RenewLease ¶
func (c *BlobClient) RenewLease(ctx context.Context, o *BlobRenewOptions) (BlobRenewResponse, error)
RenewLease renews the blob's previously-acquired lease. For more information, see https://docs.microsoft.com/rest/api/storageservices/lease-blob.
type BlobClientOptions ¶
type BlobClientOptions struct {
	// LeaseID contains a caller-provided lease ID.
	LeaseID *string
}
    BlobClientOptions contains the optional values when creating a BlobClient.
type BlobReleaseOptions ¶
type BlobReleaseOptions struct {
	ModifiedAccessConditions *ModifiedAccessConditions
}
    BlobReleaseOptions contains the optional parameters for the LeaseClient.ReleaseLease method.
type BlobReleaseResponse ¶
type BlobReleaseResponse = generated.BlobClientReleaseLeaseResponse
BlobReleaseResponse contains the response from method BlobClient.ReleaseLease.
type BlobRenewOptions ¶
type BlobRenewOptions struct {
	ModifiedAccessConditions *ModifiedAccessConditions
}
    BlobRenewOptions contains the optional parameters for the LeaseClient.RenewLease method.
type BlobRenewResponse ¶
type BlobRenewResponse = generated.BlobClientRenewLeaseResponse
BlobRenewResponse contains the response from method BlobClient.RenewLease.
type ContainerAcquireOptions ¶
type ContainerAcquireOptions struct {
	ModifiedAccessConditions *ModifiedAccessConditions
}
    ContainerAcquireOptions contains the optional parameters for the LeaseClient.AcquireLease method.
type ContainerAcquireResponse ¶
type ContainerAcquireResponse = generated.ContainerClientAcquireLeaseResponse
ContainerAcquireResponse contains the response from method BlobClient.AcquireLease.
type ContainerBreakOptions ¶
type ContainerBreakOptions struct {
	// For a break operation, proposed Duration the lease should continue before it is broken, in seconds, between 0 and 60. This
	// break period is only used if it is shorter than the time remaining on the lease. If longer, the time remaining on the lease
	// is used. A new lease will not be available before the break period has expired, but the lease may be held for longer than
	// the break period. If this header does not appear with a break operation, a fixed-Duration lease breaks after the remaining
	// lease period elapses, and an infinite lease breaks immediately.
	BreakPeriod              *int32
	ModifiedAccessConditions *ModifiedAccessConditions
}
    ContainerBreakOptions contains the optional parameters for the LeaseClient.BreakLease method.
type ContainerBreakResponse ¶
type ContainerBreakResponse = generated.ContainerClientBreakLeaseResponse
ContainerBreakResponse contains the response from method BlobClient.BreakLease.
type ContainerChangeOptions ¶
type ContainerChangeOptions struct {
	ModifiedAccessConditions *ModifiedAccessConditions
}
    ContainerChangeOptions contains the optional parameters for the LeaseClient.ChangeLease method.
type ContainerChangeResponse ¶
type ContainerChangeResponse = generated.ContainerClientChangeLeaseResponse
ContainerChangeResponse contains the response from method BlobClient.ChangeLease.
type ContainerClient ¶
type ContainerClient struct {
	// contains filtered or unexported fields
}
    ContainerClient provides lease functionality for the underlying container client.
func NewContainerClient ¶
func NewContainerClient(client *container.Client, options *ContainerClientOptions) (*ContainerClient, error)
NewContainerClient creates a container lease client for the provided container client.
- client - an instance of a container client
 - options - client options; pass nil to accept the default values
 
func (*ContainerClient) AcquireLease ¶
func (c *ContainerClient) AcquireLease(ctx context.Context, duration int32, o *ContainerAcquireOptions) (ContainerAcquireResponse, error)
AcquireLease acquires a lease on the blob for write and delete operations. The lease Duration must be between 15 and 60 seconds, or infinite (-1). For more information, see https://docs.microsoft.com/rest/api/storageservices/lease-blob.
func (*ContainerClient) BreakLease ¶
func (c *ContainerClient) BreakLease(ctx context.Context, o *ContainerBreakOptions) (ContainerBreakResponse, error)
BreakLease breaks the blob's previously-acquired lease (if it exists). Pass the LeaseBreakDefault (-1) constant to break a fixed-Duration lease when it expires or an infinite lease immediately. For more information, see https://docs.microsoft.com/rest/api/storageservices/lease-blob.
func (*ContainerClient) ChangeLease ¶
func (c *ContainerClient) ChangeLease(ctx context.Context, proposedLeaseID string, o *ContainerChangeOptions) (ContainerChangeResponse, error)
ChangeLease changes the blob's lease ID. For more information, see https://docs.microsoft.com/rest/api/storageservices/lease-blob.
func (*ContainerClient) LeaseID ¶
func (c *ContainerClient) LeaseID() *string
LeaseID returns leaseID of the client.
func (*ContainerClient) ReleaseLease ¶
func (c *ContainerClient) ReleaseLease(ctx context.Context, o *ContainerReleaseOptions) (ContainerReleaseResponse, error)
ReleaseLease releases the blob's previously-acquired lease. For more information, see https://docs.microsoft.com/rest/api/storageservices/lease-blob.
func (*ContainerClient) RenewLease ¶
func (c *ContainerClient) RenewLease(ctx context.Context, o *ContainerRenewOptions) (ContainerRenewResponse, error)
RenewLease renews the blob's previously-acquired lease. For more information, see https://docs.microsoft.com/rest/api/storageservices/lease-blob.
type ContainerClientOptions ¶
type ContainerClientOptions struct {
	// LeaseID contains a caller-provided lease ID.
	LeaseID *string
}
    ContainerClientOptions contains the optional values when creating a ContainerClient.
type ContainerReleaseOptions ¶
type ContainerReleaseOptions struct {
	ModifiedAccessConditions *ModifiedAccessConditions
}
    ContainerReleaseOptions contains the optional parameters for the LeaseClient.ReleaseLease method.
type ContainerReleaseResponse ¶
type ContainerReleaseResponse = generated.ContainerClientReleaseLeaseResponse
ContainerReleaseResponse contains the response from method BlobClient.ReleaseLease.
type ContainerRenewOptions ¶
type ContainerRenewOptions struct {
	ModifiedAccessConditions *ModifiedAccessConditions
}
    ContainerRenewOptions contains the optional parameters for the LeaseClient.RenewLease method.
type ContainerRenewResponse ¶
type ContainerRenewResponse = generated.ContainerClientRenewLeaseResponse
ContainerRenewResponse contains the response from method BlobClient.RenewLease.
type DurationType ¶ added in v0.6.0
type DurationType = generated.LeaseDurationType
DurationType defines values for DurationType
const ( DurationTypeInfinite DurationType = generated.LeaseDurationTypeInfinite DurationTypeFixed DurationType = generated.LeaseDurationTypeFixed )
func PossibleDurationTypeValues ¶ added in v0.6.0
func PossibleDurationTypeValues() []DurationType
PossibleDurationTypeValues returns the possible values for the DurationType const type.
type ModifiedAccessConditions ¶
type ModifiedAccessConditions = exported.ModifiedAccessConditions
ModifiedAccessConditions contains a group of parameters for specifying access conditions.
type StateType ¶ added in v0.6.0
type StateType = generated.LeaseStateType
StateType defines values for StateType
const ( StateTypeAvailable StateType = generated.LeaseStateTypeAvailable StateTypeLeased StateType = generated.LeaseStateTypeLeased StateTypeExpired StateType = generated.LeaseStateTypeExpired StateTypeBreaking StateType = generated.LeaseStateTypeBreaking StateTypeBroken StateType = generated.LeaseStateTypeBroken )
func PossibleStateTypeValues ¶ added in v0.6.0
func PossibleStateTypeValues() []StateType
PossibleStateTypeValues returns the possible values for the StateType const type.
type StatusType ¶ added in v0.6.0
type StatusType = generated.LeaseStatusType
StatusType defines values for StatusType
const ( StatusTypeLocked StatusType = generated.LeaseStatusTypeLocked StatusTypeUnlocked StatusType = generated.LeaseStatusTypeUnlocked )
func PossibleStatusTypeValues ¶ added in v0.6.0
func PossibleStatusTypeValues() []StatusType
PossibleStatusTypeValues returns the possible values for the StatusType const type.