mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-18 04:32:59 -06:00
804d714ff6
In c244e5a6
this resource was converted to a data source, but that was
a mistake since data sources are expected to produce stable results on
each run, and yet certificate requests contain a random nonce as part of
the signature.
Additionally, using the data source as a managed resource through the
provided compatibility shim was not actually working, since "Read" was
trying to parse the private key out of a SHA1 hash of the key, which is
what we place in state due to the StateFunc on that attribute.
By restoring this we restore Terraform's ability to produce all of the
parts of a basic PKI/CA, which is useful for creating dev environments
and bootstrapping PKI for production environments.
113 lines
2.7 KiB
Go
113 lines
2.7 KiB
Go
package tls
|
|
|
|
import (
|
|
"crypto/sha1"
|
|
"crypto/x509/pkix"
|
|
"encoding/hex"
|
|
"strings"
|
|
|
|
"github.com/hashicorp/terraform/helper/schema"
|
|
"github.com/hashicorp/terraform/terraform"
|
|
)
|
|
|
|
func Provider() terraform.ResourceProvider {
|
|
return &schema.Provider{
|
|
ResourcesMap: map[string]*schema.Resource{
|
|
"tls_private_key": resourcePrivateKey(),
|
|
"tls_locally_signed_cert": resourceLocallySignedCert(),
|
|
"tls_self_signed_cert": resourceSelfSignedCert(),
|
|
"tls_cert_request": resourceCertRequest(),
|
|
},
|
|
}
|
|
}
|
|
|
|
func hashForState(value string) string {
|
|
if value == "" {
|
|
return ""
|
|
}
|
|
hash := sha1.Sum([]byte(strings.TrimSpace(value)))
|
|
return hex.EncodeToString(hash[:])
|
|
}
|
|
|
|
func nameFromResourceData(nameMap map[string]interface{}) (*pkix.Name, error) {
|
|
result := &pkix.Name{}
|
|
|
|
if value := nameMap["common_name"]; value != nil {
|
|
result.CommonName = value.(string)
|
|
}
|
|
if value := nameMap["organization"]; value != nil {
|
|
result.Organization = []string{value.(string)}
|
|
}
|
|
if value := nameMap["organizational_unit"]; value != nil {
|
|
result.OrganizationalUnit = []string{value.(string)}
|
|
}
|
|
if value := nameMap["street_address"]; value != nil {
|
|
valueI := value.([]interface{})
|
|
result.StreetAddress = make([]string, len(valueI))
|
|
for i, vi := range valueI {
|
|
result.StreetAddress[i] = vi.(string)
|
|
}
|
|
}
|
|
if value := nameMap["locality"]; value != nil {
|
|
result.Locality = []string{value.(string)}
|
|
}
|
|
if value := nameMap["province"]; value != nil {
|
|
result.Province = []string{value.(string)}
|
|
}
|
|
if value := nameMap["country"]; value != nil {
|
|
result.Country = []string{value.(string)}
|
|
}
|
|
if value := nameMap["postal_code"]; value != nil {
|
|
result.PostalCode = []string{value.(string)}
|
|
}
|
|
if value := nameMap["serial_number"]; value != nil {
|
|
result.SerialNumber = value.(string)
|
|
}
|
|
|
|
return result, nil
|
|
}
|
|
|
|
var nameSchema *schema.Resource = &schema.Resource{
|
|
Schema: map[string]*schema.Schema{
|
|
"organization": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Optional: true,
|
|
},
|
|
"common_name": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Optional: true,
|
|
},
|
|
"organizational_unit": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Optional: true,
|
|
},
|
|
"street_address": &schema.Schema{
|
|
Type: schema.TypeList,
|
|
Optional: true,
|
|
Elem: &schema.Schema{
|
|
Type: schema.TypeString,
|
|
},
|
|
},
|
|
"locality": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Optional: true,
|
|
},
|
|
"province": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Optional: true,
|
|
},
|
|
"country": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Optional: true,
|
|
},
|
|
"postal_code": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Optional: true,
|
|
},
|
|
"serial_number": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Optional: true,
|
|
},
|
|
},
|
|
}
|