{-# 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.ECS.Types.ExecuteCommandConfiguration -- 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.ECS.Types.ExecuteCommandConfiguration where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.ECS.Types.ExecuteCommandLogConfiguration import Amazonka.ECS.Types.ExecuteCommandLogging import qualified Amazonka.Prelude as Prelude -- | The details of the execute command configuration. -- -- /See:/ 'newExecuteCommandConfiguration' smart constructor. data ExecuteCommandConfiguration = ExecuteCommandConfiguration' { -- | Specify an Key Management Service key ID to encrypt the data between the -- local client and the container. kmsKeyId :: Prelude.Maybe Prelude.Text, -- | The log configuration for the results of the execute command actions. -- The logs can be sent to CloudWatch Logs or an Amazon S3 bucket. When -- @logging=OVERRIDE@ is specified, a @logConfiguration@ must be provided. logConfiguration :: Prelude.Maybe ExecuteCommandLogConfiguration, -- | The log setting to use for redirecting logs for your execute command -- results. The following log settings are available. -- -- - @NONE@: The execute command session is not logged. -- -- - @DEFAULT@: The @awslogs@ configuration in the task definition is -- used. If no logging parameter is specified, it defaults to this -- value. If no @awslogs@ log driver is configured in the task -- definition, the output won\'t be logged. -- -- - @OVERRIDE@: Specify the logging details as a part of -- @logConfiguration@. If the @OVERRIDE@ logging option is specified, -- the @logConfiguration@ is required. logging :: Prelude.Maybe ExecuteCommandLogging } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ExecuteCommandConfiguration' 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: -- -- 'kmsKeyId', 'executeCommandConfiguration_kmsKeyId' - Specify an Key Management Service key ID to encrypt the data between the -- local client and the container. -- -- 'logConfiguration', 'executeCommandConfiguration_logConfiguration' - The log configuration for the results of the execute command actions. -- The logs can be sent to CloudWatch Logs or an Amazon S3 bucket. When -- @logging=OVERRIDE@ is specified, a @logConfiguration@ must be provided. -- -- 'logging', 'executeCommandConfiguration_logging' - The log setting to use for redirecting logs for your execute command -- results. The following log settings are available. -- -- - @NONE@: The execute command session is not logged. -- -- - @DEFAULT@: The @awslogs@ configuration in the task definition is -- used. If no logging parameter is specified, it defaults to this -- value. If no @awslogs@ log driver is configured in the task -- definition, the output won\'t be logged. -- -- - @OVERRIDE@: Specify the logging details as a part of -- @logConfiguration@. If the @OVERRIDE@ logging option is specified, -- the @logConfiguration@ is required. newExecuteCommandConfiguration :: ExecuteCommandConfiguration newExecuteCommandConfiguration = ExecuteCommandConfiguration' { kmsKeyId = Prelude.Nothing, logConfiguration = Prelude.Nothing, logging = Prelude.Nothing } -- | Specify an Key Management Service key ID to encrypt the data between the -- local client and the container. executeCommandConfiguration_kmsKeyId :: Lens.Lens' ExecuteCommandConfiguration (Prelude.Maybe Prelude.Text) executeCommandConfiguration_kmsKeyId = Lens.lens (\ExecuteCommandConfiguration' {kmsKeyId} -> kmsKeyId) (\s@ExecuteCommandConfiguration' {} a -> s {kmsKeyId = a} :: ExecuteCommandConfiguration) -- | The log configuration for the results of the execute command actions. -- The logs can be sent to CloudWatch Logs or an Amazon S3 bucket. When -- @logging=OVERRIDE@ is specified, a @logConfiguration@ must be provided. executeCommandConfiguration_logConfiguration :: Lens.Lens' ExecuteCommandConfiguration (Prelude.Maybe ExecuteCommandLogConfiguration) executeCommandConfiguration_logConfiguration = Lens.lens (\ExecuteCommandConfiguration' {logConfiguration} -> logConfiguration) (\s@ExecuteCommandConfiguration' {} a -> s {logConfiguration = a} :: ExecuteCommandConfiguration) -- | The log setting to use for redirecting logs for your execute command -- results. The following log settings are available. -- -- - @NONE@: The execute command session is not logged. -- -- - @DEFAULT@: The @awslogs@ configuration in the task definition is -- used. If no logging parameter is specified, it defaults to this -- value. If no @awslogs@ log driver is configured in the task -- definition, the output won\'t be logged. -- -- - @OVERRIDE@: Specify the logging details as a part of -- @logConfiguration@. If the @OVERRIDE@ logging option is specified, -- the @logConfiguration@ is required. executeCommandConfiguration_logging :: Lens.Lens' ExecuteCommandConfiguration (Prelude.Maybe ExecuteCommandLogging) executeCommandConfiguration_logging = Lens.lens (\ExecuteCommandConfiguration' {logging} -> logging) (\s@ExecuteCommandConfiguration' {} a -> s {logging = a} :: ExecuteCommandConfiguration) instance Data.FromJSON ExecuteCommandConfiguration where parseJSON = Data.withObject "ExecuteCommandConfiguration" ( \x -> ExecuteCommandConfiguration' Prelude.<$> (x Data..:? "kmsKeyId") Prelude.<*> (x Data..:? "logConfiguration") Prelude.<*> (x Data..:? "logging") ) instance Prelude.Hashable ExecuteCommandConfiguration where hashWithSalt _salt ExecuteCommandConfiguration' {..} = _salt `Prelude.hashWithSalt` kmsKeyId `Prelude.hashWithSalt` logConfiguration `Prelude.hashWithSalt` logging instance Prelude.NFData ExecuteCommandConfiguration where rnf ExecuteCommandConfiguration' {..} = Prelude.rnf kmsKeyId `Prelude.seq` Prelude.rnf logConfiguration `Prelude.seq` Prelude.rnf logging instance Data.ToJSON ExecuteCommandConfiguration where toJSON ExecuteCommandConfiguration' {..} = Data.object ( Prelude.catMaybes [ ("kmsKeyId" Data..=) Prelude.<$> kmsKeyId, ("logConfiguration" Data..=) Prelude.<$> logConfiguration, ("logging" Data..=) Prelude.<$> logging ] )