Skip to content

Commit

Permalink
adding persistance profile support for FAST HTTP/HTTPS
Browse files Browse the repository at this point in the history
  • Loading branch information
RavinderReddyF5 committed Nov 3, 2023
1 parent 936800d commit 265a247
Show file tree
Hide file tree
Showing 8 changed files with 252 additions and 253 deletions.
8 changes: 4 additions & 4 deletions bigip/resource_bigip_fast_application_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -55,18 +55,18 @@ func TestAccFastAppCreateOnBigip(t *testing.T) {
})
}

func testCheckFastAppExists(app, tenant string, exists bool) resource.TestCheckFunc {
func testCheckFastAppExists(app1, tenant1 string, exists bool) resource.TestCheckFunc {
return func(s *terraform.State) error {
client := testAccProvider.Meta().(*bigip.BigIP)
p, err := client.GetFastApp(tenant, app)
p, err := client.GetFastApp(tenant1, app1)
if err != nil {
return err
}
if exists && p == "" {
return fmt.Errorf("fast application %s was not created", app)
return fmt.Errorf("fast application %s was not created", app1)
}
if !exists && p != "" {
return fmt.Errorf("fast application %s still exists", app)
return fmt.Errorf("fast application %s still exists", app1)
}
return nil
}
Expand Down
202 changes: 48 additions & 154 deletions bigip/resource_bigip_fast_http.go
Original file line number Diff line number Diff line change
Expand Up @@ -77,6 +77,32 @@ func resourceBigipHttpFastApp() *schema.Resource {
Elem: &schema.Schema{Type: schema.TypeString},
ConflictsWith: []string{"existing_snat_pool"},
},
"persistence_profile": {
Type: schema.TypeString,
Optional: true,
Description: "Name of an existing BIG-IP persistence profile to be used.",
ConflictsWith: []string{"persistence_type"},
},
"persistence_type": {
Type: schema.TypeString,
Optional: true,
Description: "Type of persistence profile to be created.",
ValidateFunc: validation.StringInSlice([]string{
"cookie",
"msrdp",
"tls-session-id",
"destination-address",
"source-address"}, false),
ConflictsWith: []string{"persistence_profile"},
},
"fallback_persistence": {
Type: schema.TypeString,
Optional: true,
Description: "Type of fallback persistence record to be created for each new client connection.",
ValidateFunc: validation.StringInSlice([]string{
"destination-address",
"source-address"}, false),
},
"existing_pool": {
Type: schema.TypeString,
Optional: true,
Expand Down Expand Up @@ -120,111 +146,10 @@ func resourceBigipHttpFastApp() *schema.Resource {
},
"service_discovery": {
Type: schema.TypeList,
Computed: true,
Optional: true,
Elem: &schema.Schema{Type: schema.TypeString},
ConflictsWith: []string{"existing_pool"},
},
// "service_discovery_list": {
// Type: schema.TypeSet,
// Optional: true,
// Elem: &schema.Resource{
// Schema: map[string]*schema.Schema{
// "sd_type": {
// Type: schema.TypeString,
// Required: true,
// },
// "sd_port": {
// Type: schema.TypeInt,
// Required: true,
// },
// "sd_aws_tag_key": {
// Type: schema.TypeString,
// Computed: true,
// Optional: true,
// },
// "sd_aws_tag_val": {
// Type: schema.TypeString,
// Computed: true,
// Optional: true,
// },
// "sd_aws_region": {
// Type: schema.TypeString,
// Computed: true,
// Optional: true,
// },
// "sd_aws_access_key": {
// Type: schema.TypeString,
// Computed: true,
// Optional: true,
// },
// "sd_aws_secret_access_key": {
// Type: schema.TypeString,
// Computed: true,
// Optional: true,
// },
// "sd_address_realm": {
// Type: schema.TypeString,
// Optional: true,
// Default: "private",
// },
// "sd_undetectable_action": {
// Type: schema.TypeString,
// Optional: true,
// Default: "remove",
// },
// "sd_azure_resource_group": {
// Type: schema.TypeString,
// Optional: true,
// Computed: true,
// },
// "sd_azure_subscription_id": {
// Type: schema.TypeString,
// Optional: true,
// Computed: true,
// },
// "sd_azure_resource_id": {
// Type: schema.TypeString,
// Optional: true,
// Computed: true,
// // ConflictsWith: []string{"service_discovery.sd_azure_tag_key", "service_discovery.sd_azure_tag_val"},
// },
// "sd_azure_directory_id": {
// Type: schema.TypeString,
// Optional: true,
// Computed: true,
// // ConflictsWith: []string{"sd_azure_tag_key", "sd_azure_tag_val"},
// },
// "sd_azure_tag_key": {
// Type: schema.TypeString,
// Computed: true,
// Optional: true,
// // ConflictsWith: []string{"sd_azure_resource_id", "sd_azure_directory_id"},
// },
// "sd_azure_tag_val": {
// Type: schema.TypeString,
// Computed: true,
// Optional: true,
// // ConflictsWith: []string{"sd_azure_resource_id", "sd_azure_directory_id"},
// },
// "sd_gce_tag_key": {
// Type: schema.TypeString,
// Computed: true,
// Optional: true,
// },
// "sd_gce_tag_val": {
// Type: schema.TypeString,
// Computed: true,
// Optional: true,
// },
// "sd_gce_region": {
// Type: schema.TypeString,
// Computed: true,
// Optional: true,
// },
// },
// },
// },
"load_balancing_mode": {
Type: schema.TypeString,
Optional: true,
Expand Down Expand Up @@ -486,6 +411,12 @@ func setFastHttpData(d *schema.ResourceData, data bigip.FastHttpJson) error {
if _, ok := d.GetOk("endpoint_ltm_policy"); ok {
_ = d.Set("endpoint_ltm_policy", data.EndpointPolicyNames)
}
if _, ok := d.GetOk("fallback_persistence"); ok {
_ = d.Set("fallback_persistence", data.FallbackPersistenceType)

Check failure on line 415 in bigip/resource_bigip_fast_http.go

View workflow job for this annotation

GitHub Actions / golint

data.FallbackPersistenceType undefined (type "github.com/f5devcentral/go-bigip".FastHttpJson has no field or method FallbackPersistenceType)
}
if _, ok := d.GetOk("persistence_profile"); ok {
_ = d.Set("persistence_profile", data.PersistenceProfile)

Check failure on line 418 in bigip/resource_bigip_fast_http.go

View workflow job for this annotation

GitHub Actions / golint

data.PersistenceProfile undefined (type "github.com/f5devcentral/go-bigip".FastHttpJson has no field or method PersistenceProfile)
}
if _, ok := d.GetOk("monitor"); ok {
if err := d.Set("monitor", []interface{}{flattenFastMonitor(data)}); err != nil {
return fmt.Errorf("error setting monitor: %w", err)
Expand Down Expand Up @@ -645,59 +576,6 @@ func getFastHttpConfig(d *schema.ResourceData) (string, error) {
}
httpJson.ServiceDiscovery = serviceDiscovery

// if p, ok := d.GetOk("service_discovery"); ok {
// httpJson.SdEnable = true
// httpJson.PoolEnable = true
// httpJson.MakePool = true
// var sdObjs []bigip.ServiceDiscoverObj
// for _, r := range p.(*schema.Set).List() {
// sdObj := bigip.ServiceDiscoverObj{}
// sdObj.SdType = r.(map[string]interface{})["sd_type"].(string)
// sdObj.SdPort = r.(map[string]interface{})["sd_port"].(int)
// sdObj.SdAddressRealm = r.(map[string]interface{})["sd_address_realm"].(string)
// if sdObj.SdType == "aws" {
// if r.(map[string]interface{})["sd_aws_tag_key"].(string) == "" || r.(map[string]interface{})["sd_aws_tag_val"].(string) == "" {
// return "", fmt.Errorf("'sd_aws_tag_key' and 'sd_aws_tag_val' must be specified for aws service discovery")
// }
// sdObj.SdTagKey = r.(map[string]interface{})["sd_aws_tag_key"].(string)
// sdObj.SdTagVal = r.(map[string]interface{})["sd_aws_tag_val"].(string)
// sdObj.SdAwsRegion = r.(map[string]interface{})["sd_aws_region"].(string)
// sdObj.SdAccessKeyId = r.(map[string]interface{})["sd_aws_access_key"].(string)
// sdObj.SdSecretAccessKey = r.(map[string]interface{})["sd_aws_secret_access_key"].(string)
// sdObj.SdUndetectableAction = r.(map[string]interface{})["sd_undetectable_action"].(string)
// sdObjs = append(sdObjs, sdObj)
// }
// if sdObj.SdType == "azure" {
// if r.(map[string]interface{})["sd_azure_resource_group"].(string) == "" || r.(map[string]interface{})["sd_azure_subscription_id"].(string) == "" {
// return "", fmt.Errorf("'sd_azure_resource_group' and 'sd_azure_subscription_id' must be specified for azure service discovery")
// }
// sdObj.SdRg = r.(map[string]interface{})["sd_azure_resource_group"].(string)
// sdObj.SdSid = r.(map[string]interface{})["sd_azure_subscription_id"].(string)
// sdObj.SdRtype = "tag"
// sdObj.SdUseManagedIdentity = true
// if r.(map[string]interface{})["sd_azure_tag_key"].(string) != "" && r.(map[string]interface{})["sd_azure_tag_val"].(string) != "" {
// sdObj.SdAzureTagKey = r.(map[string]interface{})["sd_azure_tag_key"].(string)
// sdObj.SdAzureTagVal = r.(map[string]interface{})["sd_azure_tag_val"].(string)
// } else if r.(map[string]interface{})["sd_azure_resource_id"].(string) != "" {
// sdObj.SdRid = r.(map[string]interface{})["sd_azure_resource_id"].(string)
// // sdObj.SdDirid = r.(map[string]interface{})["sd_azure_directory_id"].(string)
// }
// sdObj.SdUndetectableAction = r.(map[string]interface{})["sd_undetectable_action"].(string)
// sdObjs = append(sdObjs, sdObj)
// }
// if sdObj.SdType == "gce" {
// if r.(map[string]interface{})["sd_gce_tag_key"].(string) == "" || r.(map[string]interface{})["sd_gce_tag_val"].(string) == "" || r.(map[string]interface{})["sd_gce_region"].(string) == "" {
// return "", fmt.Errorf("'sd_gce_tag_key' , 'sd_gce_tag_val' and 'sd_gce_region' must be specified for GCE service discovery")
// }
// sdObj.SdTagKey = r.(map[string]interface{})["sd_gce_tag_key"].(string)
// sdObj.SdTagVal = r.(map[string]interface{})["sd_gce_tag_val"].(string)
// sdObj.SdRegion = r.(map[string]interface{})["sd_gce_region"].(string)
// sdObj.SdUndetectableAction = r.(map[string]interface{})["sd_undetectable_action"].(string)
// sdObjs = append(sdObjs, sdObj)
// }
// }
// httpJson.ServiceDiscovery = sdObjs
// }
httpJson.SnatEnable = true
httpJson.SnatAutomap = true
httpJson.WafPolicyEnable = false
Expand All @@ -718,6 +596,22 @@ func getFastHttpConfig(d *schema.ResourceData) (string, error) {
}
httpJson.SnatAddresses = snatAdd
}
httpJson.EnablePersistence = false

Check failure on line 599 in bigip/resource_bigip_fast_http.go

View workflow job for this annotation

GitHub Actions / golint

httpJson.EnablePersistence undefined (type *"github.com/f5devcentral/go-bigip".FastHttpJson has no field or method EnablePersistence)
httpJson.UseExistingPersistence = false

Check failure on line 600 in bigip/resource_bigip_fast_http.go

View workflow job for this annotation

GitHub Actions / golint

httpJson.UseExistingPersistence undefined (type *"github.com/f5devcentral/go-bigip".FastHttpJson has no field or method UseExistingPersistence)
httpJson.EnableFallbackPersistence = false

Check failure on line 601 in bigip/resource_bigip_fast_http.go

View workflow job for this annotation

GitHub Actions / golint

httpJson.EnableFallbackPersistence undefined (type *"github.com/f5devcentral/go-bigip".FastHttpJson has no field or method EnableFallbackPersistence)
if v, ok := d.GetOk("persistence_profile"); ok {
httpJson.EnablePersistence = true

Check failure on line 603 in bigip/resource_bigip_fast_http.go

View workflow job for this annotation

GitHub Actions / golint

httpJson.EnablePersistence undefined (type *"github.com/f5devcentral/go-bigip".FastHttpJson has no field or method EnablePersistence)
httpJson.UseExistingPersistence = true

Check failure on line 604 in bigip/resource_bigip_fast_http.go

View workflow job for this annotation

GitHub Actions / golint

httpJson.UseExistingPersistence undefined (type *"github.com/f5devcentral/go-bigip".FastHttpJson has no field or method UseExistingPersistence)
httpJson.PersistenceProfile = v.(string)

Check failure on line 605 in bigip/resource_bigip_fast_http.go

View workflow job for this annotation

GitHub Actions / golint

httpJson.PersistenceProfile undefined (type *"github.com/f5devcentral/go-bigip".FastHttpJson has no field or method PersistenceProfile)
}
if v, ok := d.GetOk("persistence_type"); ok {
httpJson.EnablePersistence = true
httpJson.PersistenceType = v.(string)
}
if v, ok := d.GetOk("fallback_persistence"); ok {
httpJson.EnableFallbackPersistence = true
httpJson.FallbackPersistenceType = v.(string)
}
if s, ok := d.GetOk("endpoint_ltm_policy"); ok {
var endptPolicy []string
for _, policy := range s.([]interface{}) {
Expand Down
47 changes: 47 additions & 0 deletions bigip/resource_bigip_fast_http_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -65,6 +65,32 @@ func TestAccFastHTTPAppCreateTC02(t *testing.T) {
})
}

func TestAccFastHTTPAppCreateTC03(t *testing.T) {
var httpApp3Name = "fast_http_apptc3"
var httpTenant3Name = "fast_http_tenanttc3"
resource.Test(t, resource.TestCase{
PreCheck: func() {
testAcctPreCheck(t)
},
Providers: testAccProviders,
CheckDestroy: testCheckFastHTTPAppDestroyed,
Steps: []resource.TestStep{
{
Config: getFastHTTPAppConfigTC03(httpTenant3Name, httpApp3Name),
Check: resource.ComposeTestCheckFunc(
//testCheckFastAppExists(httpApp3Name, httpTenant3Name, true),
resource.TestCheckResourceAttr("bigip_fast_http_app.fast_http_app_tc3", "application", httpApp3Name),
resource.TestCheckResourceAttr("bigip_fast_http_app.fast_http_app_tc3", "tenant", httpTenant3Name),
resource.TestCheckResourceAttr("bigip_fast_http_app.fast_http_app_tc3", "virtual_server.0.ip", "10.200.21.2"),
resource.TestCheckResourceAttr("bigip_fast_http_app.fast_http_app_tc3", "virtual_server.0.port", "443"),
resource.TestCheckResourceAttr("bigip_fast_http_app.fast_http_app_tc3", "persistence_profile", "/Common/dest_addr"),
resource.TestCheckResourceAttr("bigip_fast_http_app.fast_http_app_tc3", "fallback_persistence", "source-address"),
),
},
},
})
}

func getFastHTTPAppConfig() string {
return fmt.Sprintf(`
resource "bigip_fast_http_app" "fast_http_app" {
Expand Down Expand Up @@ -97,6 +123,27 @@ resource "bigip_fast_http_app" "fast_http_app_tc2" {
`, httpTenantName, httpAppName)
}

func getFastHTTPAppConfigTC03(httpTenantName, httpAppName string) string {
return fmt.Sprintf(`
resource "bigip_fast_http_app" "fast_http_app_tc3" {
tenant = "%v"
application = "%v"
virtual_server {
ip = "10.200.21.2"
port = 443
}
pool_members {
addresses = ["10.1.20.120", "10.1.10.121", "10.1.10.122"]
port = 80
}
persistence_profile="/Common/dest_addr"
fallback_persistence = "source-address"
load_balancing_mode = "least-connections-member"
endpoint_ltm_policy = ["/Common/testpolicy1"]
}
`, httpTenantName, httpAppName)
}

func testCheckFastHTTPAppDestroyed(s *terraform.State) error {
client := testAccProvider.Meta().(*bigip.BigIP)
for _, rs := range s.RootModule().Resources {
Expand Down
Loading

0 comments on commit 265a247

Please sign in to comment.