github.com/IBM-Cloud/terraform@v0.6.4-0.20170726051544-8872b87621df/builtin/providers/heroku/resource_heroku_cert.go (about) 1 package heroku 2 3 import ( 4 "context" 5 "fmt" 6 "log" 7 8 "github.com/cyberdelia/heroku-go/v3" 9 "github.com/hashicorp/terraform/helper/schema" 10 ) 11 12 func resourceHerokuCert() *schema.Resource { 13 return &schema.Resource{ 14 Create: resourceHerokuCertCreate, 15 Read: resourceHerokuCertRead, 16 Update: resourceHerokuCertUpdate, 17 Delete: resourceHerokuCertDelete, 18 19 Schema: map[string]*schema.Schema{ 20 "app": { 21 Type: schema.TypeString, 22 Required: true, 23 ForceNew: true, 24 }, 25 26 "certificate_chain": { 27 Type: schema.TypeString, 28 Required: true, 29 }, 30 31 "private_key": { 32 Type: schema.TypeString, 33 Required: true, 34 }, 35 36 "cname": { 37 Type: schema.TypeString, 38 Computed: true, 39 }, 40 41 "name": { 42 Type: schema.TypeString, 43 Computed: true, 44 }, 45 }, 46 } 47 } 48 49 func resourceHerokuCertCreate(d *schema.ResourceData, meta interface{}) error { 50 client := meta.(*heroku.Service) 51 52 app := d.Get("app").(string) 53 preprocess := true 54 opts := heroku.SSLEndpointCreateOpts{ 55 CertificateChain: d.Get("certificate_chain").(string), 56 Preprocess: &preprocess, 57 PrivateKey: d.Get("private_key").(string)} 58 59 log.Printf("[DEBUG] SSL Certificate create configuration: %#v, %#v", app, opts) 60 a, err := client.SSLEndpointCreate(context.TODO(), app, opts) 61 if err != nil { 62 return fmt.Errorf("Error creating SSL endpoint: %s", err) 63 } 64 65 d.SetId(a.ID) 66 log.Printf("[INFO] SSL Certificate ID: %s", d.Id()) 67 68 return resourceHerokuCertRead(d, meta) 69 } 70 71 func resourceHerokuCertRead(d *schema.ResourceData, meta interface{}) error { 72 client := meta.(*heroku.Service) 73 74 cert, err := resourceHerokuSSLCertRetrieve( 75 d.Get("app").(string), d.Id(), client) 76 if err != nil { 77 return err 78 } 79 80 d.Set("certificate_chain", cert.CertificateChain) 81 d.Set("name", cert.Name) 82 d.Set("cname", cert.CName) 83 84 return nil 85 } 86 87 func resourceHerokuCertUpdate(d *schema.ResourceData, meta interface{}) error { 88 client := meta.(*heroku.Service) 89 90 app := d.Get("app").(string) 91 preprocess := true 92 rollback := false 93 opts := heroku.SSLEndpointUpdateOpts{ 94 CertificateChain: heroku.String(d.Get("certificate_chain").(string)), 95 Preprocess: &preprocess, 96 PrivateKey: heroku.String(d.Get("private_key").(string)), 97 Rollback: &rollback} 98 99 if d.HasChange("certificate_chain") || d.HasChange("private_key") { 100 log.Printf("[DEBUG] SSL Certificate update configuration: %#v, %#v", app, opts) 101 _, err := client.SSLEndpointUpdate(context.TODO(), app, d.Id(), opts) 102 if err != nil { 103 return fmt.Errorf("Error updating SSL endpoint: %s", err) 104 } 105 } 106 107 return resourceHerokuCertRead(d, meta) 108 } 109 110 func resourceHerokuCertDelete(d *schema.ResourceData, meta interface{}) error { 111 client := meta.(*heroku.Service) 112 113 log.Printf("[INFO] Deleting SSL Cert: %s", d.Id()) 114 115 // Destroy the app 116 _, err := client.SSLEndpointDelete(context.TODO(), d.Get("app").(string), d.Id()) 117 if err != nil { 118 return fmt.Errorf("Error deleting SSL Cert: %s", err) 119 } 120 121 d.SetId("") 122 return nil 123 } 124 125 func resourceHerokuSSLCertRetrieve(app string, id string, client *heroku.Service) (*heroku.SSLEndpointInfoResult, error) { 126 addon, err := client.SSLEndpointInfo(context.TODO(), app, id) 127 128 if err != nil { 129 return nil, fmt.Errorf("Error retrieving SSL Cert: %s", err) 130 } 131 132 return addon, nil 133 }