2016-01-26 14:45:18 -06:00
|
|
|
package azurerm
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"log"
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
"github.com/hashicorp/terraform/helper/schema"
|
|
|
|
)
|
|
|
|
|
|
|
|
func resourceArmStorageBlob() *schema.Resource {
|
|
|
|
return &schema.Resource{
|
|
|
|
Create: resourceArmStorageBlobCreate,
|
|
|
|
Read: resourceArmStorageBlobRead,
|
|
|
|
Exists: resourceArmStorageBlobExists,
|
|
|
|
Delete: resourceArmStorageBlobDelete,
|
|
|
|
|
|
|
|
Schema: map[string]*schema.Schema{
|
2016-06-01 15:17:21 -05:00
|
|
|
"name": {
|
2016-01-26 14:45:18 -06:00
|
|
|
Type: schema.TypeString,
|
|
|
|
Required: true,
|
|
|
|
ForceNew: true,
|
|
|
|
},
|
2016-06-01 15:17:21 -05:00
|
|
|
"resource_group_name": {
|
2016-01-26 14:45:18 -06:00
|
|
|
Type: schema.TypeString,
|
|
|
|
Required: true,
|
|
|
|
ForceNew: true,
|
|
|
|
},
|
|
|
|
"storage_account_name": {
|
|
|
|
Type: schema.TypeString,
|
|
|
|
Required: true,
|
|
|
|
ForceNew: true,
|
|
|
|
},
|
2016-06-01 15:17:21 -05:00
|
|
|
"storage_container_name": {
|
2016-01-26 14:45:18 -06:00
|
|
|
Type: schema.TypeString,
|
|
|
|
Required: true,
|
|
|
|
ForceNew: true,
|
|
|
|
},
|
2016-06-01 15:17:21 -05:00
|
|
|
"type": {
|
2016-01-26 14:45:18 -06:00
|
|
|
Type: schema.TypeString,
|
|
|
|
Required: true,
|
|
|
|
ForceNew: true,
|
|
|
|
ValidateFunc: validateArmStorageBlobType,
|
|
|
|
},
|
2016-06-01 15:17:21 -05:00
|
|
|
"size": {
|
2016-01-26 18:06:33 -06:00
|
|
|
Type: schema.TypeInt,
|
|
|
|
Optional: true,
|
|
|
|
ForceNew: true,
|
|
|
|
Default: 0,
|
|
|
|
ValidateFunc: validateArmStorageBlobSize,
|
2016-01-26 14:45:18 -06:00
|
|
|
},
|
2016-06-01 15:17:21 -05:00
|
|
|
"url": {
|
2016-01-26 14:45:18 -06:00
|
|
|
Type: schema.TypeString,
|
|
|
|
Computed: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-01-26 18:06:33 -06:00
|
|
|
func validateArmStorageBlobSize(v interface{}, k string) (ws []string, errors []error) {
|
|
|
|
value := v.(int)
|
|
|
|
|
|
|
|
if value%512 != 0 {
|
|
|
|
errors = append(errors, fmt.Errorf("Blob Size %q is invalid, must be a multiple of 512", value))
|
|
|
|
}
|
|
|
|
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2016-01-26 14:45:18 -06:00
|
|
|
func validateArmStorageBlobType(v interface{}, k string) (ws []string, errors []error) {
|
|
|
|
value := strings.ToLower(v.(string))
|
|
|
|
validTypes := map[string]struct{}{
|
|
|
|
"blob": struct{}{},
|
|
|
|
"page": struct{}{},
|
|
|
|
}
|
|
|
|
|
|
|
|
if _, ok := validTypes[value]; !ok {
|
|
|
|
errors = append(errors, fmt.Errorf("Blob type %q is invalid, must be %q or %q", value, "blob", "page"))
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func resourceArmStorageBlobCreate(d *schema.ResourceData, meta interface{}) error {
|
|
|
|
armClient := meta.(*ArmClient)
|
|
|
|
|
|
|
|
resourceGroupName := d.Get("resource_group_name").(string)
|
|
|
|
storageAccountName := d.Get("storage_account_name").(string)
|
|
|
|
|
2016-05-24 17:01:26 -05:00
|
|
|
blobClient, accountExists, err := armClient.getBlobStorageClientForStorageAccount(resourceGroupName, storageAccountName)
|
2016-01-26 14:45:18 -06:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2016-05-24 17:01:26 -05:00
|
|
|
if !accountExists {
|
|
|
|
return fmt.Errorf("Storage Account %q Not Found", storageAccountName)
|
|
|
|
}
|
2016-01-26 14:45:18 -06:00
|
|
|
|
|
|
|
name := d.Get("name").(string)
|
|
|
|
blobType := d.Get("type").(string)
|
|
|
|
cont := d.Get("storage_container_name").(string)
|
|
|
|
|
|
|
|
log.Printf("[INFO] Creating blob %q in storage account %q", name, storageAccountName)
|
|
|
|
switch strings.ToLower(blobType) {
|
|
|
|
case "block":
|
|
|
|
err = blobClient.CreateBlockBlob(cont, name)
|
|
|
|
case "page":
|
|
|
|
size := int64(d.Get("size").(int))
|
|
|
|
err = blobClient.PutPageBlob(cont, name, size, map[string]string{})
|
|
|
|
}
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("Error creating storage blob on Azure: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
d.SetId(name)
|
|
|
|
return resourceArmStorageBlobRead(d, meta)
|
|
|
|
}
|
|
|
|
|
|
|
|
func resourceArmStorageBlobRead(d *schema.ResourceData, meta interface{}) error {
|
|
|
|
armClient := meta.(*ArmClient)
|
|
|
|
|
|
|
|
resourceGroupName := d.Get("resource_group_name").(string)
|
|
|
|
storageAccountName := d.Get("storage_account_name").(string)
|
|
|
|
|
2016-05-24 17:01:26 -05:00
|
|
|
blobClient, accountExists, err := armClient.getBlobStorageClientForStorageAccount(resourceGroupName, storageAccountName)
|
2016-01-26 14:45:18 -06:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2016-05-24 17:01:26 -05:00
|
|
|
if !accountExists {
|
|
|
|
log.Printf("[DEBUG] Storage account %q not found, removing blob %q from state", storageAccountName, d.Id())
|
|
|
|
d.SetId("")
|
|
|
|
return nil
|
|
|
|
}
|
2016-01-26 14:45:18 -06:00
|
|
|
|
|
|
|
exists, err := resourceArmStorageBlobExists(d, meta)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if !exists {
|
|
|
|
// Exists already removed this from state
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
name := d.Get("name").(string)
|
|
|
|
storageContainerName := d.Get("storage_container_name").(string)
|
|
|
|
|
|
|
|
url := blobClient.GetBlobURL(storageContainerName, name)
|
|
|
|
if url == "" {
|
|
|
|
log.Printf("[INFO] URL for %q is empty", name)
|
|
|
|
}
|
|
|
|
d.Set("url", url)
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func resourceArmStorageBlobExists(d *schema.ResourceData, meta interface{}) (bool, error) {
|
|
|
|
armClient := meta.(*ArmClient)
|
|
|
|
|
|
|
|
resourceGroupName := d.Get("resource_group_name").(string)
|
|
|
|
storageAccountName := d.Get("storage_account_name").(string)
|
|
|
|
|
2016-05-24 17:01:26 -05:00
|
|
|
blobClient, accountExists, err := armClient.getBlobStorageClientForStorageAccount(resourceGroupName, storageAccountName)
|
2016-01-26 14:45:18 -06:00
|
|
|
if err != nil {
|
|
|
|
return false, err
|
|
|
|
}
|
2016-05-24 17:01:26 -05:00
|
|
|
if !accountExists {
|
|
|
|
log.Printf("[DEBUG] Storage account %q not found, removing blob %q from state", storageAccountName, d.Id())
|
|
|
|
d.SetId("")
|
|
|
|
return false, nil
|
|
|
|
}
|
2016-01-26 14:45:18 -06:00
|
|
|
|
|
|
|
name := d.Get("name").(string)
|
|
|
|
storageContainerName := d.Get("storage_container_name").(string)
|
|
|
|
|
|
|
|
log.Printf("[INFO] Checking for existence of storage blob %q.", name)
|
|
|
|
exists, err := blobClient.BlobExists(storageContainerName, name)
|
|
|
|
if err != nil {
|
|
|
|
return false, fmt.Errorf("error testing existence of storage blob %q: %s", name, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if !exists {
|
|
|
|
log.Printf("[INFO] Storage blob %q no longer exists, removing from state...", name)
|
|
|
|
d.SetId("")
|
|
|
|
}
|
|
|
|
|
|
|
|
return exists, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func resourceArmStorageBlobDelete(d *schema.ResourceData, meta interface{}) error {
|
|
|
|
armClient := meta.(*ArmClient)
|
|
|
|
|
|
|
|
resourceGroupName := d.Get("resource_group_name").(string)
|
|
|
|
storageAccountName := d.Get("storage_account_name").(string)
|
|
|
|
|
2016-05-24 17:01:26 -05:00
|
|
|
blobClient, accountExists, err := armClient.getBlobStorageClientForStorageAccount(resourceGroupName, storageAccountName)
|
2016-01-26 14:45:18 -06:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2016-05-24 17:01:26 -05:00
|
|
|
if !accountExists {
|
|
|
|
log.Printf("[INFO]Storage Account %q doesn't exist so the blob won't exist", storageAccountName)
|
|
|
|
return nil
|
|
|
|
}
|
2016-01-26 14:45:18 -06:00
|
|
|
|
|
|
|
name := d.Get("name").(string)
|
|
|
|
storageContainerName := d.Get("storage_container_name").(string)
|
|
|
|
|
|
|
|
log.Printf("[INFO] Deleting storage blob %q", name)
|
2016-06-01 15:17:21 -05:00
|
|
|
if _, err = blobClient.DeleteBlobIfExists(storageContainerName, name, map[string]string{}); err != nil {
|
2016-01-26 14:45:18 -06:00
|
|
|
return fmt.Errorf("Error deleting storage blob %q: %s", name, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
d.SetId("")
|
|
|
|
return nil
|
|
|
|
}
|