github.com/atsaki/terraform@v0.4.3-0.20150919165407-25bba5967654/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_object":          resourceStorageBucketObject(),
    58  		},
    59  
    60  		ConfigureFunc: providerConfigure,
    61  	}
    62  }
    63  
    64  func providerConfigure(d *schema.ResourceData) (interface{}, error) {
    65  	config := Config{
    66  		AccountFile: d.Get("account_file").(string),
    67  		Project:     d.Get("project").(string),
    68  		Region:      d.Get("region").(string),
    69  	}
    70  
    71  	if err := config.loadAndValidate(); err != nil {
    72  		return nil, err
    73  	}
    74  
    75  	return &config, nil
    76  }
    77  
    78  func validateAccountFile(v interface{}, k string) (warnings []string, errors []error) {
    79  	value := v.(string)
    80  
    81  	if value == "" {
    82  		return
    83  	}
    84  
    85  	var account accountFile
    86  	if err := json.Unmarshal([]byte(value), &account); err != nil {
    87  		warnings = append(warnings, `
    88  account_file is not valid JSON, so we are assuming it is a file path. This
    89  support will be removed in the future. Please update your configuration to use
    90  ${file("filename.json")} instead.`)
    91  	} else {
    92  		return
    93  	}
    94  
    95  	if _, err := os.Stat(value); err != nil {
    96  		errors = append(errors,
    97  			fmt.Errorf(
    98  				"account_file path could not be read from '%s': %s",
    99  				value,
   100  				err))
   101  	}
   102  
   103  	return
   104  }