{-# 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.Redshift.Types.Parameter -- 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.Redshift.Types.Parameter 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.Redshift.Internal import Amazonka.Redshift.Types.ParameterApplyType -- | Describes a parameter in a cluster parameter group. -- -- /See:/ 'newParameter' smart constructor. data Parameter = Parameter' { -- | The valid range of values for the parameter. allowedValues :: Prelude.Maybe Prelude.Text, -- | Specifies how to apply the WLM configuration parameter. Some properties -- can be applied dynamically, while other properties require that any -- associated clusters be rebooted for the configuration changes to be -- applied. For more information about parameters and parameter groups, go -- to -- -- in the /Amazon Redshift Cluster Management Guide/. applyType :: Prelude.Maybe ParameterApplyType, -- | The data type of the parameter. dataType :: Prelude.Maybe Prelude.Text, -- | A description of the parameter. description :: Prelude.Maybe Prelude.Text, -- | If @true@, the parameter can be modified. Some parameters have security -- or operational implications that prevent them from being changed. isModifiable :: Prelude.Maybe Prelude.Bool, -- | The earliest engine version to which the parameter can apply. minimumEngineVersion :: Prelude.Maybe Prelude.Text, -- | The name of the parameter. parameterName :: Prelude.Maybe Prelude.Text, -- | The value of the parameter. If @ParameterName@ is -- @wlm_json_configuration@, then the maximum size of @ParameterValue@ is -- 8000 characters. parameterValue :: Prelude.Maybe Prelude.Text, -- | The source of the parameter value, such as \"engine-default\" or -- \"user\". source :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'Parameter' 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: -- -- 'allowedValues', 'parameter_allowedValues' - The valid range of values for the parameter. -- -- 'applyType', 'parameter_applyType' - Specifies how to apply the WLM configuration parameter. Some properties -- can be applied dynamically, while other properties require that any -- associated clusters be rebooted for the configuration changes to be -- applied. For more information about parameters and parameter groups, go -- to -- -- in the /Amazon Redshift Cluster Management Guide/. -- -- 'dataType', 'parameter_dataType' - The data type of the parameter. -- -- 'description', 'parameter_description' - A description of the parameter. -- -- 'isModifiable', 'parameter_isModifiable' - If @true@, the parameter can be modified. Some parameters have security -- or operational implications that prevent them from being changed. -- -- 'minimumEngineVersion', 'parameter_minimumEngineVersion' - The earliest engine version to which the parameter can apply. -- -- 'parameterName', 'parameter_parameterName' - The name of the parameter. -- -- 'parameterValue', 'parameter_parameterValue' - The value of the parameter. If @ParameterName@ is -- @wlm_json_configuration@, then the maximum size of @ParameterValue@ is -- 8000 characters. -- -- 'source', 'parameter_source' - The source of the parameter value, such as \"engine-default\" or -- \"user\". newParameter :: Parameter newParameter = Parameter' { allowedValues = Prelude.Nothing, applyType = Prelude.Nothing, dataType = Prelude.Nothing, description = Prelude.Nothing, isModifiable = Prelude.Nothing, minimumEngineVersion = Prelude.Nothing, parameterName = Prelude.Nothing, parameterValue = Prelude.Nothing, source = Prelude.Nothing } -- | The valid range of values for the parameter. parameter_allowedValues :: Lens.Lens' Parameter (Prelude.Maybe Prelude.Text) parameter_allowedValues = Lens.lens (\Parameter' {allowedValues} -> allowedValues) (\s@Parameter' {} a -> s {allowedValues = a} :: Parameter) -- | Specifies how to apply the WLM configuration parameter. Some properties -- can be applied dynamically, while other properties require that any -- associated clusters be rebooted for the configuration changes to be -- applied. For more information about parameters and parameter groups, go -- to -- -- in the /Amazon Redshift Cluster Management Guide/. parameter_applyType :: Lens.Lens' Parameter (Prelude.Maybe ParameterApplyType) parameter_applyType = Lens.lens (\Parameter' {applyType} -> applyType) (\s@Parameter' {} a -> s {applyType = a} :: Parameter) -- | The data type of the parameter. parameter_dataType :: Lens.Lens' Parameter (Prelude.Maybe Prelude.Text) parameter_dataType = Lens.lens (\Parameter' {dataType} -> dataType) (\s@Parameter' {} a -> s {dataType = a} :: Parameter) -- | A description of the parameter. parameter_description :: Lens.Lens' Parameter (Prelude.Maybe Prelude.Text) parameter_description = Lens.lens (\Parameter' {description} -> description) (\s@Parameter' {} a -> s {description = a} :: Parameter) -- | If @true@, the parameter can be modified. Some parameters have security -- or operational implications that prevent them from being changed. parameter_isModifiable :: Lens.Lens' Parameter (Prelude.Maybe Prelude.Bool) parameter_isModifiable = Lens.lens (\Parameter' {isModifiable} -> isModifiable) (\s@Parameter' {} a -> s {isModifiable = a} :: Parameter) -- | The earliest engine version to which the parameter can apply. parameter_minimumEngineVersion :: Lens.Lens' Parameter (Prelude.Maybe Prelude.Text) parameter_minimumEngineVersion = Lens.lens (\Parameter' {minimumEngineVersion} -> minimumEngineVersion) (\s@Parameter' {} a -> s {minimumEngineVersion = a} :: Parameter) -- | The name of the parameter. parameter_parameterName :: Lens.Lens' Parameter (Prelude.Maybe Prelude.Text) parameter_parameterName = Lens.lens (\Parameter' {parameterName} -> parameterName) (\s@Parameter' {} a -> s {parameterName = a} :: Parameter) -- | The value of the parameter. If @ParameterName@ is -- @wlm_json_configuration@, then the maximum size of @ParameterValue@ is -- 8000 characters. parameter_parameterValue :: Lens.Lens' Parameter (Prelude.Maybe Prelude.Text) parameter_parameterValue = Lens.lens (\Parameter' {parameterValue} -> parameterValue) (\s@Parameter' {} a -> s {parameterValue = a} :: Parameter) -- | The source of the parameter value, such as \"engine-default\" or -- \"user\". parameter_source :: Lens.Lens' Parameter (Prelude.Maybe Prelude.Text) parameter_source = Lens.lens (\Parameter' {source} -> source) (\s@Parameter' {} a -> s {source = a} :: Parameter) instance Data.FromXML Parameter where parseXML x = Parameter' Prelude.<$> (x Data..@? "AllowedValues") Prelude.<*> (x Data..@? "ApplyType") Prelude.<*> (x Data..@? "DataType") Prelude.<*> (x Data..@? "Description") Prelude.<*> (x Data..@? "IsModifiable") Prelude.<*> (x Data..@? "MinimumEngineVersion") Prelude.<*> (x Data..@? "ParameterName") Prelude.<*> (x Data..@? "ParameterValue") Prelude.<*> (x Data..@? "Source") instance Prelude.Hashable Parameter where hashWithSalt _salt Parameter' {..} = _salt `Prelude.hashWithSalt` allowedValues `Prelude.hashWithSalt` applyType `Prelude.hashWithSalt` dataType `Prelude.hashWithSalt` description `Prelude.hashWithSalt` isModifiable `Prelude.hashWithSalt` minimumEngineVersion `Prelude.hashWithSalt` parameterName `Prelude.hashWithSalt` parameterValue `Prelude.hashWithSalt` source instance Prelude.NFData Parameter where rnf Parameter' {..} = Prelude.rnf allowedValues `Prelude.seq` Prelude.rnf applyType `Prelude.seq` Prelude.rnf dataType `Prelude.seq` Prelude.rnf description `Prelude.seq` Prelude.rnf isModifiable `Prelude.seq` Prelude.rnf minimumEngineVersion `Prelude.seq` Prelude.rnf parameterName `Prelude.seq` Prelude.rnf parameterValue `Prelude.seq` Prelude.rnf source instance Data.ToQuery Parameter where toQuery Parameter' {..} = Prelude.mconcat [ "AllowedValues" Data.=: allowedValues, "ApplyType" Data.=: applyType, "DataType" Data.=: dataType, "Description" Data.=: description, "IsModifiable" Data.=: isModifiable, "MinimumEngineVersion" Data.=: minimumEngineVersion, "ParameterName" Data.=: parameterName, "ParameterValue" Data.=: parameterValue, "Source" Data.=: source ]