terraform-provider-google/provider.go

59 lines
1.4 KiB
Go
Raw Normal View History

2014-08-25 18:48:20 +00:00
package google
import (
"github.com/hashicorp/terraform/helper/schema"
)
// Provider returns a terraform.ResourceProvider.
func Provider() *schema.Provider {
return &schema.Provider{
Schema: map[string]*schema.Schema{
"account_file": &schema.Schema{
Type: schema.TypeString,
Required: true,
},
"client_secrets_file": &schema.Schema{
Type: schema.TypeString,
Required: true,
},
"project": &schema.Schema{
Type: schema.TypeString,
Required: true,
},
"region": &schema.Schema{
Type: schema.TypeString,
Required: true,
},
2014-08-25 18:48:20 +00:00
},
ResourcesMap: map[string]*schema.Resource{
"google_compute_address": resourceComputeAddress(),
2014-08-25 23:23:28 +00:00
"google_compute_disk": resourceComputeDisk(),
2014-08-26 05:09:38 +00:00
"google_compute_firewall": resourceComputeFirewall(),
2014-08-25 18:48:20 +00:00
"google_compute_instance": resourceComputeInstance(),
2014-08-26 04:41:15 +00:00
"google_compute_network": resourceComputeNetwork(),
2014-08-26 05:39:29 +00:00
"google_compute_route": resourceComputeRoute(),
2014-08-25 18:48:20 +00:00
},
ConfigureFunc: providerConfigure,
}
}
func providerConfigure(d *schema.ResourceData) (interface{}, error) {
config := Config{
AccountFile: d.Get("account_file").(string),
ClientSecretsFile: d.Get("client_secrets_file").(string),
Project: d.Get("project").(string),
Region: d.Get("region").(string),
2014-08-25 18:48:20 +00:00
}
if err := config.loadAndValidate(); err != nil {
return nil, err
}
return &config, nil
2014-08-25 18:48:20 +00:00
}