{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE DuplicateRecordFields #-}
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE StrictData #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE NoImplicitPrelude #-}
{-# OPTIONS_GHC -fno-warn-unused-binds #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
{-# OPTIONS_GHC -fno-warn-unused-matches #-}

-- Derived from AWS service descriptions, licensed under Apache 2.0.

-- |
-- Module      : Amazonka.WAF.CreateGeoMatchSet
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- This is __AWS WAF Classic__ documentation. For more information, see
-- <https://docs.aws.amazon.com/waf/latest/developerguide/classic-waf-chapter.html AWS WAF Classic>
-- in the developer guide.
--
-- __For the latest version of AWS WAF__, use the AWS WAFV2 API and see the
-- <https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html AWS WAF Developer Guide>.
-- With the latest version, AWS WAF has a single set of endpoints for
-- regional and global use.
--
-- Creates an GeoMatchSet, which you use to specify which web requests you
-- want to allow or block based on the country that the requests originate
-- from. For example, if you\'re receiving a lot of requests from one or
-- more countries and you want to block the requests, you can create an
-- @GeoMatchSet@ that contains those countries and then configure AWS WAF
-- to block the requests.
--
-- To create and configure a @GeoMatchSet@, perform the following steps:
--
-- 1.  Use GetChangeToken to get the change token that you provide in the
--     @ChangeToken@ parameter of a @CreateGeoMatchSet@ request.
--
-- 2.  Submit a @CreateGeoMatchSet@ request.
--
-- 3.  Use @GetChangeToken@ to get the change token that you provide in the
--     @ChangeToken@ parameter of an UpdateGeoMatchSet request.
--
-- 4.  Submit an @UpdateGeoMatchSetSet@ request to specify the countries
--     that you want AWS WAF to watch for.
--
-- For more information about how to use the AWS WAF API to allow or block
-- HTTP requests, see the
-- <https://docs.aws.amazon.com/waf/latest/developerguide/ AWS WAF Developer Guide>.
module Amazonka.WAF.CreateGeoMatchSet
  ( -- * Creating a Request
    CreateGeoMatchSet (..),
    newCreateGeoMatchSet,

    -- * Request Lenses
    createGeoMatchSet_name,
    createGeoMatchSet_changeToken,

    -- * Destructuring the Response
    CreateGeoMatchSetResponse (..),
    newCreateGeoMatchSetResponse,

    -- * Response Lenses
    createGeoMatchSetResponse_changeToken,
    createGeoMatchSetResponse_geoMatchSet,
    createGeoMatchSetResponse_httpStatus,
  )
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 qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
import Amazonka.WAF.Types

-- | /See:/ 'newCreateGeoMatchSet' smart constructor.
data CreateGeoMatchSet = CreateGeoMatchSet'
  { -- | A friendly name or description of the GeoMatchSet. You can\'t change
    -- @Name@ after you create the @GeoMatchSet@.
    CreateGeoMatchSet -> Text
name :: Prelude.Text,
    -- | The value returned by the most recent call to GetChangeToken.
    CreateGeoMatchSet -> Text
changeToken :: Prelude.Text
  }
  deriving (CreateGeoMatchSet -> CreateGeoMatchSet -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: CreateGeoMatchSet -> CreateGeoMatchSet -> Bool
$c/= :: CreateGeoMatchSet -> CreateGeoMatchSet -> Bool
== :: CreateGeoMatchSet -> CreateGeoMatchSet -> Bool
$c== :: CreateGeoMatchSet -> CreateGeoMatchSet -> Bool
Prelude.Eq, ReadPrec [CreateGeoMatchSet]
ReadPrec CreateGeoMatchSet
Int -> ReadS CreateGeoMatchSet
ReadS [CreateGeoMatchSet]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [CreateGeoMatchSet]
$creadListPrec :: ReadPrec [CreateGeoMatchSet]
readPrec :: ReadPrec CreateGeoMatchSet
$creadPrec :: ReadPrec CreateGeoMatchSet
readList :: ReadS [CreateGeoMatchSet]
$creadList :: ReadS [CreateGeoMatchSet]
readsPrec :: Int -> ReadS CreateGeoMatchSet
$creadsPrec :: Int -> ReadS CreateGeoMatchSet
Prelude.Read, Int -> CreateGeoMatchSet -> ShowS
[CreateGeoMatchSet] -> ShowS
CreateGeoMatchSet -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [CreateGeoMatchSet] -> ShowS
$cshowList :: [CreateGeoMatchSet] -> ShowS
show :: CreateGeoMatchSet -> String
$cshow :: CreateGeoMatchSet -> String
showsPrec :: Int -> CreateGeoMatchSet -> ShowS
$cshowsPrec :: Int -> CreateGeoMatchSet -> ShowS
Prelude.Show, forall x. Rep CreateGeoMatchSet x -> CreateGeoMatchSet
forall x. CreateGeoMatchSet -> Rep CreateGeoMatchSet x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep CreateGeoMatchSet x -> CreateGeoMatchSet
$cfrom :: forall x. CreateGeoMatchSet -> Rep CreateGeoMatchSet x
Prelude.Generic)

-- |
-- Create a value of 'CreateGeoMatchSet' 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:
--
-- 'name', 'createGeoMatchSet_name' - A friendly name or description of the GeoMatchSet. You can\'t change
-- @Name@ after you create the @GeoMatchSet@.
--
-- 'changeToken', 'createGeoMatchSet_changeToken' - The value returned by the most recent call to GetChangeToken.
newCreateGeoMatchSet ::
  -- | 'name'
  Prelude.Text ->
  -- | 'changeToken'
  Prelude.Text ->
  CreateGeoMatchSet
newCreateGeoMatchSet :: Text -> Text -> CreateGeoMatchSet
newCreateGeoMatchSet Text
pName_ Text
pChangeToken_ =
  CreateGeoMatchSet'
    { $sel:name:CreateGeoMatchSet' :: Text
name = Text
pName_,
      $sel:changeToken:CreateGeoMatchSet' :: Text
changeToken = Text
pChangeToken_
    }

-- | A friendly name or description of the GeoMatchSet. You can\'t change
-- @Name@ after you create the @GeoMatchSet@.
createGeoMatchSet_name :: Lens.Lens' CreateGeoMatchSet Prelude.Text
createGeoMatchSet_name :: Lens' CreateGeoMatchSet Text
createGeoMatchSet_name = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateGeoMatchSet' {Text
name :: Text
$sel:name:CreateGeoMatchSet' :: CreateGeoMatchSet -> Text
name} -> Text
name) (\s :: CreateGeoMatchSet
s@CreateGeoMatchSet' {} Text
a -> CreateGeoMatchSet
s {$sel:name:CreateGeoMatchSet' :: Text
name = Text
a} :: CreateGeoMatchSet)

-- | The value returned by the most recent call to GetChangeToken.
createGeoMatchSet_changeToken :: Lens.Lens' CreateGeoMatchSet Prelude.Text
createGeoMatchSet_changeToken :: Lens' CreateGeoMatchSet Text
createGeoMatchSet_changeToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateGeoMatchSet' {Text
changeToken :: Text
$sel:changeToken:CreateGeoMatchSet' :: CreateGeoMatchSet -> Text
changeToken} -> Text
changeToken) (\s :: CreateGeoMatchSet
s@CreateGeoMatchSet' {} Text
a -> CreateGeoMatchSet
s {$sel:changeToken:CreateGeoMatchSet' :: Text
changeToken = Text
a} :: CreateGeoMatchSet)

instance Core.AWSRequest CreateGeoMatchSet where
  type
    AWSResponse CreateGeoMatchSet =
      CreateGeoMatchSetResponse
  request :: (Service -> Service)
-> CreateGeoMatchSet -> Request CreateGeoMatchSet
request Service -> Service
overrides =
    forall a. (ToRequest a, ToJSON a) => Service -> a -> Request a
Request.postJSON (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy CreateGeoMatchSet
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse CreateGeoMatchSet)))
response =
    forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> Object -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveJSON
      ( \Int
s ResponseHeaders
h Object
x ->
          Maybe Text -> Maybe GeoMatchSet -> Int -> CreateGeoMatchSetResponse
CreateGeoMatchSetResponse'
            forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"ChangeToken")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"GeoMatchSet")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (forall (f :: * -> *) a. Applicative f => a -> f a
Prelude.pure (forall a. Enum a => a -> Int
Prelude.fromEnum Int
s))
      )

instance Prelude.Hashable CreateGeoMatchSet where
  hashWithSalt :: Int -> CreateGeoMatchSet -> Int
hashWithSalt Int
_salt CreateGeoMatchSet' {Text
changeToken :: Text
name :: Text
$sel:changeToken:CreateGeoMatchSet' :: CreateGeoMatchSet -> Text
$sel:name:CreateGeoMatchSet' :: CreateGeoMatchSet -> Text
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
name
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
changeToken

instance Prelude.NFData CreateGeoMatchSet where
  rnf :: CreateGeoMatchSet -> ()
rnf CreateGeoMatchSet' {Text
changeToken :: Text
name :: Text
$sel:changeToken:CreateGeoMatchSet' :: CreateGeoMatchSet -> Text
$sel:name:CreateGeoMatchSet' :: CreateGeoMatchSet -> Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Text
name
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
changeToken

instance Data.ToHeaders CreateGeoMatchSet where
  toHeaders :: CreateGeoMatchSet -> ResponseHeaders
toHeaders =
    forall a b. a -> b -> a
Prelude.const
      ( forall a. Monoid a => [a] -> a
Prelude.mconcat
          [ HeaderName
"X-Amz-Target"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"AWSWAF_20150824.CreateGeoMatchSet" ::
                          Prelude.ByteString
                      ),
            HeaderName
"Content-Type"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
                          Prelude.ByteString
                      )
          ]
      )

instance Data.ToJSON CreateGeoMatchSet where
  toJSON :: CreateGeoMatchSet -> Value
toJSON CreateGeoMatchSet' {Text
changeToken :: Text
name :: Text
$sel:changeToken:CreateGeoMatchSet' :: CreateGeoMatchSet -> Text
$sel:name:CreateGeoMatchSet' :: CreateGeoMatchSet -> Text
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [ forall a. a -> Maybe a
Prelude.Just (Key
"Name" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
name),
            forall a. a -> Maybe a
Prelude.Just (Key
"ChangeToken" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
changeToken)
          ]
      )

instance Data.ToPath CreateGeoMatchSet where
  toPath :: CreateGeoMatchSet -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"

instance Data.ToQuery CreateGeoMatchSet where
  toQuery :: CreateGeoMatchSet -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

-- | /See:/ 'newCreateGeoMatchSetResponse' smart constructor.
data CreateGeoMatchSetResponse = CreateGeoMatchSetResponse'
  { -- | The @ChangeToken@ that you used to submit the @CreateGeoMatchSet@
    -- request. You can also use this value to query the status of the request.
    -- For more information, see GetChangeTokenStatus.
    CreateGeoMatchSetResponse -> Maybe Text
changeToken :: Prelude.Maybe Prelude.Text,
    -- | The GeoMatchSet returned in the @CreateGeoMatchSet@ response. The
    -- @GeoMatchSet@ contains no @GeoMatchConstraints@.
    CreateGeoMatchSetResponse -> Maybe GeoMatchSet
geoMatchSet :: Prelude.Maybe GeoMatchSet,
    -- | The response's http status code.
    CreateGeoMatchSetResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (CreateGeoMatchSetResponse -> CreateGeoMatchSetResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: CreateGeoMatchSetResponse -> CreateGeoMatchSetResponse -> Bool
$c/= :: CreateGeoMatchSetResponse -> CreateGeoMatchSetResponse -> Bool
== :: CreateGeoMatchSetResponse -> CreateGeoMatchSetResponse -> Bool
$c== :: CreateGeoMatchSetResponse -> CreateGeoMatchSetResponse -> Bool
Prelude.Eq, ReadPrec [CreateGeoMatchSetResponse]
ReadPrec CreateGeoMatchSetResponse
Int -> ReadS CreateGeoMatchSetResponse
ReadS [CreateGeoMatchSetResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [CreateGeoMatchSetResponse]
$creadListPrec :: ReadPrec [CreateGeoMatchSetResponse]
readPrec :: ReadPrec CreateGeoMatchSetResponse
$creadPrec :: ReadPrec CreateGeoMatchSetResponse
readList :: ReadS [CreateGeoMatchSetResponse]
$creadList :: ReadS [CreateGeoMatchSetResponse]
readsPrec :: Int -> ReadS CreateGeoMatchSetResponse
$creadsPrec :: Int -> ReadS CreateGeoMatchSetResponse
Prelude.Read, Int -> CreateGeoMatchSetResponse -> ShowS
[CreateGeoMatchSetResponse] -> ShowS
CreateGeoMatchSetResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [CreateGeoMatchSetResponse] -> ShowS
$cshowList :: [CreateGeoMatchSetResponse] -> ShowS
show :: CreateGeoMatchSetResponse -> String
$cshow :: CreateGeoMatchSetResponse -> String
showsPrec :: Int -> CreateGeoMatchSetResponse -> ShowS
$cshowsPrec :: Int -> CreateGeoMatchSetResponse -> ShowS
Prelude.Show, forall x.
Rep CreateGeoMatchSetResponse x -> CreateGeoMatchSetResponse
forall x.
CreateGeoMatchSetResponse -> Rep CreateGeoMatchSetResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep CreateGeoMatchSetResponse x -> CreateGeoMatchSetResponse
$cfrom :: forall x.
CreateGeoMatchSetResponse -> Rep CreateGeoMatchSetResponse x
Prelude.Generic)

-- |
-- Create a value of 'CreateGeoMatchSetResponse' 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:
--
-- 'changeToken', 'createGeoMatchSetResponse_changeToken' - The @ChangeToken@ that you used to submit the @CreateGeoMatchSet@
-- request. You can also use this value to query the status of the request.
-- For more information, see GetChangeTokenStatus.
--
-- 'geoMatchSet', 'createGeoMatchSetResponse_geoMatchSet' - The GeoMatchSet returned in the @CreateGeoMatchSet@ response. The
-- @GeoMatchSet@ contains no @GeoMatchConstraints@.
--
-- 'httpStatus', 'createGeoMatchSetResponse_httpStatus' - The response's http status code.
newCreateGeoMatchSetResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  CreateGeoMatchSetResponse
newCreateGeoMatchSetResponse :: Int -> CreateGeoMatchSetResponse
newCreateGeoMatchSetResponse Int
pHttpStatus_ =
  CreateGeoMatchSetResponse'
    { $sel:changeToken:CreateGeoMatchSetResponse' :: Maybe Text
changeToken =
        forall a. Maybe a
Prelude.Nothing,
      $sel:geoMatchSet:CreateGeoMatchSetResponse' :: Maybe GeoMatchSet
geoMatchSet = forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:CreateGeoMatchSetResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | The @ChangeToken@ that you used to submit the @CreateGeoMatchSet@
-- request. You can also use this value to query the status of the request.
-- For more information, see GetChangeTokenStatus.
createGeoMatchSetResponse_changeToken :: Lens.Lens' CreateGeoMatchSetResponse (Prelude.Maybe Prelude.Text)
createGeoMatchSetResponse_changeToken :: Lens' CreateGeoMatchSetResponse (Maybe Text)
createGeoMatchSetResponse_changeToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateGeoMatchSetResponse' {Maybe Text
changeToken :: Maybe Text
$sel:changeToken:CreateGeoMatchSetResponse' :: CreateGeoMatchSetResponse -> Maybe Text
changeToken} -> Maybe Text
changeToken) (\s :: CreateGeoMatchSetResponse
s@CreateGeoMatchSetResponse' {} Maybe Text
a -> CreateGeoMatchSetResponse
s {$sel:changeToken:CreateGeoMatchSetResponse' :: Maybe Text
changeToken = Maybe Text
a} :: CreateGeoMatchSetResponse)

-- | The GeoMatchSet returned in the @CreateGeoMatchSet@ response. The
-- @GeoMatchSet@ contains no @GeoMatchConstraints@.
createGeoMatchSetResponse_geoMatchSet :: Lens.Lens' CreateGeoMatchSetResponse (Prelude.Maybe GeoMatchSet)
createGeoMatchSetResponse_geoMatchSet :: Lens' CreateGeoMatchSetResponse (Maybe GeoMatchSet)
createGeoMatchSetResponse_geoMatchSet = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateGeoMatchSetResponse' {Maybe GeoMatchSet
geoMatchSet :: Maybe GeoMatchSet
$sel:geoMatchSet:CreateGeoMatchSetResponse' :: CreateGeoMatchSetResponse -> Maybe GeoMatchSet
geoMatchSet} -> Maybe GeoMatchSet
geoMatchSet) (\s :: CreateGeoMatchSetResponse
s@CreateGeoMatchSetResponse' {} Maybe GeoMatchSet
a -> CreateGeoMatchSetResponse
s {$sel:geoMatchSet:CreateGeoMatchSetResponse' :: Maybe GeoMatchSet
geoMatchSet = Maybe GeoMatchSet
a} :: CreateGeoMatchSetResponse)

-- | The response's http status code.
createGeoMatchSetResponse_httpStatus :: Lens.Lens' CreateGeoMatchSetResponse Prelude.Int
createGeoMatchSetResponse_httpStatus :: Lens' CreateGeoMatchSetResponse Int
createGeoMatchSetResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateGeoMatchSetResponse' {Int
httpStatus :: Int
$sel:httpStatus:CreateGeoMatchSetResponse' :: CreateGeoMatchSetResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: CreateGeoMatchSetResponse
s@CreateGeoMatchSetResponse' {} Int
a -> CreateGeoMatchSetResponse
s {$sel:httpStatus:CreateGeoMatchSetResponse' :: Int
httpStatus = Int
a} :: CreateGeoMatchSetResponse)

instance Prelude.NFData CreateGeoMatchSetResponse where
  rnf :: CreateGeoMatchSetResponse -> ()
rnf CreateGeoMatchSetResponse' {Int
Maybe Text
Maybe GeoMatchSet
httpStatus :: Int
geoMatchSet :: Maybe GeoMatchSet
changeToken :: Maybe Text
$sel:httpStatus:CreateGeoMatchSetResponse' :: CreateGeoMatchSetResponse -> Int
$sel:geoMatchSet:CreateGeoMatchSetResponse' :: CreateGeoMatchSetResponse -> Maybe GeoMatchSet
$sel:changeToken:CreateGeoMatchSetResponse' :: CreateGeoMatchSetResponse -> Maybe Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
changeToken
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe GeoMatchSet
geoMatchSet
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus