2014-08-25 18:48:20 +00:00
|
|
|
package google
|
|
|
|
|
|
|
|
import (
|
2015-07-27 19:35:52 +00:00
|
|
|
"encoding/json"
|
|
|
|
"fmt"
|
2017-12-08 21:57:55 +00:00
|
|
|
"os"
|
2015-07-27 19:35:52 +00:00
|
|
|
|
2017-01-27 14:32:42 +00:00
|
|
|
"github.com/hashicorp/terraform/helper/mutexkv"
|
2014-08-25 18:48:20 +00:00
|
|
|
"github.com/hashicorp/terraform/helper/schema"
|
2014-09-28 18:51:39 +00:00
|
|
|
"github.com/hashicorp/terraform/terraform"
|
2014-08-25 18:48:20 +00:00
|
|
|
)
|
|
|
|
|
2017-01-27 14:32:42 +00:00
|
|
|
// Global MutexKV
|
|
|
|
var mutexKV = mutexkv.NewMutexKV()
|
|
|
|
|
2014-08-25 18:48:20 +00:00
|
|
|
// Provider returns a terraform.ResourceProvider.
|
2014-09-28 18:51:39 +00:00
|
|
|
func Provider() terraform.ResourceProvider {
|
2014-08-25 18:48:20 +00:00
|
|
|
return &schema.Provider{
|
|
|
|
Schema: map[string]*schema.Schema{
|
2015-11-12 22:13:07 +00:00
|
|
|
"credentials": &schema.Schema{
|
2016-04-04 21:56:35 +00:00
|
|
|
Type: schema.TypeString,
|
|
|
|
Optional: true,
|
|
|
|
DefaultFunc: schema.MultiEnvDefaultFunc([]string{
|
|
|
|
"GOOGLE_CREDENTIALS",
|
|
|
|
"GOOGLE_CLOUD_KEYFILE_JSON",
|
2016-04-10 23:31:40 +00:00
|
|
|
"GCLOUD_KEYFILE_JSON",
|
2016-04-04 21:56:35 +00:00
|
|
|
}, nil),
|
2015-11-12 22:13:07 +00:00
|
|
|
ValidateFunc: validateCredentials,
|
2015-07-23 20:53:44 +00:00
|
|
|
},
|
|
|
|
|
2014-08-25 19:55:08 +00:00
|
|
|
"project": &schema.Schema{
|
2016-04-10 23:31:40 +00:00
|
|
|
Type: schema.TypeString,
|
|
|
|
Optional: true,
|
|
|
|
DefaultFunc: schema.MultiEnvDefaultFunc([]string{
|
|
|
|
"GOOGLE_PROJECT",
|
|
|
|
"GCLOUD_PROJECT",
|
|
|
|
"CLOUDSDK_CORE_PROJECT",
|
|
|
|
}, nil),
|
2014-08-25 19:55:08 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
"region": &schema.Schema{
|
2016-04-10 23:31:40 +00:00
|
|
|
Type: schema.TypeString,
|
2018-01-03 22:09:46 +00:00
|
|
|
Optional: true,
|
2016-04-10 23:31:40 +00:00
|
|
|
DefaultFunc: schema.MultiEnvDefaultFunc([]string{
|
|
|
|
"GOOGLE_REGION",
|
|
|
|
"GCLOUD_REGION",
|
|
|
|
"CLOUDSDK_COMPUTE_REGION",
|
|
|
|
}, nil),
|
2014-08-25 19:55:08 +00:00
|
|
|
},
|
2017-12-06 22:30:04 +00:00
|
|
|
|
|
|
|
"zone": &schema.Schema{
|
|
|
|
Type: schema.TypeString,
|
|
|
|
Optional: true,
|
|
|
|
DefaultFunc: schema.MultiEnvDefaultFunc([]string{
|
|
|
|
"GOOGLE_ZONE",
|
|
|
|
"GCLOUD_ZONE",
|
|
|
|
"CLOUDSDK_COMPUTE_ZONE",
|
|
|
|
}, nil),
|
|
|
|
},
|
2014-08-25 18:48:20 +00:00
|
|
|
},
|
|
|
|
|
2016-08-10 04:44:53 +00:00
|
|
|
DataSourcesMap: map[string]*schema.Resource{
|
2018-02-21 21:37:23 +00:00
|
|
|
"google_active_folder": dataSourceGoogleActiveFolder(),
|
|
|
|
"google_billing_account": dataSourceGoogleBillingAccount(),
|
|
|
|
"google_dns_managed_zone": dataSourceDnsManagedZone(),
|
|
|
|
"google_client_config": dataSourceGoogleClientConfig(),
|
|
|
|
"google_cloudfunctions_function": dataSourceGoogleCloudFunctionsFunction(),
|
|
|
|
"google_compute_address": dataSourceGoogleComputeAddress(),
|
2018-03-12 16:41:15 +00:00
|
|
|
"google_compute_default_service_account": dataSourceGoogleComputeDefaultServiceAccount(),
|
2018-02-21 21:37:23 +00:00
|
|
|
"google_compute_image": dataSourceGoogleComputeImage(),
|
|
|
|
"google_compute_global_address": dataSourceGoogleComputeGlobalAddress(),
|
|
|
|
"google_compute_lb_ip_ranges": dataSourceGoogleComputeLbIpRanges(),
|
|
|
|
"google_compute_network": dataSourceGoogleComputeNetwork(),
|
2018-02-28 20:37:24 +00:00
|
|
|
"google_project": dataSourceGoogleProject(),
|
2018-02-21 21:37:23 +00:00
|
|
|
"google_compute_subnetwork": dataSourceGoogleComputeSubnetwork(),
|
|
|
|
"google_compute_zones": dataSourceGoogleComputeZones(),
|
|
|
|
"google_compute_instance_group": dataSourceGoogleComputeInstanceGroup(),
|
|
|
|
"google_compute_region_instance_group": dataSourceGoogleComputeRegionInstanceGroup(),
|
|
|
|
"google_compute_vpn_gateway": dataSourceGoogleComputeVpnGateway(),
|
|
|
|
"google_compute_forwarding_rule": dataSourceGoogleComputeForwardingRule(),
|
|
|
|
"google_container_cluster": dataSourceGoogleContainerCluster(),
|
|
|
|
"google_container_engine_versions": dataSourceGoogleContainerEngineVersions(),
|
|
|
|
"google_container_registry_repository": dataSourceGoogleContainerRepo(),
|
|
|
|
"google_container_registry_image": dataSourceGoogleContainerImage(),
|
|
|
|
"google_iam_policy": dataSourceGoogleIamPolicy(),
|
|
|
|
"google_kms_secret": dataSourceGoogleKmsSecret(),
|
|
|
|
"google_organization": dataSourceGoogleOrganization(),
|
|
|
|
"google_storage_object_signed_url": dataSourceGoogleSignedUrl(),
|
|
|
|
"google_storage_project_service_account": dataSourceGoogleStorageProjectServiceAccount(),
|
2018-03-12 22:09:30 +00:00
|
|
|
"google_compute_backend_service": dataSourceGoogleComputeBackendService(),
|
2016-08-10 04:44:53 +00:00
|
|
|
},
|
|
|
|
|
2014-08-25 18:48:20 +00:00
|
|
|
ResourcesMap: map[string]*schema.Resource{
|
2017-09-09 00:02:32 +00:00
|
|
|
"google_bigquery_dataset": resourceBigQueryDataset(),
|
|
|
|
"google_bigquery_table": resourceBigQueryTable(),
|
|
|
|
"google_bigtable_instance": resourceBigtableInstance(),
|
|
|
|
"google_bigtable_table": resourceBigtableTable(),
|
2018-01-10 21:25:43 +00:00
|
|
|
"google_cloudfunctions_function": resourceCloudFunctionsFunction(),
|
2018-01-24 21:03:09 +00:00
|
|
|
"google_cloudiot_registry": resourceCloudIoTRegistry(),
|
2017-09-09 00:02:32 +00:00
|
|
|
"google_compute_autoscaler": resourceComputeAutoscaler(),
|
|
|
|
"google_compute_address": resourceComputeAddress(),
|
|
|
|
"google_compute_backend_bucket": resourceComputeBackendBucket(),
|
|
|
|
"google_compute_backend_service": resourceComputeBackendService(),
|
|
|
|
"google_compute_disk": resourceComputeDisk(),
|
|
|
|
"google_compute_snapshot": resourceComputeSnapshot(),
|
|
|
|
"google_compute_firewall": resourceComputeFirewall(),
|
|
|
|
"google_compute_forwarding_rule": resourceComputeForwardingRule(),
|
|
|
|
"google_compute_global_address": resourceComputeGlobalAddress(),
|
|
|
|
"google_compute_global_forwarding_rule": resourceComputeGlobalForwardingRule(),
|
|
|
|
"google_compute_health_check": resourceComputeHealthCheck(),
|
|
|
|
"google_compute_http_health_check": resourceComputeHttpHealthCheck(),
|
|
|
|
"google_compute_https_health_check": resourceComputeHttpsHealthCheck(),
|
|
|
|
"google_compute_image": resourceComputeImage(),
|
|
|
|
"google_compute_instance": resourceComputeInstance(),
|
|
|
|
"google_compute_instance_group": resourceComputeInstanceGroup(),
|
|
|
|
"google_compute_instance_group_manager": resourceComputeInstanceGroupManager(),
|
|
|
|
"google_compute_instance_template": resourceComputeInstanceTemplate(),
|
|
|
|
"google_compute_network": resourceComputeNetwork(),
|
|
|
|
"google_compute_network_peering": resourceComputeNetworkPeering(),
|
|
|
|
"google_compute_project_metadata": resourceComputeProjectMetadata(),
|
|
|
|
"google_compute_project_metadata_item": resourceComputeProjectMetadataItem(),
|
2017-10-09 17:59:38 +00:00
|
|
|
"google_compute_region_autoscaler": resourceComputeRegionAutoscaler(),
|
2017-09-09 00:02:32 +00:00
|
|
|
"google_compute_region_backend_service": resourceComputeRegionBackendService(),
|
|
|
|
"google_compute_region_instance_group_manager": resourceComputeRegionInstanceGroupManager(),
|
|
|
|
"google_compute_route": resourceComputeRoute(),
|
|
|
|
"google_compute_router": resourceComputeRouter(),
|
|
|
|
"google_compute_router_interface": resourceComputeRouterInterface(),
|
|
|
|
"google_compute_router_peer": resourceComputeRouterPeer(),
|
2017-10-11 19:51:09 +00:00
|
|
|
"google_compute_shared_vpc_host_project": resourceComputeSharedVpcHostProject(),
|
|
|
|
"google_compute_shared_vpc_service_project": resourceComputeSharedVpcServiceProject(),
|
2017-09-09 00:02:32 +00:00
|
|
|
"google_compute_ssl_certificate": resourceComputeSslCertificate(),
|
|
|
|
"google_compute_subnetwork": resourceComputeSubnetwork(),
|
|
|
|
"google_compute_target_http_proxy": resourceComputeTargetHttpProxy(),
|
|
|
|
"google_compute_target_https_proxy": resourceComputeTargetHttpsProxy(),
|
2017-10-05 17:27:56 +00:00
|
|
|
"google_compute_target_tcp_proxy": resourceComputeTargetTcpProxy(),
|
2017-10-13 18:02:42 +00:00
|
|
|
"google_compute_target_ssl_proxy": resourceComputeTargetSslProxy(),
|
2017-09-09 00:02:32 +00:00
|
|
|
"google_compute_target_pool": resourceComputeTargetPool(),
|
|
|
|
"google_compute_url_map": resourceComputeUrlMap(),
|
|
|
|
"google_compute_vpn_gateway": resourceComputeVpnGateway(),
|
|
|
|
"google_compute_vpn_tunnel": resourceComputeVpnTunnel(),
|
|
|
|
"google_container_cluster": resourceContainerCluster(),
|
|
|
|
"google_container_node_pool": resourceContainerNodePool(),
|
2018-01-10 22:38:15 +00:00
|
|
|
"google_dataflow_job": resourceDataflowJob(),
|
2017-10-30 23:41:37 +00:00
|
|
|
"google_dataproc_cluster": resourceDataprocCluster(),
|
2017-11-21 17:32:43 +00:00
|
|
|
"google_dataproc_job": resourceDataprocJob(),
|
2017-09-09 00:02:32 +00:00
|
|
|
"google_dns_managed_zone": resourceDnsManagedZone(),
|
|
|
|
"google_dns_record_set": resourceDnsRecordSet(),
|
2018-01-24 21:03:57 +00:00
|
|
|
"google_endpoints_service": resourceEndpointsService(),
|
2017-09-14 18:19:58 +00:00
|
|
|
"google_folder": resourceGoogleFolder(),
|
2018-02-13 20:49:51 +00:00
|
|
|
"google_folder_iam_binding": ResourceIamBindingWithImport(IamFolderSchema, NewFolderIamUpdater, FolderIdParseFunc),
|
|
|
|
"google_folder_iam_member": ResourceIamMemberWithImport(IamFolderSchema, NewFolderIamUpdater, FolderIdParseFunc),
|
2017-12-11 18:24:53 +00:00
|
|
|
"google_folder_iam_policy": ResourceIamPolicyWithImport(IamFolderSchema, NewFolderIamUpdater, FolderIdParseFunc),
|
2017-11-27 22:53:01 +00:00
|
|
|
"google_folder_organization_policy": resourceGoogleFolderOrganizationPolicy(),
|
2017-09-26 22:26:54 +00:00
|
|
|
"google_logging_billing_account_sink": resourceLoggingBillingAccountSink(),
|
2018-01-08 23:15:30 +00:00
|
|
|
"google_logging_organization_sink": resourceLoggingOrganizationSink(),
|
2017-10-03 16:26:19 +00:00
|
|
|
"google_logging_folder_sink": resourceLoggingFolderSink(),
|
2017-09-15 02:15:14 +00:00
|
|
|
"google_logging_project_sink": resourceLoggingProjectSink(),
|
2017-10-27 16:40:01 +00:00
|
|
|
"google_kms_key_ring": resourceKmsKeyRing(),
|
2017-12-11 18:24:53 +00:00
|
|
|
"google_kms_key_ring_iam_binding": ResourceIamBindingWithImport(IamKmsKeyRingSchema, NewKmsKeyRingIamUpdater, KeyRingIdParseFunc),
|
|
|
|
"google_kms_key_ring_iam_member": ResourceIamMemberWithImport(IamKmsKeyRingSchema, NewKmsKeyRingIamUpdater, KeyRingIdParseFunc),
|
|
|
|
"google_kms_key_ring_iam_policy": ResourceIamPolicyWithImport(IamKmsKeyRingSchema, NewKmsKeyRingIamUpdater, KeyRingIdParseFunc),
|
2017-11-14 21:21:25 +00:00
|
|
|
"google_kms_crypto_key": resourceKmsCryptoKey(),
|
2017-12-11 18:24:53 +00:00
|
|
|
"google_kms_crypto_key_iam_binding": ResourceIamBindingWithImport(IamKmsCryptoKeySchema, NewKmsCryptoKeyIamUpdater, CryptoIdParseFunc),
|
|
|
|
"google_kms_crypto_key_iam_member": ResourceIamMemberWithImport(IamKmsCryptoKeySchema, NewKmsCryptoKeyIamUpdater, CryptoIdParseFunc),
|
2017-09-09 00:02:32 +00:00
|
|
|
"google_sourcerepo_repository": resourceSourceRepoRepository(),
|
|
|
|
"google_spanner_instance": resourceSpannerInstance(),
|
|
|
|
"google_spanner_database": resourceSpannerDatabase(),
|
|
|
|
"google_sql_database": resourceSqlDatabase(),
|
|
|
|
"google_sql_database_instance": resourceSqlDatabaseInstance(),
|
|
|
|
"google_sql_user": resourceSqlUser(),
|
2017-12-11 18:24:53 +00:00
|
|
|
"google_organization_iam_binding": ResourceIamBindingWithImport(IamOrganizationSchema, NewOrganizationIamUpdater, OrgIdParseFunc),
|
2017-11-14 00:05:16 +00:00
|
|
|
"google_organization_iam_custom_role": resourceGoogleOrganizationIamCustomRole(),
|
2017-12-11 18:24:53 +00:00
|
|
|
"google_organization_iam_member": ResourceIamMemberWithImport(IamOrganizationSchema, NewOrganizationIamUpdater, OrgIdParseFunc),
|
2018-03-14 22:21:33 +00:00
|
|
|
"google_organization_iam_policy": ResourceIamPolicyWithImport(IamOrganizationSchema, NewOrganizationIamUpdater, OrgIdParseFunc),
|
2017-10-05 20:20:16 +00:00
|
|
|
"google_organization_policy": resourceGoogleOrganizationPolicy(),
|
2017-09-09 00:02:32 +00:00
|
|
|
"google_project": resourceGoogleProject(),
|
|
|
|
"google_project_iam_policy": resourceGoogleProjectIamPolicy(),
|
2017-12-11 18:24:53 +00:00
|
|
|
"google_project_iam_binding": ResourceIamBindingWithImport(IamProjectSchema, NewProjectIamUpdater, ProjectIdParseFunc),
|
|
|
|
"google_project_iam_member": ResourceIamMemberWithImport(IamProjectSchema, NewProjectIamUpdater, ProjectIdParseFunc),
|
2017-11-07 23:19:57 +00:00
|
|
|
"google_project_service": resourceGoogleProjectService(),
|
2017-11-10 19:01:33 +00:00
|
|
|
"google_project_iam_custom_role": resourceGoogleProjectIamCustomRole(),
|
2018-02-13 21:30:17 +00:00
|
|
|
"google_project_usage_export_bucket": resourceProjectUsageBucket(),
|
2017-09-09 00:02:32 +00:00
|
|
|
"google_project_services": resourceGoogleProjectServices(),
|
|
|
|
"google_pubsub_topic": resourcePubsubTopic(),
|
2017-12-20 01:19:04 +00:00
|
|
|
"google_pubsub_topic_iam_binding": ResourceIamBindingWithImport(IamPubsubTopicSchema, NewPubsubTopicIamUpdater, PubsubTopicIdParseFunc),
|
|
|
|
"google_pubsub_topic_iam_member": ResourceIamMemberWithImport(IamPubsubTopicSchema, NewPubsubTopicIamUpdater, PubsubTopicIdParseFunc),
|
|
|
|
"google_pubsub_topic_iam_policy": ResourceIamPolicyWithImport(IamPubsubTopicSchema, NewPubsubTopicIamUpdater, PubsubTopicIdParseFunc),
|
2017-09-09 00:02:32 +00:00
|
|
|
"google_pubsub_subscription": resourcePubsubSubscription(),
|
2018-03-06 17:52:39 +00:00
|
|
|
"google_pubsub_subscription_iam_binding": ResourceIamBindingWithImport(IamPubsubSubscriptionSchema, NewPubsubSubscriptionIamUpdater, PubsubSubscriptionIdParseFunc),
|
|
|
|
"google_pubsub_subscription_iam_member": ResourceIamMemberWithImport(IamPubsubSubscriptionSchema, NewPubsubSubscriptionIamUpdater, PubsubSubscriptionIdParseFunc),
|
|
|
|
"google_pubsub_subscription_iam_policy": ResourceIamPolicyWithImport(IamPubsubSubscriptionSchema, NewPubsubSubscriptionIamUpdater, PubsubSubscriptionIdParseFunc),
|
2017-09-09 00:02:32 +00:00
|
|
|
"google_runtimeconfig_config": resourceRuntimeconfigConfig(),
|
|
|
|
"google_runtimeconfig_variable": resourceRuntimeconfigVariable(),
|
|
|
|
"google_service_account": resourceGoogleServiceAccount(),
|
2017-12-14 22:52:44 +00:00
|
|
|
"google_service_account_iam_binding": ResourceIamBindingWithImport(IamServiceAccountSchema, NewServiceAccountIamUpdater, ServiceAccountIdParseFunc),
|
|
|
|
"google_service_account_iam_member": ResourceIamMemberWithImport(IamServiceAccountSchema, NewServiceAccountIamUpdater, ServiceAccountIdParseFunc),
|
|
|
|
"google_service_account_iam_policy": ResourceIamPolicyWithImport(IamServiceAccountSchema, NewServiceAccountIamUpdater, ServiceAccountIdParseFunc),
|
2017-10-25 19:43:20 +00:00
|
|
|
"google_service_account_key": resourceGoogleServiceAccountKey(),
|
2017-09-09 00:02:32 +00:00
|
|
|
"google_storage_bucket": resourceStorageBucket(),
|
|
|
|
"google_storage_bucket_acl": resourceStorageBucketAcl(),
|
2017-12-07 21:12:25 +00:00
|
|
|
// Legacy roles such as roles/storage.legacyBucketReader are automatically added
|
|
|
|
// when creating a bucket. For this reason, it is better not to add the authoritative
|
|
|
|
// google_storage_bucket_iam_policy resource.
|
|
|
|
"google_storage_bucket_iam_binding": ResourceIamBinding(IamStorageBucketSchema, NewStorageBucketIamUpdater),
|
|
|
|
"google_storage_bucket_iam_member": ResourceIamMember(IamStorageBucketSchema, NewStorageBucketIamUpdater),
|
|
|
|
"google_storage_bucket_object": resourceStorageBucketObject(),
|
|
|
|
"google_storage_object_acl": resourceStorageObjectAcl(),
|
2018-01-25 19:29:49 +00:00
|
|
|
"google_storage_default_object_acl": resourceStorageDefaultObjectAcl(),
|
2018-02-05 22:14:36 +00:00
|
|
|
"google_storage_notification": resourceStorageNotification(),
|
2014-08-25 18:48:20 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
ConfigureFunc: providerConfigure,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func providerConfigure(d *schema.ResourceData) (interface{}, error) {
|
2015-11-12 22:13:07 +00:00
|
|
|
credentials := d.Get("credentials").(string)
|
2014-08-25 18:48:20 +00:00
|
|
|
config := Config{
|
2015-11-12 22:13:07 +00:00
|
|
|
Credentials: credentials,
|
2015-07-27 19:35:52 +00:00
|
|
|
Project: d.Get("project").(string),
|
|
|
|
Region: d.Get("region").(string),
|
2017-12-06 22:30:04 +00:00
|
|
|
Zone: d.Get("zone").(string),
|
2014-08-25 18:48:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if err := config.loadAndValidate(); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
2014-08-25 19:55:08 +00:00
|
|
|
return &config, nil
|
2014-08-25 18:48:20 +00:00
|
|
|
}
|
2015-07-27 19:35:52 +00:00
|
|
|
|
2015-11-12 22:13:07 +00:00
|
|
|
func validateCredentials(v interface{}, k string) (warnings []string, errors []error) {
|
|
|
|
if v == nil || v.(string) == "" {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
creds := v.(string)
|
2017-12-08 21:57:55 +00:00
|
|
|
// if this is a path and we can stat it, assume it's ok
|
|
|
|
if _, err := os.Stat(creds); err == nil {
|
|
|
|
return
|
|
|
|
}
|
2015-11-12 22:13:07 +00:00
|
|
|
var account accountFile
|
|
|
|
if err := json.Unmarshal([]byte(creds), &account); err != nil {
|
2015-07-27 21:07:38 +00:00
|
|
|
errors = append(errors,
|
2015-11-12 22:13:07 +00:00
|
|
|
fmt.Errorf("credentials are not valid JSON '%s': %s", creds, err))
|
2015-07-27 19:35:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return
|
|
|
|
}
|