2015-09-16 23:02:28 +02:00
|
|
|
package aws
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"log"
|
|
|
|
|
|
|
|
"github.com/hashicorp/terraform/helper/schema"
|
|
|
|
|
|
|
|
"github.com/aws/aws-sdk-go/aws"
|
|
|
|
"github.com/aws/aws-sdk-go/service/cloudwatchlogs"
|
|
|
|
)
|
|
|
|
|
|
|
|
func resourceAwsCloudWatchLogGroup() *schema.Resource {
|
|
|
|
return &schema.Resource{
|
|
|
|
Create: resourceAwsCloudWatchLogGroupCreate,
|
|
|
|
Read: resourceAwsCloudWatchLogGroupRead,
|
|
|
|
Update: resourceAwsCloudWatchLogGroupUpdate,
|
|
|
|
Delete: resourceAwsCloudWatchLogGroupDelete,
|
2016-06-23 02:55:29 +02:00
|
|
|
Importer: &schema.ResourceImporter{
|
|
|
|
State: schema.ImportStatePassthrough,
|
|
|
|
},
|
2015-09-16 23:02:28 +02:00
|
|
|
|
|
|
|
Schema: map[string]*schema.Schema{
|
|
|
|
"name": &schema.Schema{
|
2016-03-05 17:37:45 +01:00
|
|
|
Type: schema.TypeString,
|
|
|
|
Required: true,
|
|
|
|
ForceNew: true,
|
|
|
|
ValidateFunc: validateLogGroupName,
|
2015-09-16 23:02:28 +02:00
|
|
|
},
|
|
|
|
|
|
|
|
"retention_in_days": &schema.Schema{
|
|
|
|
Type: schema.TypeInt,
|
|
|
|
Optional: true,
|
|
|
|
Default: 0,
|
|
|
|
},
|
|
|
|
|
|
|
|
"arn": &schema.Schema{
|
|
|
|
Type: schema.TypeString,
|
|
|
|
Computed: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func resourceAwsCloudWatchLogGroupCreate(d *schema.ResourceData, meta interface{}) error {
|
|
|
|
conn := meta.(*AWSClient).cloudwatchlogsconn
|
|
|
|
|
|
|
|
log.Printf("[DEBUG] Creating CloudWatch Log Group: %s", d.Get("name").(string))
|
|
|
|
_, err := conn.CreateLogGroup(&cloudwatchlogs.CreateLogGroupInput{
|
|
|
|
LogGroupName: aws.String(d.Get("name").(string)),
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("Creating CloudWatch Log Group failed: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
d.SetId(d.Get("name").(string))
|
|
|
|
|
|
|
|
log.Println("[INFO] CloudWatch Log Group created")
|
|
|
|
|
|
|
|
return resourceAwsCloudWatchLogGroupUpdate(d, meta)
|
|
|
|
}
|
|
|
|
|
|
|
|
func resourceAwsCloudWatchLogGroupRead(d *schema.ResourceData, meta interface{}) error {
|
|
|
|
conn := meta.(*AWSClient).cloudwatchlogsconn
|
|
|
|
log.Printf("[DEBUG] Reading CloudWatch Log Group: %q", d.Get("name").(string))
|
2016-07-11 20:06:44 +02:00
|
|
|
lg, exists, err := lookupCloudWatchLogGroup(conn, d.Id(), nil)
|
2015-09-16 23:02:28 +02:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2016-07-11 20:06:44 +02:00
|
|
|
if !exists {
|
|
|
|
log.Printf("[DEBUG] CloudWatch Group %q Not Found", d.Id())
|
|
|
|
d.SetId("")
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2015-09-16 23:02:28 +02:00
|
|
|
log.Printf("[DEBUG] Found Log Group: %#v", *lg)
|
|
|
|
|
2016-08-28 20:25:30 +02:00
|
|
|
d.Set("arn", lg.Arn)
|
|
|
|
d.Set("name", lg.LogGroupName)
|
2015-09-16 23:02:28 +02:00
|
|
|
|
|
|
|
if lg.RetentionInDays != nil {
|
2016-08-28 20:25:30 +02:00
|
|
|
d.Set("retention_in_days", lg.RetentionInDays)
|
2015-09-16 23:02:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func lookupCloudWatchLogGroup(conn *cloudwatchlogs.CloudWatchLogs,
|
2016-07-11 20:06:44 +02:00
|
|
|
name string, nextToken *string) (*cloudwatchlogs.LogGroup, bool, error) {
|
2015-09-16 23:02:28 +02:00
|
|
|
input := &cloudwatchlogs.DescribeLogGroupsInput{
|
|
|
|
LogGroupNamePrefix: aws.String(name),
|
|
|
|
NextToken: nextToken,
|
|
|
|
}
|
|
|
|
resp, err := conn.DescribeLogGroups(input)
|
|
|
|
if err != nil {
|
2016-07-11 20:06:44 +02:00
|
|
|
return nil, true, err
|
2015-09-16 23:02:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
for _, lg := range resp.LogGroups {
|
|
|
|
if *lg.LogGroupName == name {
|
2016-07-11 20:06:44 +02:00
|
|
|
return lg, true, nil
|
2015-09-16 23:02:28 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if resp.NextToken != nil {
|
|
|
|
return lookupCloudWatchLogGroup(conn, name, resp.NextToken)
|
|
|
|
}
|
|
|
|
|
2016-07-11 20:06:44 +02:00
|
|
|
return nil, false, nil
|
2015-09-16 23:02:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func resourceAwsCloudWatchLogGroupUpdate(d *schema.ResourceData, meta interface{}) error {
|
|
|
|
conn := meta.(*AWSClient).cloudwatchlogsconn
|
|
|
|
|
|
|
|
name := d.Get("name").(string)
|
|
|
|
log.Printf("[DEBUG] Updating CloudWatch Log Group: %q", name)
|
|
|
|
|
|
|
|
if d.HasChange("retention_in_days") {
|
|
|
|
var err error
|
|
|
|
|
|
|
|
if v, ok := d.GetOk("retention_in_days"); ok {
|
|
|
|
input := cloudwatchlogs.PutRetentionPolicyInput{
|
|
|
|
LogGroupName: aws.String(name),
|
|
|
|
RetentionInDays: aws.Int64(int64(v.(int))),
|
|
|
|
}
|
|
|
|
log.Printf("[DEBUG] Setting retention for CloudWatch Log Group: %q: %s", name, input)
|
|
|
|
_, err = conn.PutRetentionPolicy(&input)
|
|
|
|
} else {
|
|
|
|
log.Printf("[DEBUG] Deleting retention for CloudWatch Log Group: %q", name)
|
|
|
|
_, err = conn.DeleteRetentionPolicy(&cloudwatchlogs.DeleteRetentionPolicyInput{
|
|
|
|
LogGroupName: aws.String(name),
|
|
|
|
})
|
2016-04-28 14:12:47 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return err
|
2015-09-16 23:02:28 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return resourceAwsCloudWatchLogGroupRead(d, meta)
|
|
|
|
}
|
|
|
|
|
|
|
|
func resourceAwsCloudWatchLogGroupDelete(d *schema.ResourceData, meta interface{}) error {
|
|
|
|
conn := meta.(*AWSClient).cloudwatchlogsconn
|
|
|
|
log.Printf("[INFO] Deleting CloudWatch Log Group: %s", d.Id())
|
|
|
|
_, err := conn.DeleteLogGroup(&cloudwatchlogs.DeleteLogGroupInput{
|
|
|
|
LogGroupName: aws.String(d.Get("name").(string)),
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("Error deleting CloudWatch Log Group: %s", err)
|
|
|
|
}
|
|
|
|
log.Println("[INFO] CloudWatch Log Group deleted")
|
|
|
|
|
|
|
|
d.SetId("")
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|