// This is an automatically generated code sample.
// To make this code sample work in your Oracle Cloud tenancy,
// please replace the values for any parameters whose current values do not fit
// your use case (such as resource IDs, strings containing ‘EXAMPLE’ or ‘unique_id’, and
// boolean, number, and enum parameters with values not fitting your use case).

package main

import (
	"context"
	"fmt"

	"github.com/oracle/oci-go-sdk/v65/common"
	"github.com/oracle/oci-go-sdk/v65/example/helpers"
	"github.com/oracle/oci-go-sdk/v65/waas"
)

func ExampleUpdateWaasPolicy() {
	// Create a default authentication provider that uses the DEFAULT
	// profile in the configuration file.
	// Refer to <see href="https://docs.cloud.oracle.com/en-us/iaas/Content/API/Concepts/sdkconfig.htm#SDK_and_CLI_Configuration_File>the public documentation</see> on how to prepare a configuration file.
	client, err := waas.NewWaasClientWithConfigurationProvider(common.DefaultConfigProvider())
	helpers.FatalIfError(err)

	// Create a request and dependent object(s).

	req := waas.UpdateWaasPolicyRequest{IfMatch: common.String("EXAMPLE-ifMatch-Value"),
		OpcRequestId:  common.String("PNQFQ72AZ1UP1R3JZSYR<unique_ID>"),
		OpcRetryToken: common.String("EXAMPLE-opcRetryToken-Value"),
		UpdateWaasPolicyDetails: waas.UpdateWaasPolicyDetails{WafConfig: &waas.WafConfig{CustomProtectionRules: []waas.CustomProtectionRuleSetting{waas.CustomProtectionRuleSetting{Action: waas.CustomProtectionRuleSettingActionBlock,
			Exclusions: []waas.ProtectionRuleExclusion{waas.ProtectionRuleExclusion{Exclusions: []string{"EXAMPLE--Value"},
				Target: waas.ProtectionRuleExclusionTargetArgsNames}},
			Id: common.String("ocid1.test.oc1..<unique_ID>EXAMPLE-id-Value")}},
			DeviceFingerprintChallenge: &waas.DeviceFingerprintChallenge{FailureThresholdExpirationInSeconds: common.Int(50400),
				IsEnabled:                          common.Bool(false),
				MaxAddressCount:                    common.Int(1027),
				MaxAddressCountExpirationInSeconds: common.Int(228323),
				Action:                             waas.DeviceFingerprintChallengeActionBlock,
				ActionExpirationInSeconds:          common.Int(417053),
				ChallengeSettings: &waas.BlockChallengeSettings{BlockResponseCode: common.Int(456),
					CaptchaFooter:             common.String("EXAMPLE-captchaFooter-Value"),
					CaptchaSubmitLabel:        common.String("EXAMPLE-captchaSubmitLabel-Value"),
					CaptchaTitle:              common.String("EXAMPLE-captchaTitle-Value"),
					CaptchaHeader:             common.String("EXAMPLE-captchaHeader-Value"),
					BlockAction:               waas.BlockChallengeSettingsBlockActionShowErrorPage,
					BlockErrorPageCode:        common.String("EXAMPLE-blockErrorPageCode-Value"),
					BlockErrorPageDescription: common.String("EXAMPLE-blockErrorPageDescription-Value"),
					BlockErrorPageMessage:     common.String("EXAMPLE-blockErrorPageMessage-Value")},
				FailureThreshold: common.Int(299387)},
			GoodBots: []waas.GoodBot{waas.GoodBot{Description: common.String("EXAMPLE-description-Value"),
				IsEnabled: common.Bool(true),
				Key:       common.String("EXAMPLE-key-Value"),
				Name:      common.String("EXAMPLE-name-Value")}},
			HumanInteractionChallenge: &waas.HumanInteractionChallenge{IsNatEnabled: common.Bool(true),
				RecordingPeriodInSeconds: common.Int(4474),
				SetHttpHeader: &waas.Header{Name: common.String("EXAMPLE-name-Value"),
					Value: common.String("EXAMPLE-value-Value")},
				ActionExpirationInSeconds: common.Int(282222),
				FailureThreshold:          common.Int(376645),
				Action:                    waas.HumanInteractionChallengeActionDetect,
				ChallengeSettings: &waas.BlockChallengeSettings{BlockErrorPageCode: common.String("EXAMPLE-blockErrorPageCode-Value"),
					BlockErrorPageDescription: common.String("EXAMPLE-blockErrorPageDescription-Value"),
					BlockErrorPageMessage:     common.String("EXAMPLE-blockErrorPageMessage-Value"),
					BlockResponseCode:         common.Int(368),
					CaptchaFooter:             common.String("EXAMPLE-captchaFooter-Value"),
					CaptchaHeader:             common.String("EXAMPLE-captchaHeader-Value"),
					CaptchaSubmitLabel:        common.String("EXAMPLE-captchaSubmitLabel-Value"),
					BlockAction:               waas.BlockChallengeSettingsBlockActionShowCaptcha,
					CaptchaTitle:              common.String("EXAMPLE-captchaTitle-Value")},
				FailureThresholdExpirationInSeconds: common.Int(96723),
				InteractionThreshold:                common.Int(18),
				IsEnabled:                           common.Bool(false)},
			ProtectionRules: []waas.ProtectionRule{waas.ProtectionRule{Key: common.String("EXAMPLE-key-Value"),
				Labels:             []string{"EXAMPLE--Value"},
				ModSecurityRuleIds: []string{"EXAMPLE--Value"},
				Name:               common.String("EXAMPLE-name-Value"),
				Action:             waas.ProtectionRuleActionBlock,
				Description:        common.String("EXAMPLE-description-Value"),
				Exclusions: []waas.ProtectionRuleExclusion{waas.ProtectionRuleExclusion{Exclusions: []string{"EXAMPLE--Value"},
					Target: waas.ProtectionRuleExclusionTargetRequestCookieNames}}}},
			Whitelists: []waas.Whitelist{waas.Whitelist{AddressLists: []string{"EXAMPLE--Value"},
				Addresses: []string{"EXAMPLE--Value"},
				Name:      common.String("EXAMPLE-name-Value")}},
			Captchas: []waas.Captcha{waas.Captcha{SubmitLabel: common.String("EXAMPLE-submitLabel-Value"),
				Title:                      common.String("EXAMPLE-title-Value"),
				Url:                        common.String("EXAMPLE-url-Value"),
				FailureMessage:             common.String("EXAMPLE-failureMessage-Value"),
				FooterText:                 common.String("EXAMPLE-footerText-Value"),
				HeaderText:                 common.String("EXAMPLE-headerText-Value"),
				SessionExpirationInSeconds: common.Int(246472)}},
			JsChallenge: &waas.JsChallenge{IsNatEnabled: common.Bool(true),
				Action:                    waas.JsChallengeActionBlock,
				ActionExpirationInSeconds: common.Int(193740),
				AreRedirectsChallenged:    common.Bool(true),
				ChallengeSettings: &waas.BlockChallengeSettings{BlockAction: waas.BlockChallengeSettingsBlockActionSetResponseCode,
					BlockErrorPageDescription: common.String("EXAMPLE-blockErrorPageDescription-Value"),
					CaptchaFooter:             common.String("EXAMPLE-captchaFooter-Value"),
					BlockErrorPageCode:        common.String("EXAMPLE-blockErrorPageCode-Value"),
					BlockErrorPageMessage:     common.String("EXAMPLE-blockErrorPageMessage-Value"),
					BlockResponseCode:         common.Int(341),
					CaptchaHeader:             common.String("EXAMPLE-captchaHeader-Value"),
					CaptchaSubmitLabel:        common.String("EXAMPLE-captchaSubmitLabel-Value"),
					CaptchaTitle:              common.String("EXAMPLE-captchaTitle-Value")},
				Criteria: []waas.AccessRuleCriteria{waas.AccessRuleCriteria{Condition: waas.AccessRuleCriteriaConditionUrlDoesNotStartWith,
					IsCaseSensitive: common.Bool(false),
					Value:           common.String("EXAMPLE-value-Value")}},
				IsEnabled: common.Bool(false),
				SetHttpHeader: &waas.Header{Name: common.String("EXAMPLE-name-Value"),
					Value: common.String("EXAMPLE-value-Value")},
				FailureThreshold: common.Int(327451)},
			ProtectionSettings: &waas.ProtectionSettings{BlockErrorPageDescription: common.String("EXAMPLE-blockErrorPageDescription-Value"),
				IsResponseInspected:           common.Bool(true),
				MaxArgumentCount:              common.Int(8859),
				MaxTotalNameLengthOfArguments: common.Int(184764),
				AllowedHttpMethods:            []waas.ProtectionSettingsAllowedHttpMethodsEnum{waas.ProtectionSettingsAllowedHttpMethodsPatch},
				BlockErrorPageMessage:         common.String("EXAMPLE-blockErrorPageMessage-Value"),
				BlockResponseCode:             common.Int(635),
				MaxNameLengthPerArgument:      common.Int(114287),
				MaxResponseSizeInKiB:          common.Int(160),
				MediaTypes:                    []string{"EXAMPLE--Value"},
				RecommendationsPeriodInDays:   common.Int(75),
				BlockAction:                   waas.ProtectionSettingsBlockActionShowErrorPage,
				BlockErrorPageCode:            common.String("EXAMPLE-blockErrorPageCode-Value")},
			ThreatFeeds: []waas.ThreatFeed{waas.ThreatFeed{Action: waas.ThreatFeedActionBlock,
				Description: common.String("EXAMPLE-description-Value"),
				Key:         common.String("EXAMPLE-key-Value"),
				Name:        common.String("EXAMPLE-name-Value")}},
			AccessRules: []waas.AccessRule{waas.AccessRule{CaptchaFooter: common.String("EXAMPLE-captchaFooter-Value"),
				CaptchaSubmitLabel:         common.String("EXAMPLE-captchaSubmitLabel-Value"),
				Name:                       common.String("EXAMPLE-name-Value"),
				ResponseHeaderManipulation: []waas.HeaderManipulationAction{waas.RemoveHttpResponseHeaderAction{Header: common.String("EXAMPLE-header-Value")}},
				Action:                     waas.AccessRuleActionDetect,
				BlockAction:                waas.AccessRuleBlockActionShowErrorPage,
				CaptchaTitle:               common.String("EXAMPLE-captchaTitle-Value"),
				RedirectUrl:                common.String("EXAMPLE-redirectUrl-Value"),
				BlockErrorPageDescription:  common.String("EXAMPLE-blockErrorPageDescription-Value"),
				BlockResponseCode:          common.Int(380),
				CaptchaHeader:              common.String("EXAMPLE-captchaHeader-Value"),
				BypassChallenges:           []waas.AccessRuleBypassChallengesEnum{waas.AccessRuleBypassChallengesJsChallenge},
				Criteria: []waas.AccessRuleCriteria{waas.AccessRuleCriteria{Value: common.String("EXAMPLE-value-Value"),
					Condition:       waas.AccessRuleCriteriaConditionHttpMethodIs,
					IsCaseSensitive: common.Bool(true)}},
				RedirectResponseCode:  waas.AccessRuleRedirectResponseCodeFound,
				BlockErrorPageCode:    common.String("EXAMPLE-blockErrorPageCode-Value"),
				BlockErrorPageMessage: common.String("EXAMPLE-blockErrorPageMessage-Value")}},
			AddressRateLimiting: &waas.AddressRateLimiting{BlockResponseCode: common.Int(884),
				IsEnabled:                 common.Bool(false),
				MaxDelayedCountPerAddress: common.Int(2136),
				AllowedRatePerAddress:     common.Int(4109)},
			CachingRules: []waas.CachingRule{waas.CachingRule{IsClientCachingEnabled: common.Bool(false),
				Key:                   common.String("EXAMPLE-key-Value"),
				Name:                  common.String("EXAMPLE-name-Value"),
				Action:                waas.CachingRuleActionCache,
				CachingDuration:       common.String("EXAMPLE-cachingDuration-Value"),
				ClientCachingDuration: common.String("EXAMPLE-clientCachingDuration-Value"),
				Criteria: []waas.CachingRuleCriteria{waas.CachingRuleCriteria{Condition: waas.CachingRuleCriteriaConditionStartsWith,
					Value: common.String("EXAMPLE-value-Value")}}}},
			Origin:       common.String("EXAMPLE-origin-Value"),
			OriginGroups: []string{"EXAMPLE--Value"}},
			AdditionalDomains: []string{"EXAMPLE--Value"},
			DefinedTags:       map[string]map[string]interface{}{"EXAMPLE_KEY_MFjH2": map[string]interface{}{"EXAMPLE_KEY_O7upV": "EXAMPLE--Value"}},
			DisplayName:       common.String("EXAMPLE-displayName-Value"),
			FreeformTags:      map[string]string{"EXAMPLE_KEY_skA42": "EXAMPLE_VALUE_37VPTmpTTC1L6Rc89tYm"},
			OriginGroups: map[string]waas.OriginGroup{"EXAMPLE_KEY_vxgdi": waas.OriginGroup{Origins: []waas.OriginGroupOrigins{waas.OriginGroupOrigins{Origin: common.String("EXAMPLE-origin-Value"),
				Weight: common.Int(3191)}}}},
			Origins: map[string]waas.Origin{"EXAMPLE_KEY_D59EA": waas.Origin{HttpsPort: common.Int(37492),
				Uri: common.String("EXAMPLE-uri-Value"),
				CustomHeaders: []waas.Header{waas.Header{Value: common.String("EXAMPLE-value-Value"),
					Name: common.String("EXAMPLE-name-Value")}},
				HttpPort: common.Int(64071)}},
			PolicyConfig: &waas.PolicyConfig{IsHttpsEnabled: common.Bool(true),
				IsResponseBufferingEnabled: common.Bool(true),
				LoadBalancingMethod:        waas.RoundRobinLoadBalancingMethod{},
				TlsProtocols:               []waas.PolicyConfigTlsProtocolsEnum{waas.PolicyConfigTlsProtocolsV13},
				WebsocketPathPrefixes:      []string{"EXAMPLE--Value"},
				CertificateId:              common.String("ocid1.test.oc1..<unique_ID>EXAMPLE-certificateId-Value"),
				CipherGroup:                waas.PolicyConfigCipherGroupDefault,
				ClientAddressHeader:        waas.PolicyConfigClientAddressHeaderTrueClientIp,
				HealthChecks: &waas.HealthCheck{ExpectedResponseText: common.String("EXAMPLE-expectedResponseText-Value"),
					HealthyThreshold:           common.Int(5),
					IntervalInSeconds:          common.Int(41),
					IsEnabled:                  common.Bool(false),
					IsResponseTextCheckEnabled: common.Bool(false),
					Method:                     waas.HealthCheckMethodGet,
					Path:                       common.String("EXAMPLE-path-Value"),
					UnhealthyThreshold:         common.Int(16),
					ExpectedResponseCodeGroup:  []waas.HealthCheckExpectedResponseCodeGroupEnum{waas.HealthCheckExpectedResponseCodeGroup5xx},
					Headers:                    map[string]string{"EXAMPLE_KEY_1otfA": "EXAMPLE_VALUE_tdmiBzRoNCaLVhe7aQXl"},
					TimeoutInSeconds:           common.Int(23)},
				IsCacheControlRespected:    common.Bool(true),
				IsHttpsForced:              common.Bool(true),
				IsOriginCompressionEnabled: common.Bool(false),
				IsSniEnabled:               common.Bool(false),
				IsBehindCdn:                common.Bool(false)}},
		WaasPolicyId: common.String("ocid1.test.oc1..<unique_ID>EXAMPLE-waasPolicyId-Value")}

	// Send the request using the service client
	resp, err := client.UpdateWaasPolicy(context.Background(), req)
	helpers.FatalIfError(err)

	// Retrieve value from the response.
	fmt.Println(resp)
}