Objective-C
Objective-C
Azure Storage: Lease Container
See more Azure Cloud Storage Examples
Azure Storage Blob Service REST API: Sample code to establishes a lock on a container for delete operations. The lock duration can be 15 to 60 seconds, or can be infinite.Chilkat Objective-C Downloads
#import <CkoRest.h>
#import <CkoAuthAzureStorage.h>
#import <CkoCrypt2.h>
#import <NSString.h>
BOOL success = NO;
// Azure Blob Service Example: Lease Container
// See also: https://msdn.microsoft.com/en-us/library/azure/jj159103.aspx
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
CkoRest *rest = [[CkoRest alloc] init];
// Connect to the Azure Storage Blob Service
BOOL bTls = YES;
int port = 443;
BOOL bAutoReconnect = YES;
// In this example, the storage account name is "chilkat".
success = [rest Connect: @"chilkat.blob.core.windows.net" port: [NSNumber numberWithInt: port] tls: bTls autoReconnect: bAutoReconnect];
if (success != YES) {
NSLog(@"%@",rest.LastErrorText);
return;
}
// Provide Azure Cloud credentials for the REST call.
CkoAuthAzureStorage *azAuth = [[CkoAuthAzureStorage alloc] init];
azAuth.AccessKey = @"AZURE_ACCESS_KEY";
// The account name used here should match the 1st part of the domain passed in the call to Connect (above).
azAuth.Account = @"chilkat";
azAuth.Scheme = @"SharedKey";
azAuth.Service = @"Blob";
// This causes the "x-ms-version: 2021-08-06" header to be automatically added.
azAuth.XMsVersion = @"2021-08-06";
success = [rest SetAuthAzureStorage: azAuth];
// Note: The application does not need to explicitly set the following
// headers: x-ms-date, Authorization. These headers
// are automatically set by Chilkat.
// The lease ID needs to be a GUID. (UUID and GUID are synonymous)
CkoCrypt2 *crypt = [[CkoCrypt2 alloc] init];
NSString *guid = [crypt GenerateUuid];
NSLog(@"%@%@",@"Lease ID: ",guid);
success = [rest AddHeader: @"x-ms-lease-id" value: guid];
// The action can be "acquire", "renew", "change", "release", or "break".
// See https://msdn.microsoft.com/en-us/library/azure/jj159103.aspx
success = [rest AddHeader: @"x-ms-lease-action" value: @"acquire"];
// The lease duration..
success = [rest AddHeader: @"x-ms-lease-duration" value: @"15"];
// In this example, we are acquiring a lease for the container named "mycontainer".
NSString *responseStr = [rest FullRequestNoBody: @"PUT" uriPath: @"/mycontainer?restype=container&comp=lease"];
if (rest.LastMethodSuccess != YES) {
NSLog(@"%@",rest.LastErrorText);
return;
}
// When successful, the Azure Storage service will respond with a 200, 201, or 202 response status code,
// with no response body.
// The status code depends on the operation:
// Acquire: A successful operation returns status code 201 (Created).
// Renew: A successful operation returns status code 200 (OK).
// Change: A successful operation returns status code 200 (OK).
// Release: A successful operation returns status code 200 (OK).
// Break: A successful operation returns status code 202 (Accepted).
if (([rest.ResponseStatusCode intValue] < 200) || ([rest.ResponseStatusCode intValue] > 202)) {
// Examine the request/response to see what happened.
NSLog(@"%@%d",@"response status code = ",[rest.ResponseStatusCode intValue]);
NSLog(@"%@%@",@"response status text = ",rest.ResponseStatusText);
NSLog(@"%@%@",@"response header: ",rest.ResponseHeader);
NSLog(@"%@%@",@"response body (if any): ",responseStr);
NSLog(@"%@",@"---");
NSLog(@"%@%@",@"LastRequestStartLine: ",rest.LastRequestStartLine);
NSLog(@"%@%@",@"LastRequestHeader: ",rest.LastRequestHeader);
return;
}
NSLog(@"%@",@"Success: Lease acquired.");