{-# 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.ELBV2.Types.RuleCondition
-- 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.ELBV2.Types.RuleCondition where

import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.ELBV2.Types.HostHeaderConditionConfig
import Amazonka.ELBV2.Types.HttpHeaderConditionConfig
import Amazonka.ELBV2.Types.HttpRequestMethodConditionConfig
import Amazonka.ELBV2.Types.PathPatternConditionConfig
import Amazonka.ELBV2.Types.QueryStringConditionConfig
import Amazonka.ELBV2.Types.SourceIpConditionConfig
import qualified Amazonka.Prelude as Prelude

-- | Information about a condition for a rule.
--
-- Each rule can optionally include up to one of each of the following
-- conditions: @http-request-method@, @host-header@, @path-pattern@, and
-- @source-ip@. Each rule can also optionally include one or more of each
-- of the following conditions: @http-header@ and @query-string@. Note that
-- the value for a condition cannot be empty.
--
-- /See:/ 'newRuleCondition' smart constructor.
data RuleCondition = RuleCondition'
  { -- | The field in the HTTP request. The following are the possible values:
    --
    -- -   @http-header@
    --
    -- -   @http-request-method@
    --
    -- -   @host-header@
    --
    -- -   @path-pattern@
    --
    -- -   @query-string@
    --
    -- -   @source-ip@
    RuleCondition -> Maybe Text
field :: Prelude.Maybe Prelude.Text,
    -- | Information for a host header condition. Specify only when @Field@ is
    -- @host-header@.
    RuleCondition -> Maybe HostHeaderConditionConfig
hostHeaderConfig :: Prelude.Maybe HostHeaderConditionConfig,
    -- | Information for an HTTP header condition. Specify only when @Field@ is
    -- @http-header@.
    RuleCondition -> Maybe HttpHeaderConditionConfig
httpHeaderConfig :: Prelude.Maybe HttpHeaderConditionConfig,
    -- | Information for an HTTP method condition. Specify only when @Field@ is
    -- @http-request-method@.
    RuleCondition -> Maybe HttpRequestMethodConditionConfig
httpRequestMethodConfig :: Prelude.Maybe HttpRequestMethodConditionConfig,
    -- | Information for a path pattern condition. Specify only when @Field@ is
    -- @path-pattern@.
    RuleCondition -> Maybe PathPatternConditionConfig
pathPatternConfig :: Prelude.Maybe PathPatternConditionConfig,
    -- | Information for a query string condition. Specify only when @Field@ is
    -- @query-string@.
    RuleCondition -> Maybe QueryStringConditionConfig
queryStringConfig :: Prelude.Maybe QueryStringConditionConfig,
    -- | Information for a source IP condition. Specify only when @Field@ is
    -- @source-ip@.
    RuleCondition -> Maybe SourceIpConditionConfig
sourceIpConfig :: Prelude.Maybe SourceIpConditionConfig,
    -- | The condition value. Specify only when @Field@ is @host-header@ or
    -- @path-pattern@. Alternatively, to specify multiple host names or
    -- multiple path patterns, use @HostHeaderConfig@ or @PathPatternConfig@.
    --
    -- If @Field@ is @host-header@ and you are not using @HostHeaderConfig@,
    -- you can specify a single host name (for example, my.example.com) in
    -- @Values@. A host name is case insensitive, can be up to 128 characters
    -- in length, and can contain any of the following characters.
    --
    -- -   A-Z, a-z, 0-9
    --
    -- -   - .
    --
    -- -   * (matches 0 or more characters)
    --
    -- -   ? (matches exactly 1 character)
    --
    -- If @Field@ is @path-pattern@ and you are not using @PathPatternConfig@,
    -- you can specify a single path pattern (for example, \/img\/*) in
    -- @Values@. A path pattern is case-sensitive, can be up to 128 characters
    -- in length, and can contain any of the following characters.
    --
    -- -   A-Z, a-z, 0-9
    --
    -- -   _ - . $ \/ ~ \" \' \@ : +
    --
    -- -   & (using &)
    --
    -- -   * (matches 0 or more characters)
    --
    -- -   ? (matches exactly 1 character)
    RuleCondition -> Maybe [Text]
values :: Prelude.Maybe [Prelude.Text]
  }
  deriving (RuleCondition -> RuleCondition -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: RuleCondition -> RuleCondition -> Bool
$c/= :: RuleCondition -> RuleCondition -> Bool
== :: RuleCondition -> RuleCondition -> Bool
$c== :: RuleCondition -> RuleCondition -> Bool
Prelude.Eq, ReadPrec [RuleCondition]
ReadPrec RuleCondition
Int -> ReadS RuleCondition
ReadS [RuleCondition]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [RuleCondition]
$creadListPrec :: ReadPrec [RuleCondition]
readPrec :: ReadPrec RuleCondition
$creadPrec :: ReadPrec RuleCondition
readList :: ReadS [RuleCondition]
$creadList :: ReadS [RuleCondition]
readsPrec :: Int -> ReadS RuleCondition
$creadsPrec :: Int -> ReadS RuleCondition
Prelude.Read, Int -> RuleCondition -> ShowS
[RuleCondition] -> ShowS
RuleCondition -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [RuleCondition] -> ShowS
$cshowList :: [RuleCondition] -> ShowS
show :: RuleCondition -> String
$cshow :: RuleCondition -> String
showsPrec :: Int -> RuleCondition -> ShowS
$cshowsPrec :: Int -> RuleCondition -> ShowS
Prelude.Show, forall x. Rep RuleCondition x -> RuleCondition
forall x. RuleCondition -> Rep RuleCondition x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep RuleCondition x -> RuleCondition
$cfrom :: forall x. RuleCondition -> Rep RuleCondition x
Prelude.Generic)

-- |
-- Create a value of 'RuleCondition' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'field', 'ruleCondition_field' - The field in the HTTP request. The following are the possible values:
--
-- -   @http-header@
--
-- -   @http-request-method@
--
-- -   @host-header@
--
-- -   @path-pattern@
--
-- -   @query-string@
--
-- -   @source-ip@
--
-- 'hostHeaderConfig', 'ruleCondition_hostHeaderConfig' - Information for a host header condition. Specify only when @Field@ is
-- @host-header@.
--
-- 'httpHeaderConfig', 'ruleCondition_httpHeaderConfig' - Information for an HTTP header condition. Specify only when @Field@ is
-- @http-header@.
--
-- 'httpRequestMethodConfig', 'ruleCondition_httpRequestMethodConfig' - Information for an HTTP method condition. Specify only when @Field@ is
-- @http-request-method@.
--
-- 'pathPatternConfig', 'ruleCondition_pathPatternConfig' - Information for a path pattern condition. Specify only when @Field@ is
-- @path-pattern@.
--
-- 'queryStringConfig', 'ruleCondition_queryStringConfig' - Information for a query string condition. Specify only when @Field@ is
-- @query-string@.
--
-- 'sourceIpConfig', 'ruleCondition_sourceIpConfig' - Information for a source IP condition. Specify only when @Field@ is
-- @source-ip@.
--
-- 'values', 'ruleCondition_values' - The condition value. Specify only when @Field@ is @host-header@ or
-- @path-pattern@. Alternatively, to specify multiple host names or
-- multiple path patterns, use @HostHeaderConfig@ or @PathPatternConfig@.
--
-- If @Field@ is @host-header@ and you are not using @HostHeaderConfig@,
-- you can specify a single host name (for example, my.example.com) in
-- @Values@. A host name is case insensitive, can be up to 128 characters
-- in length, and can contain any of the following characters.
--
-- -   A-Z, a-z, 0-9
--
-- -   - .
--
-- -   * (matches 0 or more characters)
--
-- -   ? (matches exactly 1 character)
--
-- If @Field@ is @path-pattern@ and you are not using @PathPatternConfig@,
-- you can specify a single path pattern (for example, \/img\/*) in
-- @Values@. A path pattern is case-sensitive, can be up to 128 characters
-- in length, and can contain any of the following characters.
--
-- -   A-Z, a-z, 0-9
--
-- -   _ - . $ \/ ~ \" \' \@ : +
--
-- -   & (using &amp;)
--
-- -   * (matches 0 or more characters)
--
-- -   ? (matches exactly 1 character)
newRuleCondition ::
  RuleCondition
newRuleCondition :: RuleCondition
newRuleCondition =
  RuleCondition'
    { $sel:field:RuleCondition' :: Maybe Text
field = forall a. Maybe a
Prelude.Nothing,
      $sel:hostHeaderConfig:RuleCondition' :: Maybe HostHeaderConditionConfig
hostHeaderConfig = forall a. Maybe a
Prelude.Nothing,
      $sel:httpHeaderConfig:RuleCondition' :: Maybe HttpHeaderConditionConfig
httpHeaderConfig = forall a. Maybe a
Prelude.Nothing,
      $sel:httpRequestMethodConfig:RuleCondition' :: Maybe HttpRequestMethodConditionConfig
httpRequestMethodConfig = forall a. Maybe a
Prelude.Nothing,
      $sel:pathPatternConfig:RuleCondition' :: Maybe PathPatternConditionConfig
pathPatternConfig = forall a. Maybe a
Prelude.Nothing,
      $sel:queryStringConfig:RuleCondition' :: Maybe QueryStringConditionConfig
queryStringConfig = forall a. Maybe a
Prelude.Nothing,
      $sel:sourceIpConfig:RuleCondition' :: Maybe SourceIpConditionConfig
sourceIpConfig = forall a. Maybe a
Prelude.Nothing,
      $sel:values:RuleCondition' :: Maybe [Text]
values = forall a. Maybe a
Prelude.Nothing
    }

-- | The field in the HTTP request. The following are the possible values:
--
-- -   @http-header@
--
-- -   @http-request-method@
--
-- -   @host-header@
--
-- -   @path-pattern@
--
-- -   @query-string@
--
-- -   @source-ip@
ruleCondition_field :: Lens.Lens' RuleCondition (Prelude.Maybe Prelude.Text)
ruleCondition_field :: Lens' RuleCondition (Maybe Text)
ruleCondition_field = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\RuleCondition' {Maybe Text
field :: Maybe Text
$sel:field:RuleCondition' :: RuleCondition -> Maybe Text
field} -> Maybe Text
field) (\s :: RuleCondition
s@RuleCondition' {} Maybe Text
a -> RuleCondition
s {$sel:field:RuleCondition' :: Maybe Text
field = Maybe Text
a} :: RuleCondition)

-- | Information for a host header condition. Specify only when @Field@ is
-- @host-header@.
ruleCondition_hostHeaderConfig :: Lens.Lens' RuleCondition (Prelude.Maybe HostHeaderConditionConfig)
ruleCondition_hostHeaderConfig :: Lens' RuleCondition (Maybe HostHeaderConditionConfig)
ruleCondition_hostHeaderConfig = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\RuleCondition' {Maybe HostHeaderConditionConfig
hostHeaderConfig :: Maybe HostHeaderConditionConfig
$sel:hostHeaderConfig:RuleCondition' :: RuleCondition -> Maybe HostHeaderConditionConfig
hostHeaderConfig} -> Maybe HostHeaderConditionConfig
hostHeaderConfig) (\s :: RuleCondition
s@RuleCondition' {} Maybe HostHeaderConditionConfig
a -> RuleCondition
s {$sel:hostHeaderConfig:RuleCondition' :: Maybe HostHeaderConditionConfig
hostHeaderConfig = Maybe HostHeaderConditionConfig
a} :: RuleCondition)

-- | Information for an HTTP header condition. Specify only when @Field@ is
-- @http-header@.
ruleCondition_httpHeaderConfig :: Lens.Lens' RuleCondition (Prelude.Maybe HttpHeaderConditionConfig)
ruleCondition_httpHeaderConfig :: Lens' RuleCondition (Maybe HttpHeaderConditionConfig)
ruleCondition_httpHeaderConfig = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\RuleCondition' {Maybe HttpHeaderConditionConfig
httpHeaderConfig :: Maybe HttpHeaderConditionConfig
$sel:httpHeaderConfig:RuleCondition' :: RuleCondition -> Maybe HttpHeaderConditionConfig
httpHeaderConfig} -> Maybe HttpHeaderConditionConfig
httpHeaderConfig) (\s :: RuleCondition
s@RuleCondition' {} Maybe HttpHeaderConditionConfig
a -> RuleCondition
s {$sel:httpHeaderConfig:RuleCondition' :: Maybe HttpHeaderConditionConfig
httpHeaderConfig = Maybe HttpHeaderConditionConfig
a} :: RuleCondition)

-- | Information for an HTTP method condition. Specify only when @Field@ is
-- @http-request-method@.
ruleCondition_httpRequestMethodConfig :: Lens.Lens' RuleCondition (Prelude.Maybe HttpRequestMethodConditionConfig)
ruleCondition_httpRequestMethodConfig :: Lens' RuleCondition (Maybe HttpRequestMethodConditionConfig)
ruleCondition_httpRequestMethodConfig = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\RuleCondition' {Maybe HttpRequestMethodConditionConfig
httpRequestMethodConfig :: Maybe HttpRequestMethodConditionConfig
$sel:httpRequestMethodConfig:RuleCondition' :: RuleCondition -> Maybe HttpRequestMethodConditionConfig
httpRequestMethodConfig} -> Maybe HttpRequestMethodConditionConfig
httpRequestMethodConfig) (\s :: RuleCondition
s@RuleCondition' {} Maybe HttpRequestMethodConditionConfig
a -> RuleCondition
s {$sel:httpRequestMethodConfig:RuleCondition' :: Maybe HttpRequestMethodConditionConfig
httpRequestMethodConfig = Maybe HttpRequestMethodConditionConfig
a} :: RuleCondition)

-- | Information for a path pattern condition. Specify only when @Field@ is
-- @path-pattern@.
ruleCondition_pathPatternConfig :: Lens.Lens' RuleCondition (Prelude.Maybe PathPatternConditionConfig)
ruleCondition_pathPatternConfig :: Lens' RuleCondition (Maybe PathPatternConditionConfig)
ruleCondition_pathPatternConfig = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\RuleCondition' {Maybe PathPatternConditionConfig
pathPatternConfig :: Maybe PathPatternConditionConfig
$sel:pathPatternConfig:RuleCondition' :: RuleCondition -> Maybe PathPatternConditionConfig
pathPatternConfig} -> Maybe PathPatternConditionConfig
pathPatternConfig) (\s :: RuleCondition
s@RuleCondition' {} Maybe PathPatternConditionConfig
a -> RuleCondition
s {$sel:pathPatternConfig:RuleCondition' :: Maybe PathPatternConditionConfig
pathPatternConfig = Maybe PathPatternConditionConfig
a} :: RuleCondition)

-- | Information for a query string condition. Specify only when @Field@ is
-- @query-string@.
ruleCondition_queryStringConfig :: Lens.Lens' RuleCondition (Prelude.Maybe QueryStringConditionConfig)
ruleCondition_queryStringConfig :: Lens' RuleCondition (Maybe QueryStringConditionConfig)
ruleCondition_queryStringConfig = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\RuleCondition' {Maybe QueryStringConditionConfig
queryStringConfig :: Maybe QueryStringConditionConfig
$sel:queryStringConfig:RuleCondition' :: RuleCondition -> Maybe QueryStringConditionConfig
queryStringConfig} -> Maybe QueryStringConditionConfig
queryStringConfig) (\s :: RuleCondition
s@RuleCondition' {} Maybe QueryStringConditionConfig
a -> RuleCondition
s {$sel:queryStringConfig:RuleCondition' :: Maybe QueryStringConditionConfig
queryStringConfig = Maybe QueryStringConditionConfig
a} :: RuleCondition)

-- | Information for a source IP condition. Specify only when @Field@ is
-- @source-ip@.
ruleCondition_sourceIpConfig :: Lens.Lens' RuleCondition (Prelude.Maybe SourceIpConditionConfig)
ruleCondition_sourceIpConfig :: Lens' RuleCondition (Maybe SourceIpConditionConfig)
ruleCondition_sourceIpConfig = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\RuleCondition' {Maybe SourceIpConditionConfig
sourceIpConfig :: Maybe SourceIpConditionConfig
$sel:sourceIpConfig:RuleCondition' :: RuleCondition -> Maybe SourceIpConditionConfig
sourceIpConfig} -> Maybe SourceIpConditionConfig
sourceIpConfig) (\s :: RuleCondition
s@RuleCondition' {} Maybe SourceIpConditionConfig
a -> RuleCondition
s {$sel:sourceIpConfig:RuleCondition' :: Maybe SourceIpConditionConfig
sourceIpConfig = Maybe SourceIpConditionConfig
a} :: RuleCondition)

-- | The condition value. Specify only when @Field@ is @host-header@ or
-- @path-pattern@. Alternatively, to specify multiple host names or
-- multiple path patterns, use @HostHeaderConfig@ or @PathPatternConfig@.
--
-- If @Field@ is @host-header@ and you are not using @HostHeaderConfig@,
-- you can specify a single host name (for example, my.example.com) in
-- @Values@. A host name is case insensitive, can be up to 128 characters
-- in length, and can contain any of the following characters.
--
-- -   A-Z, a-z, 0-9
--
-- -   - .
--
-- -   * (matches 0 or more characters)
--
-- -   ? (matches exactly 1 character)
--
-- If @Field@ is @path-pattern@ and you are not using @PathPatternConfig@,
-- you can specify a single path pattern (for example, \/img\/*) in
-- @Values@. A path pattern is case-sensitive, can be up to 128 characters
-- in length, and can contain any of the following characters.
--
-- -   A-Z, a-z, 0-9
--
-- -   _ - . $ \/ ~ \" \' \@ : +
--
-- -   & (using &amp;)
--
-- -   * (matches 0 or more characters)
--
-- -   ? (matches exactly 1 character)
ruleCondition_values :: Lens.Lens' RuleCondition (Prelude.Maybe [Prelude.Text])
ruleCondition_values :: Lens' RuleCondition (Maybe [Text])
ruleCondition_values = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\RuleCondition' {Maybe [Text]
values :: Maybe [Text]
$sel:values:RuleCondition' :: RuleCondition -> Maybe [Text]
values} -> Maybe [Text]
values) (\s :: RuleCondition
s@RuleCondition' {} Maybe [Text]
a -> RuleCondition
s {$sel:values:RuleCondition' :: Maybe [Text]
values = Maybe [Text]
a} :: RuleCondition) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall (f :: * -> *) (g :: * -> *) s t a b.
(Functor f, Functor g) =>
AnIso s t a b -> Iso (f s) (g t) (f a) (g b)
Lens.mapping forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced

instance Data.FromXML RuleCondition where
  parseXML :: [Node] -> Either String RuleCondition
parseXML [Node]
x =
    Maybe Text
-> Maybe HostHeaderConditionConfig
-> Maybe HttpHeaderConditionConfig
-> Maybe HttpRequestMethodConditionConfig
-> Maybe PathPatternConditionConfig
-> Maybe QueryStringConditionConfig
-> Maybe SourceIpConditionConfig
-> Maybe [Text]
-> RuleCondition
RuleCondition'
      forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> ([Node]
x forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"Field")
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> ([Node]
x forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"HostHeaderConfig")
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> ([Node]
x forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"HttpHeaderConfig")
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> ([Node]
x forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"HttpRequestMethodConfig")
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> ([Node]
x forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"PathPatternConfig")
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> ([Node]
x forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"QueryStringConfig")
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> ([Node]
x forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"SourceIpConfig")
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> ( [Node]
x
                      forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"Values"
                      forall (f :: * -> *) a. Functor f => f (Maybe a) -> a -> f a
Core..!@ forall a. Monoid a => a
Prelude.mempty
                      forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
Prelude.>>= forall (f :: * -> *) a b.
Applicative f =>
([a] -> f b) -> [a] -> f (Maybe b)
Core.may (forall a. FromXML a => Text -> [Node] -> Either String [a]
Data.parseXMLList Text
"member")
                  )

instance Prelude.Hashable RuleCondition where
  hashWithSalt :: Int -> RuleCondition -> Int
hashWithSalt Int
_salt RuleCondition' {Maybe [Text]
Maybe Text
Maybe HostHeaderConditionConfig
Maybe HttpHeaderConditionConfig
Maybe HttpRequestMethodConditionConfig
Maybe PathPatternConditionConfig
Maybe QueryStringConditionConfig
Maybe SourceIpConditionConfig
values :: Maybe [Text]
sourceIpConfig :: Maybe SourceIpConditionConfig
queryStringConfig :: Maybe QueryStringConditionConfig
pathPatternConfig :: Maybe PathPatternConditionConfig
httpRequestMethodConfig :: Maybe HttpRequestMethodConditionConfig
httpHeaderConfig :: Maybe HttpHeaderConditionConfig
hostHeaderConfig :: Maybe HostHeaderConditionConfig
field :: Maybe Text
$sel:values:RuleCondition' :: RuleCondition -> Maybe [Text]
$sel:sourceIpConfig:RuleCondition' :: RuleCondition -> Maybe SourceIpConditionConfig
$sel:queryStringConfig:RuleCondition' :: RuleCondition -> Maybe QueryStringConditionConfig
$sel:pathPatternConfig:RuleCondition' :: RuleCondition -> Maybe PathPatternConditionConfig
$sel:httpRequestMethodConfig:RuleCondition' :: RuleCondition -> Maybe HttpRequestMethodConditionConfig
$sel:httpHeaderConfig:RuleCondition' :: RuleCondition -> Maybe HttpHeaderConditionConfig
$sel:hostHeaderConfig:RuleCondition' :: RuleCondition -> Maybe HostHeaderConditionConfig
$sel:field:RuleCondition' :: RuleCondition -> Maybe Text
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
field
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe HostHeaderConditionConfig
hostHeaderConfig
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe HttpHeaderConditionConfig
httpHeaderConfig
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe HttpRequestMethodConditionConfig
httpRequestMethodConfig
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe PathPatternConditionConfig
pathPatternConfig
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe QueryStringConditionConfig
queryStringConfig
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe SourceIpConditionConfig
sourceIpConfig
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [Text]
values

instance Prelude.NFData RuleCondition where
  rnf :: RuleCondition -> ()
rnf RuleCondition' {Maybe [Text]
Maybe Text
Maybe HostHeaderConditionConfig
Maybe HttpHeaderConditionConfig
Maybe HttpRequestMethodConditionConfig
Maybe PathPatternConditionConfig
Maybe QueryStringConditionConfig
Maybe SourceIpConditionConfig
values :: Maybe [Text]
sourceIpConfig :: Maybe SourceIpConditionConfig
queryStringConfig :: Maybe QueryStringConditionConfig
pathPatternConfig :: Maybe PathPatternConditionConfig
httpRequestMethodConfig :: Maybe HttpRequestMethodConditionConfig
httpHeaderConfig :: Maybe HttpHeaderConditionConfig
hostHeaderConfig :: Maybe HostHeaderConditionConfig
field :: Maybe Text
$sel:values:RuleCondition' :: RuleCondition -> Maybe [Text]
$sel:sourceIpConfig:RuleCondition' :: RuleCondition -> Maybe SourceIpConditionConfig
$sel:queryStringConfig:RuleCondition' :: RuleCondition -> Maybe QueryStringConditionConfig
$sel:pathPatternConfig:RuleCondition' :: RuleCondition -> Maybe PathPatternConditionConfig
$sel:httpRequestMethodConfig:RuleCondition' :: RuleCondition -> Maybe HttpRequestMethodConditionConfig
$sel:httpHeaderConfig:RuleCondition' :: RuleCondition -> Maybe HttpHeaderConditionConfig
$sel:hostHeaderConfig:RuleCondition' :: RuleCondition -> Maybe HostHeaderConditionConfig
$sel:field:RuleCondition' :: RuleCondition -> Maybe Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
field
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe HostHeaderConditionConfig
hostHeaderConfig
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe HttpHeaderConditionConfig
httpHeaderConfig
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe HttpRequestMethodConditionConfig
httpRequestMethodConfig
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe PathPatternConditionConfig
pathPatternConfig
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe QueryStringConditionConfig
queryStringConfig
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe SourceIpConditionConfig
sourceIpConfig
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe [Text]
values

instance Data.ToQuery RuleCondition where
  toQuery :: RuleCondition -> QueryString
toQuery RuleCondition' {Maybe [Text]
Maybe Text
Maybe HostHeaderConditionConfig
Maybe HttpHeaderConditionConfig
Maybe HttpRequestMethodConditionConfig
Maybe PathPatternConditionConfig
Maybe QueryStringConditionConfig
Maybe SourceIpConditionConfig
values :: Maybe [Text]
sourceIpConfig :: Maybe SourceIpConditionConfig
queryStringConfig :: Maybe QueryStringConditionConfig
pathPatternConfig :: Maybe PathPatternConditionConfig
httpRequestMethodConfig :: Maybe HttpRequestMethodConditionConfig
httpHeaderConfig :: Maybe HttpHeaderConditionConfig
hostHeaderConfig :: Maybe HostHeaderConditionConfig
field :: Maybe Text
$sel:values:RuleCondition' :: RuleCondition -> Maybe [Text]
$sel:sourceIpConfig:RuleCondition' :: RuleCondition -> Maybe SourceIpConditionConfig
$sel:queryStringConfig:RuleCondition' :: RuleCondition -> Maybe QueryStringConditionConfig
$sel:pathPatternConfig:RuleCondition' :: RuleCondition -> Maybe PathPatternConditionConfig
$sel:httpRequestMethodConfig:RuleCondition' :: RuleCondition -> Maybe HttpRequestMethodConditionConfig
$sel:httpHeaderConfig:RuleCondition' :: RuleCondition -> Maybe HttpHeaderConditionConfig
$sel:hostHeaderConfig:RuleCondition' :: RuleCondition -> Maybe HostHeaderConditionConfig
$sel:field:RuleCondition' :: RuleCondition -> Maybe Text
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"Field" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
field,
        ByteString
"HostHeaderConfig" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe HostHeaderConditionConfig
hostHeaderConfig,
        ByteString
"HttpHeaderConfig" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe HttpHeaderConditionConfig
httpHeaderConfig,
        ByteString
"HttpRequestMethodConfig"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe HttpRequestMethodConditionConfig
httpRequestMethodConfig,
        ByteString
"PathPatternConfig" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe PathPatternConditionConfig
pathPatternConfig,
        ByteString
"QueryStringConfig" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe QueryStringConditionConfig
queryStringConfig,
        ByteString
"SourceIpConfig" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe SourceIpConditionConfig
sourceIpConfig,
        ByteString
"Values"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: forall a. ToQuery a => a -> QueryString
Data.toQuery
            (forall a.
(IsList a, ToQuery (Item a)) =>
ByteString -> a -> QueryString
Data.toQueryList ByteString
"member" forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe [Text]
values)
      ]