{-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE DuplicateRecordFields #-} {-# LANGUAGE NamedFieldPuns #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE StrictData #-} {-# LANGUAGE NoImplicitPrelude #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} {-# OPTIONS_GHC -fno-warn-unused-matches #-} -- Derived from AWS service descriptions, licensed under Apache 2.0. -- | -- Module : Amazonka.CloudSearch.Types.DomainEndpointOptions -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) module Amazonka.CloudSearch.Types.DomainEndpointOptions where import Amazonka.CloudSearch.Types.TLSSecurityPolicy import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import qualified Amazonka.Prelude as Prelude -- | The domain\'s endpoint options. -- -- /See:/ 'newDomainEndpointOptions' smart constructor. data DomainEndpointOptions = DomainEndpointOptions' { -- | Whether the domain is HTTPS only enabled. enforceHTTPS :: Prelude.Maybe Prelude.Bool, -- | The minimum required TLS version tLSSecurityPolicy :: Prelude.Maybe TLSSecurityPolicy } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DomainEndpointOptions' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'enforceHTTPS', 'domainEndpointOptions_enforceHTTPS' - Whether the domain is HTTPS only enabled. -- -- 'tLSSecurityPolicy', 'domainEndpointOptions_tLSSecurityPolicy' - The minimum required TLS version newDomainEndpointOptions :: DomainEndpointOptions newDomainEndpointOptions = DomainEndpointOptions' { enforceHTTPS = Prelude.Nothing, tLSSecurityPolicy = Prelude.Nothing } -- | Whether the domain is HTTPS only enabled. domainEndpointOptions_enforceHTTPS :: Lens.Lens' DomainEndpointOptions (Prelude.Maybe Prelude.Bool) domainEndpointOptions_enforceHTTPS = Lens.lens (\DomainEndpointOptions' {enforceHTTPS} -> enforceHTTPS) (\s@DomainEndpointOptions' {} a -> s {enforceHTTPS = a} :: DomainEndpointOptions) -- | The minimum required TLS version domainEndpointOptions_tLSSecurityPolicy :: Lens.Lens' DomainEndpointOptions (Prelude.Maybe TLSSecurityPolicy) domainEndpointOptions_tLSSecurityPolicy = Lens.lens (\DomainEndpointOptions' {tLSSecurityPolicy} -> tLSSecurityPolicy) (\s@DomainEndpointOptions' {} a -> s {tLSSecurityPolicy = a} :: DomainEndpointOptions) instance Data.FromXML DomainEndpointOptions where parseXML x = DomainEndpointOptions' Prelude.<$> (x Data..@? "EnforceHTTPS") Prelude.<*> (x Data..@? "TLSSecurityPolicy") instance Prelude.Hashable DomainEndpointOptions where hashWithSalt _salt DomainEndpointOptions' {..} = _salt `Prelude.hashWithSalt` enforceHTTPS `Prelude.hashWithSalt` tLSSecurityPolicy instance Prelude.NFData DomainEndpointOptions where rnf DomainEndpointOptions' {..} = Prelude.rnf enforceHTTPS `Prelude.seq` Prelude.rnf tLSSecurityPolicy instance Data.ToQuery DomainEndpointOptions where toQuery DomainEndpointOptions' {..} = Prelude.mconcat [ "EnforceHTTPS" Data.=: enforceHTTPS, "TLSSecurityPolicy" Data.=: tLSSecurityPolicy ]