mirror of
https://github.com/letic/terraform-provider-google.git
synced 2024-10-06 02:31:05 +00:00
75 lines
1.9 KiB
Go
75 lines
1.9 KiB
Go
|
package google
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
|
||
|
"github.com/hashicorp/terraform/helper/schema"
|
||
|
"github.com/hashicorp/terraform/helper/validation"
|
||
|
)
|
||
|
|
||
|
func dataSourceGoogleServiceAccountKey() *schema.Resource {
|
||
|
return &schema.Resource{
|
||
|
Read: dataSourceGoogleServiceAccountKeyRead,
|
||
|
|
||
|
Schema: map[string]*schema.Schema{
|
||
|
"service_account_id": &schema.Schema{
|
||
|
Type: schema.TypeString,
|
||
|
Required: true,
|
||
|
},
|
||
|
"public_key_type": &schema.Schema{
|
||
|
Type: schema.TypeString,
|
||
|
Default: "TYPE_X509_PEM_FILE",
|
||
|
Optional: true,
|
||
|
ValidateFunc: validation.StringInSlice([]string{"TYPE_NONE", "TYPE_X509_PEM_FILE", "TYPE_RAW_PUBLIC_KEY"}, false),
|
||
|
},
|
||
|
"project": &schema.Schema{
|
||
|
Type: schema.TypeString,
|
||
|
Optional: true,
|
||
|
},
|
||
|
// Computed
|
||
|
"name": &schema.Schema{
|
||
|
Type: schema.TypeString,
|
||
|
Computed: true,
|
||
|
},
|
||
|
"key_algorithm": {
|
||
|
Type: schema.TypeString,
|
||
|
Computed: true,
|
||
|
},
|
||
|
"public_key": {
|
||
|
Type: schema.TypeString,
|
||
|
Computed: true,
|
||
|
},
|
||
|
},
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func dataSourceGoogleServiceAccountKeyRead(d *schema.ResourceData, meta interface{}) error {
|
||
|
config := meta.(*Config)
|
||
|
|
||
|
// Get the project from the resource or fallback to the project
|
||
|
// in the provider configuration
|
||
|
project, err := getProject(d, config)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
|
||
|
// Get the service account as the fully qualified name
|
||
|
serviceAccountName := serviceAccountFQN(d.Get("service_account_id").(string), project)
|
||
|
|
||
|
publicKeyType := d.Get("public_key_type").(string)
|
||
|
|
||
|
// Confirm the service account key exists
|
||
|
sak, err := config.clientIAM.Projects.ServiceAccounts.Keys.Get(serviceAccountName).PublicKeyType(publicKeyType).Do()
|
||
|
if err != nil {
|
||
|
return handleNotFoundError(err, d, fmt.Sprintf("Service Account Key %q", serviceAccountName))
|
||
|
}
|
||
|
|
||
|
d.SetId(sak.Name)
|
||
|
|
||
|
d.Set("name", sak.Name)
|
||
|
d.Set("key_algorithm", sak.KeyAlgorithm)
|
||
|
d.Set("public_key", sak.PublicKeyData)
|
||
|
|
||
|
return nil
|
||
|
}
|