providers/aws/waf_regional.go (233 lines of code) (raw):
// Copyright 2020 The Terraformer Authors.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package aws
import (
"context"
"github.com/GoogleCloudPlatform/terraformer/terraformutils"
"github.com/aws/aws-sdk-go-v2/service/wafregional"
)
type WafRegionalGenerator struct {
AWSService
}
func (g *WafRegionalGenerator) InitResources() error {
config, e := g.generateConfig()
if e != nil {
return e
}
svc := wafregional.NewFromConfig(config)
if err := g.loadWebACL(svc); err != nil {
return err
}
// AWS WAF Regional API doesn't provide API to build aws_wafregional_web_acl_association resources
if err := g.loadByteMatchSet(svc); err != nil {
return err
}
if err := g.loadGeoMatchSet(svc); err != nil {
return err
}
if err := g.loadIPSet(svc); err != nil {
return err
}
if err := g.loadRateBasedRules(svc); err != nil {
return err
}
if err := g.loadRegexMatchSets(svc); err != nil {
return err
}
if err := g.loadRegexPatternSets(svc); err != nil {
return err
}
if err := g.loadWafRules(svc); err != nil {
return err
}
if err := g.loadWafRuleGroups(svc); err != nil {
return err
}
if err := g.loadSizeConstraintSets(svc); err != nil {
return err
}
if err := g.loadSQLInjectionMatchSets(svc); err != nil {
return err
}
if err := g.loadXSSMatchSet(svc); err != nil {
return err
}
return nil
}
func (g *WafRegionalGenerator) loadWebACL(svc *wafregional.Client) error {
output, err := svc.ListWebACLs(context.TODO(), &wafregional.ListWebACLsInput{})
if err != nil {
return err
}
for _, acl := range output.WebACLs {
g.Resources = append(g.Resources, terraformutils.NewSimpleResource(
*acl.WebACLId,
*acl.Name+"_"+(*acl.WebACLId)[0:8],
"aws_wafregional_web_acl",
"aws",
wafAllowEmptyValues))
}
return nil
}
func (g *WafRegionalGenerator) loadByteMatchSet(svc *wafregional.Client) error {
output, err := svc.ListByteMatchSets(context.TODO(), &wafregional.ListByteMatchSetsInput{})
if err != nil {
return err
}
for _, byteMatchSet := range output.ByteMatchSets {
g.Resources = append(g.Resources, terraformutils.NewSimpleResource(
*byteMatchSet.ByteMatchSetId,
*byteMatchSet.Name+"_"+(*byteMatchSet.ByteMatchSetId)[0:8],
"aws_wafregional_byte_match_set",
"aws",
wafAllowEmptyValues))
}
return nil
}
func (g *WafRegionalGenerator) loadGeoMatchSet(svc *wafregional.Client) error {
output, err := svc.ListGeoMatchSets(context.TODO(), &wafregional.ListGeoMatchSetsInput{})
if err != nil {
return err
}
for _, matchSet := range output.GeoMatchSets {
g.Resources = append(g.Resources, terraformutils.NewSimpleResource(
*matchSet.GeoMatchSetId,
*matchSet.Name+"_"+(*matchSet.GeoMatchSetId)[0:8],
"aws_wafregional_geo_match_set",
"aws",
wafAllowEmptyValues))
}
return nil
}
func (g *WafRegionalGenerator) loadIPSet(svc *wafregional.Client) error {
output, err := svc.ListIPSets(context.TODO(), &wafregional.ListIPSetsInput{})
if err != nil {
return err
}
for _, IPSet := range output.IPSets {
g.Resources = append(g.Resources, terraformutils.NewSimpleResource(
*IPSet.IPSetId,
*IPSet.Name+"_"+(*IPSet.IPSetId)[0:8],
"aws_wafregional_ipset",
"aws",
wafAllowEmptyValues))
}
return nil
}
func (g *WafRegionalGenerator) loadRateBasedRules(svc *wafregional.Client) error {
output, err := svc.ListRateBasedRules(context.TODO(), &wafregional.ListRateBasedRulesInput{})
if err != nil {
return err
}
for _, rule := range output.Rules {
g.Resources = append(g.Resources, terraformutils.NewSimpleResource(
*rule.RuleId,
*rule.Name+"_"+(*rule.RuleId)[0:8],
"aws_wafregional_rate_based_rule",
"aws",
wafAllowEmptyValues))
}
return nil
}
func (g *WafRegionalGenerator) loadRegexMatchSets(svc *wafregional.Client) error {
output, err := svc.ListRegexMatchSets(context.TODO(), &wafregional.ListRegexMatchSetsInput{})
if err != nil {
return err
}
for _, regexMatchSet := range output.RegexMatchSets {
g.Resources = append(g.Resources, terraformutils.NewSimpleResource(
*regexMatchSet.RegexMatchSetId,
*regexMatchSet.Name+"_"+(*regexMatchSet.RegexMatchSetId)[0:8],
"aws_wafregional_regex_match_set",
"aws",
wafAllowEmptyValues))
}
return nil
}
func (g *WafRegionalGenerator) loadRegexPatternSets(svc *wafregional.Client) error {
output, err := svc.ListRegexPatternSets(context.TODO(), &wafregional.ListRegexPatternSetsInput{})
if err != nil {
return err
}
for _, regexPatternSet := range output.RegexPatternSets {
g.Resources = append(g.Resources, terraformutils.NewSimpleResource(
*regexPatternSet.RegexPatternSetId,
*regexPatternSet.Name+"_"+(*regexPatternSet.RegexPatternSetId)[0:8],
"aws_wafregional_regex_pattern_set",
"aws",
wafAllowEmptyValues))
}
return nil
}
func (g *WafRegionalGenerator) loadWafRules(svc *wafregional.Client) error {
output, err := svc.ListRules(context.TODO(), &wafregional.ListRulesInput{})
if err != nil {
return err
}
for _, rule := range output.Rules {
g.Resources = append(g.Resources, terraformutils.NewSimpleResource(
*rule.RuleId,
*rule.Name+"_"+(*rule.RuleId)[0:8],
"aws_wafregional_rule",
"aws",
wafAllowEmptyValues))
}
return nil
}
func (g *WafRegionalGenerator) loadWafRuleGroups(svc *wafregional.Client) error {
output, err := svc.ListRuleGroups(context.TODO(), &wafregional.ListRuleGroupsInput{})
if err != nil {
return err
}
for _, ruleGroup := range output.RuleGroups {
g.Resources = append(g.Resources, terraformutils.NewSimpleResource(
*ruleGroup.RuleGroupId,
*ruleGroup.Name+"_"+(*ruleGroup.RuleGroupId)[0:8],
"aws_wafregional_rule_group",
"aws",
wafAllowEmptyValues))
}
return nil
}
func (g *WafRegionalGenerator) loadSizeConstraintSets(svc *wafregional.Client) error {
output, err := svc.ListSizeConstraintSets(context.TODO(), &wafregional.ListSizeConstraintSetsInput{})
if err != nil {
return err
}
for _, sizeConstraintSet := range output.SizeConstraintSets {
g.Resources = append(g.Resources, terraformutils.NewSimpleResource(
*sizeConstraintSet.SizeConstraintSetId,
*sizeConstraintSet.Name+"_"+(*sizeConstraintSet.SizeConstraintSetId)[0:8],
"aws_wafregional_size_constraint_set",
"aws",
wafAllowEmptyValues))
}
return nil
}
func (g *WafRegionalGenerator) loadSQLInjectionMatchSets(svc *wafregional.Client) error {
output, err := svc.ListSqlInjectionMatchSets(context.TODO(), &wafregional.ListSqlInjectionMatchSetsInput{})
if err != nil {
return err
}
for _, sqlInjectionMatchSet := range output.SqlInjectionMatchSets {
g.Resources = append(g.Resources, terraformutils.NewSimpleResource(
*sqlInjectionMatchSet.SqlInjectionMatchSetId,
*sqlInjectionMatchSet.Name+"_"+(*sqlInjectionMatchSet.SqlInjectionMatchSetId)[0:8],
"aws_wafregional_sql_injection_match_set",
"aws",
wafAllowEmptyValues))
}
return nil
}
func (g *WafRegionalGenerator) loadXSSMatchSet(svc *wafregional.Client) error {
output, err := svc.ListXssMatchSets(context.TODO(), &wafregional.ListXssMatchSetsInput{})
if err != nil {
return err
}
for _, xssMatchSet := range output.XssMatchSets {
g.Resources = append(g.Resources, terraformutils.NewSimpleResource(
*xssMatchSet.XssMatchSetId,
*xssMatchSet.Name+"_"+(*xssMatchSet.XssMatchSetId)[0:8],
"aws_wafregional_xss_match_set",
"aws",
wafAllowEmptyValues))
}
return nil
}