mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-02 12:17:39 -06:00
b862cd2ccb
* Terraform ProfitBricks Builder * make fmt * Merge remote-tracking branch 'upstream/master' into terraform-provider-profitbricks # Conflicts: # command/internal_plugin_list.go * Addressing PR remarks * Removed importers * Added ProfitBricks Data Sources * Added documentation * Updated to REST v3: - nat parameter for Nics - availabilityZone for Volumes Minor code clean up * Minor code clean up * Fixed typo in volume documentation * make fmt * Addressing requested changes * Added a step in load balancer tests in CheckDestroy where we are making sure that the test doesn't leave dangling resources in ProfitBricks * Changed expected image name * Fixed data center test Code clean up
70 lines
1.6 KiB
Go
70 lines
1.6 KiB
Go
package profitbricks
|
|
|
|
import (
|
|
"fmt"
|
|
"github.com/hashicorp/terraform/helper/schema"
|
|
"github.com/profitbricks/profitbricks-sdk-go"
|
|
"log"
|
|
"strings"
|
|
)
|
|
|
|
func dataSourceDataCenter() *schema.Resource {
|
|
return &schema.Resource{
|
|
Read: dataSourceDataCenterRead,
|
|
Schema: map[string]*schema.Schema{
|
|
"name": {
|
|
Type: schema.TypeString,
|
|
Required: true,
|
|
},
|
|
"location": {
|
|
Type: schema.TypeString,
|
|
Optional: true,
|
|
},
|
|
},
|
|
}
|
|
}
|
|
|
|
func dataSourceDataCenterRead(d *schema.ResourceData, meta interface{}) error {
|
|
datacenters := profitbricks.ListDatacenters()
|
|
|
|
if datacenters.StatusCode > 299 {
|
|
return fmt.Errorf("An error occured while fetching datacenters %s", datacenters.Response)
|
|
}
|
|
|
|
name := d.Get("name").(string)
|
|
location, locationOk := d.GetOk("location")
|
|
|
|
results := []profitbricks.Datacenter{}
|
|
|
|
for _, dc := range datacenters.Items {
|
|
if dc.Properties.Name == name || strings.Contains(dc.Properties.Name, name) {
|
|
results = append(results, dc)
|
|
}
|
|
}
|
|
|
|
if locationOk {
|
|
log.Printf("[INFO] searching dcs by location***********")
|
|
locationResults := []profitbricks.Datacenter{}
|
|
for _, dc := range results {
|
|
if dc.Properties.Location == location.(string) {
|
|
locationResults = append(locationResults, dc)
|
|
}
|
|
}
|
|
results = locationResults
|
|
}
|
|
log.Printf("[INFO] Results length %d *************", len(results))
|
|
|
|
if len(results) > 1 {
|
|
log.Printf("[INFO] Results length greater than 1")
|
|
return fmt.Errorf("There is more than one datacenters that match the search criteria")
|
|
}
|
|
|
|
if len(results) == 0 {
|
|
return fmt.Errorf("There are no datacenters that match the search criteria")
|
|
}
|
|
|
|
d.SetId(results[0].Id)
|
|
|
|
return nil
|
|
}
|