{-# 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.AppMesh.Types.ClientTlsCertificate -- 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.AppMesh.Types.ClientTlsCertificate where import Amazonka.AppMesh.Types.ListenerTlsFileCertificate import Amazonka.AppMesh.Types.ListenerTlsSdsCertificate 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 -- | An object that represents the client\'s certificate. -- -- /See:/ 'newClientTlsCertificate' smart constructor. data ClientTlsCertificate = ClientTlsCertificate' { -- | An object that represents a local file certificate. The certificate must -- meet specific requirements and you must have proxy authorization -- enabled. For more information, see -- . file :: Prelude.Maybe ListenerTlsFileCertificate, -- | A reference to an object that represents a client\'s TLS Secret -- Discovery Service certificate. sds :: Prelude.Maybe ListenerTlsSdsCertificate } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ClientTlsCertificate' 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: -- -- 'file', 'clientTlsCertificate_file' - An object that represents a local file certificate. The certificate must -- meet specific requirements and you must have proxy authorization -- enabled. For more information, see -- . -- -- 'sds', 'clientTlsCertificate_sds' - A reference to an object that represents a client\'s TLS Secret -- Discovery Service certificate. newClientTlsCertificate :: ClientTlsCertificate newClientTlsCertificate = ClientTlsCertificate' { file = Prelude.Nothing, sds = Prelude.Nothing } -- | An object that represents a local file certificate. The certificate must -- meet specific requirements and you must have proxy authorization -- enabled. For more information, see -- . clientTlsCertificate_file :: Lens.Lens' ClientTlsCertificate (Prelude.Maybe ListenerTlsFileCertificate) clientTlsCertificate_file = Lens.lens (\ClientTlsCertificate' {file} -> file) (\s@ClientTlsCertificate' {} a -> s {file = a} :: ClientTlsCertificate) -- | A reference to an object that represents a client\'s TLS Secret -- Discovery Service certificate. clientTlsCertificate_sds :: Lens.Lens' ClientTlsCertificate (Prelude.Maybe ListenerTlsSdsCertificate) clientTlsCertificate_sds = Lens.lens (\ClientTlsCertificate' {sds} -> sds) (\s@ClientTlsCertificate' {} a -> s {sds = a} :: ClientTlsCertificate) instance Data.FromJSON ClientTlsCertificate where parseJSON = Data.withObject "ClientTlsCertificate" ( \x -> ClientTlsCertificate' Prelude.<$> (x Data..:? "file") Prelude.<*> (x Data..:? "sds") ) instance Prelude.Hashable ClientTlsCertificate where hashWithSalt _salt ClientTlsCertificate' {..} = _salt `Prelude.hashWithSalt` file `Prelude.hashWithSalt` sds instance Prelude.NFData ClientTlsCertificate where rnf ClientTlsCertificate' {..} = Prelude.rnf file `Prelude.seq` Prelude.rnf sds instance Data.ToJSON ClientTlsCertificate where toJSON ClientTlsCertificate' {..} = Data.object ( Prelude.catMaybes [ ("file" Data..=) Prelude.<$> file, ("sds" Data..=) Prelude.<$> sds ] )