github.com/icebourg/terraform@v0.6.5-0.20151015205227-263cc1b85535/builtin/providers/google/provider.go (about)

     1  package google
     2  
     3  import (
     4  	"encoding/json"
     5  	"fmt"
     6  	"os"
     7  
     8  	"github.com/hashicorp/terraform/helper/schema"
     9  	"github.com/hashicorp/terraform/terraform"
    10  )
    11  
    12  // Provider returns a terraform.ResourceProvider.
    13  func Provider() terraform.ResourceProvider {
    14  	return &schema.Provider{
    15  		Schema: map[string]*schema.Schema{
    16  			"account_file": &schema.Schema{
    17  				Type:         schema.TypeString,
    18  				Required:     true,
    19  				DefaultFunc:  schema.EnvDefaultFunc("GOOGLE_ACCOUNT_FILE", nil),
    20  				ValidateFunc: validateAccountFile,
    21  			},
    22  
    23  			"project": &schema.Schema{
    24  				Type:        schema.TypeString,
    25  				Required:    true,
    26  				DefaultFunc: schema.EnvDefaultFunc("GOOGLE_PROJECT", nil),
    27  			},
    28  
    29  			"region": &schema.Schema{
    30  				Type:        schema.TypeString,
    31  				Required:    true,
    32  				DefaultFunc: schema.EnvDefaultFunc("GOOGLE_REGION", nil),
    33  			},
    34  		},
    35  
    36  		ResourcesMap: map[string]*schema.Resource{
    37  			"google_compute_autoscaler":             resourceComputeAutoscaler(),
    38  			"google_compute_address":                resourceComputeAddress(),
    39  			"google_compute_backend_service":        resourceComputeBackendService(),
    40  			"google_compute_disk":                   resourceComputeDisk(),
    41  			"google_compute_firewall":               resourceComputeFirewall(),
    42  			"google_compute_forwarding_rule":        resourceComputeForwardingRule(),
    43  			"google_compute_http_health_check":      resourceComputeHttpHealthCheck(),
    44  			"google_compute_instance":               resourceComputeInstance(),
    45  			"google_compute_instance_template":      resourceComputeInstanceTemplate(),
    46  			"google_compute_network":                resourceComputeNetwork(),
    47  			"google_compute_project_metadata":       resourceComputeProjectMetadata(),
    48  			"google_compute_route":                  resourceComputeRoute(),
    49  			"google_compute_target_pool":            resourceComputeTargetPool(),
    50  			"google_compute_vpn_gateway":            resourceComputeVpnGateway(),
    51  			"google_compute_vpn_tunnel":             resourceComputeVpnTunnel(),
    52  			"google_container_cluster":              resourceContainerCluster(),
    53  			"google_dns_managed_zone":               resourceDnsManagedZone(),
    54  			"google_dns_record_set":                 resourceDnsRecordSet(),
    55  			"google_compute_instance_group_manager": resourceComputeInstanceGroupManager(),
    56  			"google_storage_bucket":                 resourceStorageBucket(),
    57  			"google_storage_bucket_acl":             resourceStorageBucketAcl(),
    58  			"google_storage_bucket_object":          resourceStorageBucketObject(),
    59  			"google_storage_object_acl":             resourceStorageObjectAcl(),
    60  		},
    61  
    62  		ConfigureFunc: providerConfigure,
    63  	}
    64  }
    65  
    66  func providerConfigure(d *schema.ResourceData) (interface{}, error) {
    67  	config := Config{
    68  		AccountFile: d.Get("account_file").(string),
    69  		Project:     d.Get("project").(string),
    70  		Region:      d.Get("region").(string),
    71  	}
    72  
    73  	if err := config.loadAndValidate(); err != nil {
    74  		return nil, err
    75  	}
    76  
    77  	return &config, nil
    78  }
    79  
    80  func validateAccountFile(v interface{}, k string) (warnings []string, errors []error) {
    81  	value := v.(string)
    82  
    83  	if value == "" {
    84  		return
    85  	}
    86  
    87  	var account accountFile
    88  	if err := json.Unmarshal([]byte(value), &account); err != nil {
    89  		warnings = append(warnings, `
    90  account_file is not valid JSON, so we are assuming it is a file path. This
    91  support will be removed in the future. Please update your configuration to use
    92  ${file("filename.json")} instead.`)
    93  	} else {
    94  		return
    95  	}
    96  
    97  	if _, err := os.Stat(value); err != nil {
    98  		errors = append(errors,
    99  			fmt.Errorf(
   100  				"account_file path could not be read from '%s': %s",
   101  				value,
   102  				err))
   103  	}
   104  
   105  	return
   106  }