{-# 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.IAM.Types.ServerCertificate -- 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.IAM.Types.ServerCertificate where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.IAM.Types.ServerCertificateMetadata import Amazonka.IAM.Types.Tag import qualified Amazonka.Prelude as Prelude -- | Contains information about a server certificate. -- -- This data type is used as a response element in the GetServerCertificate -- operation. -- -- /See:/ 'newServerCertificate' smart constructor. data ServerCertificate = ServerCertificate' { -- | The contents of the public key certificate chain. certificateChain :: Prelude.Maybe Prelude.Text, -- | A list of tags that are attached to the server certificate. For more -- information about tagging, see -- -- in the /IAM User Guide/. tags :: Prelude.Maybe [Tag], -- | The meta information of the server certificate, such as its name, path, -- ID, and ARN. serverCertificateMetadata :: ServerCertificateMetadata, -- | The contents of the public key certificate. certificateBody :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ServerCertificate' 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: -- -- 'certificateChain', 'serverCertificate_certificateChain' - The contents of the public key certificate chain. -- -- 'tags', 'serverCertificate_tags' - A list of tags that are attached to the server certificate. For more -- information about tagging, see -- -- in the /IAM User Guide/. -- -- 'serverCertificateMetadata', 'serverCertificate_serverCertificateMetadata' - The meta information of the server certificate, such as its name, path, -- ID, and ARN. -- -- 'certificateBody', 'serverCertificate_certificateBody' - The contents of the public key certificate. newServerCertificate :: -- | 'serverCertificateMetadata' ServerCertificateMetadata -> -- | 'certificateBody' Prelude.Text -> ServerCertificate newServerCertificate pServerCertificateMetadata_ pCertificateBody_ = ServerCertificate' { certificateChain = Prelude.Nothing, tags = Prelude.Nothing, serverCertificateMetadata = pServerCertificateMetadata_, certificateBody = pCertificateBody_ } -- | The contents of the public key certificate chain. serverCertificate_certificateChain :: Lens.Lens' ServerCertificate (Prelude.Maybe Prelude.Text) serverCertificate_certificateChain = Lens.lens (\ServerCertificate' {certificateChain} -> certificateChain) (\s@ServerCertificate' {} a -> s {certificateChain = a} :: ServerCertificate) -- | A list of tags that are attached to the server certificate. For more -- information about tagging, see -- -- in the /IAM User Guide/. serverCertificate_tags :: Lens.Lens' ServerCertificate (Prelude.Maybe [Tag]) serverCertificate_tags = Lens.lens (\ServerCertificate' {tags} -> tags) (\s@ServerCertificate' {} a -> s {tags = a} :: ServerCertificate) Prelude.. Lens.mapping Lens.coerced -- | The meta information of the server certificate, such as its name, path, -- ID, and ARN. serverCertificate_serverCertificateMetadata :: Lens.Lens' ServerCertificate ServerCertificateMetadata serverCertificate_serverCertificateMetadata = Lens.lens (\ServerCertificate' {serverCertificateMetadata} -> serverCertificateMetadata) (\s@ServerCertificate' {} a -> s {serverCertificateMetadata = a} :: ServerCertificate) -- | The contents of the public key certificate. serverCertificate_certificateBody :: Lens.Lens' ServerCertificate Prelude.Text serverCertificate_certificateBody = Lens.lens (\ServerCertificate' {certificateBody} -> certificateBody) (\s@ServerCertificate' {} a -> s {certificateBody = a} :: ServerCertificate) instance Data.FromXML ServerCertificate where parseXML x = ServerCertificate' Prelude.<$> (x Data..@? "CertificateChain") Prelude.<*> ( x Data..@? "Tags" Core..!@ Prelude.mempty Prelude.>>= Core.may (Data.parseXMLList "member") ) Prelude.<*> (x Data..@ "ServerCertificateMetadata") Prelude.<*> (x Data..@ "CertificateBody") instance Prelude.Hashable ServerCertificate where hashWithSalt _salt ServerCertificate' {..} = _salt `Prelude.hashWithSalt` certificateChain `Prelude.hashWithSalt` tags `Prelude.hashWithSalt` serverCertificateMetadata `Prelude.hashWithSalt` certificateBody instance Prelude.NFData ServerCertificate where rnf ServerCertificate' {..} = Prelude.rnf certificateChain `Prelude.seq` Prelude.rnf tags `Prelude.seq` Prelude.rnf serverCertificateMetadata `Prelude.seq` Prelude.rnf certificateBody