{-# 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.SSM.Types.AssociationStatus -- 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.SSM.Types.AssociationStatus where 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 import Amazonka.SSM.Types.AssociationStatusName -- | Describes an association status. -- -- /See:/ 'newAssociationStatus' smart constructor. data AssociationStatus = AssociationStatus' { -- | A user-defined string. additionalInfo :: Prelude.Maybe Prelude.Text, -- | The date when the status changed. date :: Data.POSIX, -- | The status. name :: AssociationStatusName, -- | The reason for the status. message :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'AssociationStatus' 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: -- -- 'additionalInfo', 'associationStatus_additionalInfo' - A user-defined string. -- -- 'date', 'associationStatus_date' - The date when the status changed. -- -- 'name', 'associationStatus_name' - The status. -- -- 'message', 'associationStatus_message' - The reason for the status. newAssociationStatus :: -- | 'date' Prelude.UTCTime -> -- | 'name' AssociationStatusName -> -- | 'message' Prelude.Text -> AssociationStatus newAssociationStatus pDate_ pName_ pMessage_ = AssociationStatus' { additionalInfo = Prelude.Nothing, date = Data._Time Lens.# pDate_, name = pName_, message = pMessage_ } -- | A user-defined string. associationStatus_additionalInfo :: Lens.Lens' AssociationStatus (Prelude.Maybe Prelude.Text) associationStatus_additionalInfo = Lens.lens (\AssociationStatus' {additionalInfo} -> additionalInfo) (\s@AssociationStatus' {} a -> s {additionalInfo = a} :: AssociationStatus) -- | The date when the status changed. associationStatus_date :: Lens.Lens' AssociationStatus Prelude.UTCTime associationStatus_date = Lens.lens (\AssociationStatus' {date} -> date) (\s@AssociationStatus' {} a -> s {date = a} :: AssociationStatus) Prelude.. Data._Time -- | The status. associationStatus_name :: Lens.Lens' AssociationStatus AssociationStatusName associationStatus_name = Lens.lens (\AssociationStatus' {name} -> name) (\s@AssociationStatus' {} a -> s {name = a} :: AssociationStatus) -- | The reason for the status. associationStatus_message :: Lens.Lens' AssociationStatus Prelude.Text associationStatus_message = Lens.lens (\AssociationStatus' {message} -> message) (\s@AssociationStatus' {} a -> s {message = a} :: AssociationStatus) instance Data.FromJSON AssociationStatus where parseJSON = Data.withObject "AssociationStatus" ( \x -> AssociationStatus' Prelude.<$> (x Data..:? "AdditionalInfo") Prelude.<*> (x Data..: "Date") Prelude.<*> (x Data..: "Name") Prelude.<*> (x Data..: "Message") ) instance Prelude.Hashable AssociationStatus where hashWithSalt _salt AssociationStatus' {..} = _salt `Prelude.hashWithSalt` additionalInfo `Prelude.hashWithSalt` date `Prelude.hashWithSalt` name `Prelude.hashWithSalt` message instance Prelude.NFData AssociationStatus where rnf AssociationStatus' {..} = Prelude.rnf additionalInfo `Prelude.seq` Prelude.rnf date `Prelude.seq` Prelude.rnf name `Prelude.seq` Prelude.rnf message instance Data.ToJSON AssociationStatus where toJSON AssociationStatus' {..} = Data.object ( Prelude.catMaybes [ ("AdditionalInfo" Data..=) Prelude.<$> additionalInfo, Prelude.Just ("Date" Data..= date), Prelude.Just ("Name" Data..= name), Prelude.Just ("Message" Data..= message) ] )