github.com/recobe182/terraform@v0.8.5-0.20170117231232-49ab22a935b7/builtin/providers/aws/data_source_aws_ip_ranges.go (about)

     1  package aws
     2  
     3  import (
     4  	"encoding/json"
     5  	"fmt"
     6  	"io/ioutil"
     7  	"log"
     8  	"sort"
     9  	"strconv"
    10  	"strings"
    11  
    12  	"github.com/hashicorp/go-cleanhttp"
    13  	"github.com/hashicorp/terraform/helper/schema"
    14  )
    15  
    16  type dataSourceAwsIPRangesResult struct {
    17  	CreateDate string
    18  	Prefixes   []dataSourceAwsIPRangesPrefix
    19  	SyncToken  string
    20  }
    21  
    22  type dataSourceAwsIPRangesPrefix struct {
    23  	IpPrefix string `json:"ip_prefix"`
    24  	Region   string
    25  	Service  string
    26  }
    27  
    28  func dataSourceAwsIPRanges() *schema.Resource {
    29  	return &schema.Resource{
    30  		Read: dataSourceAwsIPRangesRead,
    31  
    32  		Schema: map[string]*schema.Schema{
    33  			"cidr_blocks": &schema.Schema{
    34  				Type:     schema.TypeList,
    35  				Computed: true,
    36  				Elem:     &schema.Schema{Type: schema.TypeString},
    37  			},
    38  			"create_date": &schema.Schema{
    39  				Type:     schema.TypeString,
    40  				Computed: true,
    41  			},
    42  			"regions": &schema.Schema{
    43  				Type:     schema.TypeSet,
    44  				Elem:     &schema.Schema{Type: schema.TypeString},
    45  				Optional: true,
    46  			},
    47  			"services": &schema.Schema{
    48  				Type:     schema.TypeSet,
    49  				Required: true,
    50  				Elem:     &schema.Schema{Type: schema.TypeString},
    51  			},
    52  			"sync_token": &schema.Schema{
    53  				Type:     schema.TypeInt,
    54  				Computed: true,
    55  			},
    56  		},
    57  	}
    58  }
    59  
    60  func dataSourceAwsIPRangesRead(d *schema.ResourceData, meta interface{}) error {
    61  
    62  	conn := cleanhttp.DefaultClient()
    63  
    64  	log.Printf("[DEBUG] Reading IP ranges")
    65  
    66  	res, err := conn.Get("https://ip-ranges.amazonaws.com/ip-ranges.json")
    67  
    68  	if err != nil {
    69  		return fmt.Errorf("Error listing IP ranges: %s", err)
    70  	}
    71  
    72  	defer res.Body.Close()
    73  
    74  	data, err := ioutil.ReadAll(res.Body)
    75  
    76  	if err != nil {
    77  		return fmt.Errorf("Error reading response body: %s", err)
    78  	}
    79  
    80  	result := new(dataSourceAwsIPRangesResult)
    81  
    82  	if err := json.Unmarshal(data, result); err != nil {
    83  		return fmt.Errorf("Error parsing result: %s", err)
    84  	}
    85  
    86  	if err := d.Set("create_date", result.CreateDate); err != nil {
    87  		return fmt.Errorf("Error setting create date: %s", err)
    88  	}
    89  
    90  	syncToken, err := strconv.Atoi(result.SyncToken)
    91  
    92  	if err != nil {
    93  		return fmt.Errorf("Error while converting sync token: %s", err)
    94  	}
    95  
    96  	d.SetId(result.SyncToken)
    97  
    98  	if err := d.Set("sync_token", syncToken); err != nil {
    99  		return fmt.Errorf("Error setting sync token: %s", err)
   100  	}
   101  
   102  	get := func(key string) *schema.Set {
   103  
   104  		set := d.Get(key).(*schema.Set)
   105  
   106  		for _, e := range set.List() {
   107  
   108  			s := e.(string)
   109  
   110  			set.Remove(s)
   111  			set.Add(strings.ToLower(s))
   112  
   113  		}
   114  
   115  		return set
   116  
   117  	}
   118  
   119  	var (
   120  		regions        = get("regions")
   121  		services       = get("services")
   122  		noRegionFilter = regions.Len() == 0
   123  		prefixes       []string
   124  	)
   125  
   126  	for _, e := range result.Prefixes {
   127  
   128  		var (
   129  			matchRegion  = noRegionFilter || regions.Contains(strings.ToLower(e.Region))
   130  			matchService = services.Contains(strings.ToLower(e.Service))
   131  		)
   132  
   133  		if matchRegion && matchService {
   134  			prefixes = append(prefixes, e.IpPrefix)
   135  		}
   136  
   137  	}
   138  
   139  	if len(prefixes) == 0 {
   140  		return fmt.Errorf(" No IP ranges result from filters")
   141  	}
   142  
   143  	sort.Strings(prefixes)
   144  
   145  	if err := d.Set("cidr_blocks", prefixes); err != nil {
   146  		return fmt.Errorf("Error setting ip ranges: %s", err)
   147  	}
   148  
   149  	return nil
   150  
   151  }