Sample code for 30+ languages & platforms
PowerShell

Azure Create Storage Account

See more Azure Storage Accounts Examples

Demonstrates how to create an Azure storage account.

Chilkat PowerShell Downloads

PowerShell
Add-Type -Path "C:\chilkat\ChilkatDotNet47-x64\ChilkatDotNet47.dll"

$success = $false

# This example requires the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.

$http = New-Object Chilkat.Http

# Load an OAuth2 access token previously fetched by this example:  Get Azure OAuth2 Access Token
$jsonToken = New-Object Chilkat.JsonObject
$success = $jsonToken.LoadFile("qa_data/tokens/azureToken.json")
# Assuming success..
$http.AuthToken = $jsonToken.StringOf("access_token")
$("AuthToken: " + $http.AuthToken)

$http.Accept = "application/json"

# Create the following JSON:

# {
#   "sku": {
#     "name": "Standard_GRS"
#   },
#   "kind": "StorageV2",
#   "location": "eastus2",
# }

# Use this online tool to generate the code from sample JSON: 
# Generate Code to Create JSON

$jsonRequestBody = New-Object Chilkat.JsonObject
$jsonRequestBody.UpdateString("sku.name","Standard_GRS")
$jsonRequestBody.UpdateString("kind","StorageV2")
$jsonRequestBody.UpdateString("location","eastus2")

$url = "https://management.azure.com/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Storage/storageAccounts/{accountName}?api-version=2018-02-01"

$resp = New-Object Chilkat.HttpResponse
$success = $http.HttpJson("PUT",$url,$jsonRequestBody,"application/json",$resp)
if ($success -eq $false) {
    $($http.LastErrorText)
    exit
}

$("Response Status Code: " + $resp.StatusCode)

$json = New-Object Chilkat.JsonObject
$json.Load($resp.BodyStr)
$json.EmitCompact = $false
$($json.Emit())

if ($resp.StatusCode -ge 300) {
    $("Failed.")
    exit
}

# Successful requests to create a new account return a 202 status code with an empty response body. The storage account is created asynchronously. 
# If the account already exists or is being provisioned, the request response has a 200 return code with the configuration of the existing storage account in the response body.
if ($resp.StatusCode -eq 202) {
    $("Azure-AsyncOperation: " + $resp.GetHeaderField("Azure-AsyncOperation"))
}

if ($resp.StatusCode -eq 200) {

    # Parse a response like this:

    # 	{
    # 	  "sku": {
    # 	    "name": "Standard_GRS",
    # 	    "tier": "Standard"
    # 	  },
    # 	  "kind": "StorageV2",
    # 	  "id": "/subscriptions/6c42643b-ebef-45f0-b917-b3583b84a57f/resourceGroups/gChilkat/providers/Microsoft.Storage/storageAccounts/chilkatsoftware",
    # 	  "name": "chilkatsoftware",
    # 	  "type": "Microsoft.Storage/storageAccounts",
    # 	  "location": "eastus2",
    # 	  "tags": {},
    # 	  "properties": {
    # 	    "networkAcls": {
    # 	      "bypass": "AzureServices",
    # 	      "virtualNetworkRules": [
    # 	      ],
    # 	      "ipRules": [
    # 	      ],
    # 	      "defaultAction": "Allow"
    # 	    },
    # 	    "supportsHttpsTrafficOnly": false,
    # 	    "encryption": {
    # 	      "services": {
    # 	        "file": {
    # 	          "enabled": true,
    # 	          "lastEnabledTime": "2019-05-14T22:18:33.2246670Z"
    # 	        },
    # 	        "blob": {
    # 	          "enabled": true,
    # 	          "lastEnabledTime": "2019-05-14T22:18:33.2246670Z"
    # 	        }
    # 	      },
    # 	      "keySource": "Microsoft.Storage"
    # 	    },
    # 	    "accessTier": "Hot",
    # 	    "provisioningState": "Succeeded",
    # 
    # 	    "creationTime": "2019-05-14T22:18:33.1309165Z",
    # 	    "primaryEndpoints": {
    # 	      "dfs": "https://chilkatsoftware.dfs.core.windows.net/",
    # 	      "web": "https://chilkatsoftware.z20.web.core.windows.net/",
    # 	      "blob": "https://chilkatsoftware.blob.core.windows.net/",
    # 	      "queue": "https://chilkatsoftware.queue.core.windows.net/",
    # 	      "table": "https://chilkatsoftware.table.core.windows.net/",
    # 	      "file": "https://chilkatsoftware.file.core.windows.net/"
    # 	    },
    # 	    "primaryLocation": "eastus2",
    # 	    "statusOfPrimary": "available",
    # 	    "secondaryLocation": "centralus",
    # 	    "statusOfSecondary": "available"
    # 	  }
    # 	}

    # Use this online tool to generate parsing code from sample JSON: 
    # Generate Parsing Code from JSON

    $skuName = $json.StringOf("sku.name")
    $skuTier = $json.StringOf("sku.tier")
    $kind = $json.StringOf("kind")
    $id = $json.StringOf("id")
    $name = $json.StringOf("name")
    $v_type = $json.StringOf("type")
    $location = $json.StringOf("location")
    $propertiesNetworkAclsBypass = $json.StringOf("properties.networkAcls.bypass")
    $propertiesNetworkAclsDefaultAction = $json.StringOf("properties.networkAcls.defaultAction")
    $propertiesSupportsHttpsTrafficOnly = $json.BoolOf("properties.supportsHttpsTrafficOnly")
    $propertiesEncryptionServicesFileEnabled = $json.BoolOf("properties.encryption.services.file.enabled")
    $propertiesEncryptionServicesFileLastEnabledTime = $json.StringOf("properties.encryption.services.file.lastEnabledTime")
    $propertiesEncryptionServicesBlobEnabled = $json.BoolOf("properties.encryption.services.blob.enabled")
    $propertiesEncryptionServicesBlobLastEnabledTime = $json.StringOf("properties.encryption.services.blob.lastEnabledTime")
    $propertiesEncryptionKeySource = $json.StringOf("properties.encryption.keySource")
    $propertiesAccessTier = $json.StringOf("properties.accessTier")
    $propertiesProvisioningState = $json.StringOf("properties.provisioningState")
    $propertiesCreationTime = $json.StringOf("properties.creationTime")
    $propertiesPrimaryEndpointsDfs = $json.StringOf("properties.primaryEndpoints.dfs")
    $propertiesPrimaryEndpointsWeb = $json.StringOf("properties.primaryEndpoints.web")
    $propertiesPrimaryEndpointsBlob = $json.StringOf("properties.primaryEndpoints.blob")
    $propertiesPrimaryEndpointsQueue = $json.StringOf("properties.primaryEndpoints.queue")
    $propertiesPrimaryEndpointsTable = $json.StringOf("properties.primaryEndpoints.table")
    $propertiesPrimaryEndpointsFile = $json.StringOf("properties.primaryEndpoints.file")
    $propertiesPrimaryLocation = $json.StringOf("properties.primaryLocation")
    $propertiesStatusOfPrimary = $json.StringOf("properties.statusOfPrimary")
    $propertiesSecondaryLocation = $json.StringOf("properties.secondaryLocation")
    $propertiesStatusOfSecondary = $json.StringOf("properties.statusOfSecondary")
}

$("Success.")