{-# 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.LexV2Models.Types.Condition -- 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.LexV2Models.Types.Condition 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 -- | Provides an expression that evaluates to true or false. -- -- /See:/ 'newCondition' smart constructor. data Condition = Condition' { -- | The expression string that is evaluated. expressionString :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'Condition' 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: -- -- 'expressionString', 'condition_expressionString' - The expression string that is evaluated. newCondition :: -- | 'expressionString' Prelude.Text -> Condition newCondition pExpressionString_ = Condition' {expressionString = pExpressionString_} -- | The expression string that is evaluated. condition_expressionString :: Lens.Lens' Condition Prelude.Text condition_expressionString = Lens.lens (\Condition' {expressionString} -> expressionString) (\s@Condition' {} a -> s {expressionString = a} :: Condition) instance Data.FromJSON Condition where parseJSON = Data.withObject "Condition" ( \x -> Condition' Prelude.<$> (x Data..: "expressionString") ) instance Prelude.Hashable Condition where hashWithSalt _salt Condition' {..} = _salt `Prelude.hashWithSalt` expressionString instance Prelude.NFData Condition where rnf Condition' {..} = Prelude.rnf expressionString instance Data.ToJSON Condition where toJSON Condition' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("expressionString" Data..= expressionString) ] )