github.com/vtorhonen/terraform@v0.9.0-beta2.0.20170307220345-5d894e4ffda7/builtin/providers/azurerm/resource_arm_sql_server.go (about) 1 package azurerm 2 3 import ( 4 "fmt" 5 "log" 6 7 "github.com/hashicorp/terraform/helper/schema" 8 "github.com/jen20/riviera/azure" 9 "github.com/jen20/riviera/sql" 10 ) 11 12 func resourceArmSqlServer() *schema.Resource { 13 return &schema.Resource{ 14 Create: resourceArmSqlServerCreate, 15 Read: resourceArmSqlServerRead, 16 Update: resourceArmSqlServerCreate, 17 Delete: resourceArmSqlServerDelete, 18 Importer: &schema.ResourceImporter{ 19 State: schema.ImportStatePassthrough, 20 }, 21 22 Schema: map[string]*schema.Schema{ 23 "name": &schema.Schema{ 24 Type: schema.TypeString, 25 Required: true, 26 ForceNew: true, 27 }, 28 29 "location": locationSchema(), 30 31 "resource_group_name": &schema.Schema{ 32 Type: schema.TypeString, 33 Required: true, 34 ForceNew: true, 35 }, 36 37 "version": &schema.Schema{ 38 Type: schema.TypeString, 39 Required: true, 40 }, 41 42 "administrator_login": &schema.Schema{ 43 Type: schema.TypeString, 44 Required: true, 45 }, 46 47 "administrator_login_password": &schema.Schema{ 48 Type: schema.TypeString, 49 Required: true, 50 Sensitive: true, 51 }, 52 53 "fully_qualified_domain_name": &schema.Schema{ 54 Type: schema.TypeString, 55 Computed: true, 56 }, 57 58 "tags": tagsSchema(), 59 }, 60 } 61 } 62 63 func resourceArmSqlServerCreate(d *schema.ResourceData, meta interface{}) error { 64 client := meta.(*ArmClient) 65 rivieraClient := client.rivieraClient 66 67 tags := d.Get("tags").(map[string]interface{}) 68 expandedTags := expandTags(tags) 69 70 createRequest := rivieraClient.NewRequest() 71 createRequest.Command = &sql.CreateOrUpdateServer{ 72 Name: d.Get("name").(string), 73 Location: d.Get("location").(string), 74 ResourceGroupName: d.Get("resource_group_name").(string), 75 AdministratorLogin: azure.String(d.Get("administrator_login").(string)), 76 AdministratorLoginPassword: azure.String(d.Get("administrator_login_password").(string)), 77 Version: azure.String(d.Get("version").(string)), 78 Tags: *expandedTags, 79 } 80 81 createResponse, err := createRequest.Execute() 82 if err != nil { 83 return fmt.Errorf("Error creating SQL Server: %s", err) 84 } 85 if !createResponse.IsSuccessful() { 86 return fmt.Errorf("Error creating SQL Server: %s", createResponse.Error) 87 } 88 89 readRequest := rivieraClient.NewRequest() 90 readRequest.Command = &sql.GetServer{ 91 Name: d.Get("name").(string), 92 ResourceGroupName: d.Get("resource_group_name").(string), 93 } 94 95 readResponse, err := readRequest.Execute() 96 if err != nil { 97 return fmt.Errorf("Error reading SQL Server: %s", err) 98 } 99 if !readResponse.IsSuccessful() { 100 return fmt.Errorf("Error reading SQL Server: %s", readResponse.Error) 101 } 102 103 resp := readResponse.Parsed.(*sql.GetServerResponse) 104 d.SetId(*resp.ID) 105 106 return resourceArmSqlServerRead(d, meta) 107 } 108 109 func resourceArmSqlServerRead(d *schema.ResourceData, meta interface{}) error { 110 client := meta.(*ArmClient) 111 rivieraClient := client.rivieraClient 112 113 id, err := parseAzureResourceID(d.Id()) 114 if err != nil { 115 return err 116 } 117 118 readRequest := rivieraClient.NewRequestForURI(d.Id()) 119 readRequest.Command = &sql.GetServer{} 120 121 readResponse, err := readRequest.Execute() 122 if err != nil { 123 return fmt.Errorf("Error reading SQL Server: %s", err) 124 } 125 if !readResponse.IsSuccessful() { 126 log.Printf("[INFO] Error reading SQL Server %q - removing from state", d.Id()) 127 d.SetId("") 128 return fmt.Errorf("Error reading SQL Server: %s", readResponse.Error) 129 } 130 131 resp := readResponse.Parsed.(*sql.GetServerResponse) 132 133 d.Set("name", id.Path["servers"]) 134 d.Set("resource_group_name", id.ResourceGroup) 135 d.Set("location", azureRMNormalizeLocation(*resp.Location)) 136 d.Set("fully_qualified_domain_name", resp.FullyQualifiedDomainName) 137 d.Set("administrator_login", resp.AdministratorLogin) 138 d.Set("version", resp.Version) 139 140 flattenAndSetTags(d, resp.Tags) 141 142 return nil 143 } 144 145 func resourceArmSqlServerDelete(d *schema.ResourceData, meta interface{}) error { 146 client := meta.(*ArmClient) 147 rivieraClient := client.rivieraClient 148 149 deleteRequest := rivieraClient.NewRequestForURI(d.Id()) 150 deleteRequest.Command = &sql.DeleteServer{} 151 152 deleteResponse, err := deleteRequest.Execute() 153 if err != nil { 154 return fmt.Errorf("Error deleting SQL Server: %s", err) 155 } 156 if !deleteResponse.IsSuccessful() { 157 return fmt.Errorf("Error deleting SQL Server: %s", deleteResponse.Error) 158 } 159 160 return nil 161 }