{-# 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.KinesisAnalytics.Types.ApplicationSummary -- 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.KinesisAnalytics.Types.ApplicationSummary where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.KinesisAnalytics.Types.ApplicationStatus import qualified Amazonka.Prelude as Prelude -- | This documentation is for version 1 of the Amazon Kinesis Data Analytics -- API, which only supports SQL applications. Version 2 of the API supports -- SQL and Java applications. For more information about version 2, see -- . -- -- Provides application summary information, including the application -- Amazon Resource Name (ARN), name, and status. -- -- /See:/ 'newApplicationSummary' smart constructor. data ApplicationSummary = ApplicationSummary' { -- | Name of the application. applicationName :: Prelude.Text, -- | ARN of the application. applicationARN :: Prelude.Text, -- | Status of the application. applicationStatus :: ApplicationStatus } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ApplicationSummary' 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: -- -- 'applicationName', 'applicationSummary_applicationName' - Name of the application. -- -- 'applicationARN', 'applicationSummary_applicationARN' - ARN of the application. -- -- 'applicationStatus', 'applicationSummary_applicationStatus' - Status of the application. newApplicationSummary :: -- | 'applicationName' Prelude.Text -> -- | 'applicationARN' Prelude.Text -> -- | 'applicationStatus' ApplicationStatus -> ApplicationSummary newApplicationSummary pApplicationName_ pApplicationARN_ pApplicationStatus_ = ApplicationSummary' { applicationName = pApplicationName_, applicationARN = pApplicationARN_, applicationStatus = pApplicationStatus_ } -- | Name of the application. applicationSummary_applicationName :: Lens.Lens' ApplicationSummary Prelude.Text applicationSummary_applicationName = Lens.lens (\ApplicationSummary' {applicationName} -> applicationName) (\s@ApplicationSummary' {} a -> s {applicationName = a} :: ApplicationSummary) -- | ARN of the application. applicationSummary_applicationARN :: Lens.Lens' ApplicationSummary Prelude.Text applicationSummary_applicationARN = Lens.lens (\ApplicationSummary' {applicationARN} -> applicationARN) (\s@ApplicationSummary' {} a -> s {applicationARN = a} :: ApplicationSummary) -- | Status of the application. applicationSummary_applicationStatus :: Lens.Lens' ApplicationSummary ApplicationStatus applicationSummary_applicationStatus = Lens.lens (\ApplicationSummary' {applicationStatus} -> applicationStatus) (\s@ApplicationSummary' {} a -> s {applicationStatus = a} :: ApplicationSummary) instance Data.FromJSON ApplicationSummary where parseJSON = Data.withObject "ApplicationSummary" ( \x -> ApplicationSummary' Prelude.<$> (x Data..: "ApplicationName") Prelude.<*> (x Data..: "ApplicationARN") Prelude.<*> (x Data..: "ApplicationStatus") ) instance Prelude.Hashable ApplicationSummary where hashWithSalt _salt ApplicationSummary' {..} = _salt `Prelude.hashWithSalt` applicationName `Prelude.hashWithSalt` applicationARN `Prelude.hashWithSalt` applicationStatus instance Prelude.NFData ApplicationSummary where rnf ApplicationSummary' {..} = Prelude.rnf applicationName `Prelude.seq` Prelude.rnf applicationARN `Prelude.seq` Prelude.rnf applicationStatus