Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

New Resource & Datasources: azurerm_automation_variable_[bool|datetime|string|int] #3310

Merged
merged 31 commits into from
May 10, 2019
Merged
Show file tree
Hide file tree
Changes from 23 commits
Commits
Show all changes
31 commits
Select commit Hold shift + click to select a range
63f2150
Register automation variable client.
Feb 18, 2019
bab63c4
Implement common parse value function for AutoVar
Apr 25, 2019
8406774
Updates to string variable
WodansSon Apr 25, 2019
4351476
Updated error msgs
WodansSon Apr 25, 2019
7438635
Fix build break
WodansSon Apr 25, 2019
5524afc
Persist RG name and AA name to state file
WodansSon Apr 25, 2019
0c7c1ed
Fix time skew issue
WodansSon Apr 25, 2019
3758c93
Add null variable resource
WodansSon Apr 25, 2019
8305a48
Added bool variable
WodansSon Apr 26, 2019
4468f36
Added azurerm_automation_int_variable
WodansSon Apr 26, 2019
9823ecb
Added datetime variable
WodansSon Apr 27, 2019
49ef0b0
Update azurerm/helpers/azure/automation_variable.go
katbyte Apr 29, 2019
3b6bfe8
Update website/docs/r/automation_bool_variable.html.markdown
katbyte Apr 29, 2019
972720b
Changes per PR comments
WodansSon May 1, 2019
e256005
Changes requested per PR comments
WodansSon May 2, 2019
223ef2a
Changes requested in PR
WodansSon May 7, 2019
f8fd819
Fix test cases
WodansSon May 8, 2019
4a61e04
Add support for data sources
WodansSon May 9, 2019
491e86c
Merge branch 'master' into resource_automation_variable
WodansSon May 9, 2019
8980a5c
Resolve conficts
WodansSon May 9, 2019
aac306e
addressed minor PR comment
katbyte May 10, 2019
e39b34c
put var type at the end of all names
katbyte May 10, 2019
e15f577
missed some file renames
katbyte May 10, 2019
23c1364
fixed tests
katbyte May 10, 2019
3bcc130
fixed test names to conform to new format
katbyte May 10, 2019
c12c1c4
Update azurerm/automation_variable.go
WodansSon May 10, 2019
86cda18
Update azurerm/helpers/azure/automation_variable.go
WodansSon May 10, 2019
b49b77e
Update azurerm/automation_variable.go
WodansSon May 10, 2019
d8dc65c
Update azurerm/helpers/azure/automation_variable.go
WodansSon May 10, 2019
3afaddc
fixed datasource doc file names and TOC
katbyte May 10, 2019
a44be20
Merge branch 'resource_automation_variable' of github.com:terraform-p…
katbyte May 10, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
299 changes: 299 additions & 0 deletions azurerm/automation_variable.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,299 @@
package azurerm

import (
"fmt"
"log"
"regexp"
"strconv"
"strings"
"time"

"github.com/Azure/azure-sdk-for-go/services/automation/mgmt/2015-10-31/automation"
"github.com/hashicorp/terraform/helper/schema"
"github.com/terraform-providers/terraform-provider-azurerm/azurerm/helpers/tf"
"github.com/terraform-providers/terraform-provider-azurerm/azurerm/helpers/validate"
"github.com/terraform-providers/terraform-provider-azurerm/azurerm/utils"
)

func parseAzureAutomationVariableValue(resource string, input *string) (interface{}, error) {
if input == nil {
if resource != "azurerm_automation_null_variable" {
WodansSon marked this conversation as resolved.
Show resolved Hide resolved
return nil, fmt.Errorf("Expected value \"nil\" to be %q, actual type is \"azurerm_automation_null_variable\"", resource)
WodansSon marked this conversation as resolved.
Show resolved Hide resolved
}
return nil, nil
}

var value interface{}
var err error
actualResource := "Unknown"
datePattern := regexp.MustCompile(`"\\/Date\((-?[0-9]+)\)\\/"`)
matches := datePattern.FindStringSubmatch(*input)

if len(matches) == 2 && matches[0] == *input {
if ticks, err := strconv.ParseInt(matches[1], 10, 64); err == nil {
value = time.Unix(ticks/1000, ticks%1000*1000000).In(time.UTC)
actualResource = "azurerm_automation_variable_datetime"
}
} else if value, err = strconv.Unquote(*input); err == nil {
actualResource = "azurerm_automation_variable_string"
} else if value, err = strconv.ParseBool(*input); err == nil {
actualResource = "azurerm_automation_variable_bool"
} else if value, err = strconv.ParseInt(*input, 10, 32); err == nil {
value = int32(value.(int64))
actualResource = "azurerm_automation_variable_int"
}

if actualResource != resource {
return nil, fmt.Errorf("Expected value %q to be %q, actual type is %q", *input, resource, actualResource)
}
return value, nil
}

func resourceAutomationVariableCommonSchema(attType schema.ValueType, validateFunc schema.SchemaValidateFunc) map[string]*schema.Schema {
return map[string]*schema.Schema{
"resource_group_name": resourceGroupNameSchema(),

"name": {
Type: schema.TypeString,
Required: true,
ForceNew: true,
ValidateFunc: validate.NoEmptyStrings,
},

"automation_account_name": {
Type: schema.TypeString,
Required: true,
ForceNew: true,
ValidateFunc: validate.NoEmptyStrings,
},

"description": {
Type: schema.TypeString,
Optional: true,
},

"encrypted": {
Type: schema.TypeBool,
Optional: true,
Default: false,
},

"value": {
Type: attType,
Optional: true,
ValidateFunc: validateFunc,
},
}
}

func datasourceAutomationVariableCommonSchema(attType schema.ValueType) map[string]*schema.Schema {
return map[string]*schema.Schema{
"resource_group_name": resourceGroupNameSchema(),

"name": {
Type: schema.TypeString,
Required: true,
ValidateFunc: validate.NoEmptyStrings,
},

"automation_account_name": {
Type: schema.TypeString,
Required: true,
ValidateFunc: validate.NoEmptyStrings,
},

"description": {
Type: schema.TypeString,
Computed: true,
},

"encrypted": {
Type: schema.TypeBool,
Computed: true,
},

"value": {
Type: attType,
Computed: true,
},
}
}

func resourceAutomationVariableCreateUpdate(d *schema.ResourceData, meta interface{}, varType string) error {
client := meta.(*ArmClient).automationVariableClient
ctx := meta.(*ArmClient).StopContext

name := d.Get("name").(string)
resourceGroup := d.Get("resource_group_name").(string)
accountName := d.Get("automation_account_name").(string)
varTypeLower := strings.ToLower(varType)

if requireResourcesToBeImported {
resp, err := client.Get(ctx, resourceGroup, accountName, name)
if err != nil {
if !utils.ResponseWasNotFound(resp.Response) {
return fmt.Errorf("Error checking for present of existing Automation %s Variable %q (Automation Account Name %q / Resource Group %q): %+v", varType, name, accountName, resourceGroup, err)
}
}

if !utils.ResponseWasNotFound(resp.Response) {
return tf.ImportAsExistsError(fmt.Sprintf("azurerm_automation_%s_variable", varTypeLower), *resp.ID)
}
}

description := d.Get("description").(string)
encrypted := d.Get("encrypted").(bool)
value := ""

if varTypeLower == "datetime" {
vTime, parseErr := time.Parse(time.RFC3339, d.Get("value").(string))
if parseErr != nil {
return fmt.Errorf("Error invalid time format: %+v", parseErr)
}
value = fmt.Sprintf("\"\\/Date(%d)\\/\"", vTime.UnixNano()/1000000)
} else if varTypeLower == "bool" {
value = strconv.FormatBool(d.Get("value").(bool))
} else if varTypeLower == "int" {
value = strconv.Itoa(d.Get("value").(int))
} else if varTypeLower == "string" {
value = strconv.Quote(d.Get("value").(string))
}

parameters := automation.VariableCreateOrUpdateParameters{
Name: utils.String(name),
VariableCreateOrUpdateProperties: &automation.VariableCreateOrUpdateProperties{
Description: utils.String(description),
IsEncrypted: utils.Bool(encrypted),
},
}

if varTypeLower != "null" {
parameters.VariableCreateOrUpdateProperties.Value = utils.String(value)
}

if _, err := client.CreateOrUpdate(ctx, resourceGroup, accountName, name, parameters); err != nil {
return fmt.Errorf("Error creating Automation %s Variable %q (Automation Account Name %q / Resource Group %q): %+v", varType, name, accountName, resourceGroup, err)
}

resp, err := client.Get(ctx, resourceGroup, accountName, name)
if err != nil {
return fmt.Errorf("Error retrieving Automation %s Variable %q (Automation Account Name %q / Resource Group %q): %+v", varType, name, accountName, resourceGroup, err)
}
if resp.ID == nil {
return fmt.Errorf("Cannot read Automation %s Variable %q (Automation Account Name %q / Resource Group %q) ID", varType, name, accountName, resourceGroup)
}
d.SetId(*resp.ID)

return resourceAutomationVariableRead(d, meta, varType)
}

func resourceAutomationVariableRead(d *schema.ResourceData, meta interface{}, varType string) error {
client := meta.(*ArmClient).automationVariableClient
ctx := meta.(*ArmClient).StopContext

id, err := parseAzureResourceID(d.Id())
if err != nil {
return err
}

resourceGroup := id.ResourceGroup
accountName := id.Path["automationAccounts"]
name := id.Path["variables"]
varTypeLower := strings.ToLower(varType)

resp, err := client.Get(ctx, resourceGroup, accountName, name)
if err != nil {
if utils.ResponseWasNotFound(resp.Response) {
log.Printf("[INFO] Automation %s Variable %q does not exist - removing from state", varType, d.Id())
d.SetId("")
return nil
}
return fmt.Errorf("Error reading Automation %s Variable %q (Automation Account Name %q / Resource Group %q): %+v", varType, name, accountName, resourceGroup, err)
}

d.Set("name", resp.Name)
d.Set("resource_group_name", resourceGroup)
d.Set("automation_account_name", accountName)
if properties := resp.VariableProperties; properties != nil {
d.Set("description", properties.Description)
d.Set("encrypted", properties.IsEncrypted)
if !d.Get("encrypted").(bool) {
value, err := parseAzureAutomationVariableValue(fmt.Sprintf("azurerm_automation_%s_variable", varTypeLower), properties.Value)
if err != nil {
return err
}

if varTypeLower == "datetime" {
d.Set("value", value.(time.Time).Format("2006-01-02T15:04:05.999Z"))
} else if varTypeLower != "null" {
d.Set("value", value)
}
}
}

return nil
}

func datasourceAutomationVariableRead(d *schema.ResourceData, meta interface{}, varType string) error {
client := meta.(*ArmClient).automationVariableClient
ctx := meta.(*ArmClient).StopContext

resourceGroup := d.Get("resource_group_name").(string)
accountName := d.Get("automation_account_name").(string)
name := d.Get("name").(string)
varTypeLower := strings.ToLower(varType)

resp, err := client.Get(ctx, resourceGroup, accountName, name)
if err != nil {
if utils.ResponseWasNotFound(resp.Response) {
log.Printf("[INFO] Automation %s Variable %q does not exist - removing from state", varType, d.Id())
d.SetId("")
return nil
}
return fmt.Errorf("Error reading Automation %s Variable %q (Automation Account Name %q / Resource Group %q): %+v", varType, name, accountName, resourceGroup, err)
}

d.SetId(*resp.ID)

d.Set("name", resp.Name)
d.Set("resource_group_name", resourceGroup)
d.Set("automation_account_name", accountName)
if properties := resp.VariableProperties; properties != nil {
d.Set("description", properties.Description)
d.Set("encrypted", properties.IsEncrypted)
if !d.Get("encrypted").(bool) {
value, err := parseAzureAutomationVariableValue(fmt.Sprintf("azurerm_automation_%s_variable", varTypeLower), properties.Value)
if err != nil {
return err
}

if varTypeLower == "datetime" {
d.Set("value", value.(time.Time).Format("2006-01-02T15:04:05.999Z"))
} else if varTypeLower != "null" {
d.Set("value", value)
}
}
}

return nil
}

func resourceAutomationVariableDelete(d *schema.ResourceData, meta interface{}, varType string) error {
client := meta.(*ArmClient).automationVariableClient
ctx := meta.(*ArmClient).StopContext

id, err := parseAzureResourceID(d.Id())
if err != nil {
return err
}

resourceGroup := id.ResourceGroup
accountName := id.Path["automationAccounts"]
name := id.Path["variables"]

if _, err := client.Delete(ctx, resourceGroup, accountName, name); err != nil {
return fmt.Errorf("Error deleting Automation %s Variable %q (Automation Account Name %q / Resource Group %q): %+v", varType, name, accountName, resourceGroup, err)
}

return nil
}
Loading