{-# 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.EC2.CreateVerifiedAccessGroup
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- An Amazon Web Services Verified Access group is a collection of Amazon
-- Web Services Verified Access endpoints who\'s associated applications
-- have similar security requirements. Each instance within an Amazon Web
-- Services Verified Access group shares an Amazon Web Services Verified
-- Access policy. For example, you can group all Amazon Web Services
-- Verified Access instances associated with “sales” applications together
-- and use one common Amazon Web Services Verified Access policy.
module Amazonka.EC2.CreateVerifiedAccessGroup
  ( -- * Creating a Request
    CreateVerifiedAccessGroup (..),
    newCreateVerifiedAccessGroup,

    -- * Request Lenses
    createVerifiedAccessGroup_clientToken,
    createVerifiedAccessGroup_description,
    createVerifiedAccessGroup_dryRun,
    createVerifiedAccessGroup_policyDocument,
    createVerifiedAccessGroup_tagSpecifications,
    createVerifiedAccessGroup_verifiedAccessInstanceId,

    -- * Destructuring the Response
    CreateVerifiedAccessGroupResponse (..),
    newCreateVerifiedAccessGroupResponse,

    -- * Response Lenses
    createVerifiedAccessGroupResponse_verifiedAccessGroup,
    createVerifiedAccessGroupResponse_httpStatus,
  )
where

import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.EC2.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response

-- | /See:/ 'newCreateVerifiedAccessGroup' smart constructor.
data CreateVerifiedAccessGroup = CreateVerifiedAccessGroup'
  { -- | A unique, case-sensitive token that you provide to ensure idempotency of
    -- your modification request. For more information, see
    -- <https://docs.aws.amazon.com/AWSEC2/latest/APIReference/Run_Instance_Idempotency.html Ensuring Idempotency>.
    CreateVerifiedAccessGroup -> Maybe Text
clientToken :: Prelude.Maybe Prelude.Text,
    -- | A description for the Amazon Web Services Verified Access group.
    CreateVerifiedAccessGroup -> Maybe Text
description :: Prelude.Maybe Prelude.Text,
    -- | Checks whether you have the required permissions for the action, without
    -- actually making the request, and provides an error response. If you have
    -- the required permissions, the error response is @DryRunOperation@.
    -- Otherwise, it is @UnauthorizedOperation@.
    CreateVerifiedAccessGroup -> Maybe Bool
dryRun :: Prelude.Maybe Prelude.Bool,
    -- | The Amazon Web Services Verified Access policy document.
    CreateVerifiedAccessGroup -> Maybe Text
policyDocument :: Prelude.Maybe Prelude.Text,
    -- | The tags to assign to the Amazon Web Services Verified Access group.
    CreateVerifiedAccessGroup -> Maybe [TagSpecification]
tagSpecifications :: Prelude.Maybe [TagSpecification],
    -- | The ID of the Amazon Web Services Verified Access instance.
    CreateVerifiedAccessGroup -> Text
verifiedAccessInstanceId :: Prelude.Text
  }
  deriving (CreateVerifiedAccessGroup -> CreateVerifiedAccessGroup -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: CreateVerifiedAccessGroup -> CreateVerifiedAccessGroup -> Bool
$c/= :: CreateVerifiedAccessGroup -> CreateVerifiedAccessGroup -> Bool
== :: CreateVerifiedAccessGroup -> CreateVerifiedAccessGroup -> Bool
$c== :: CreateVerifiedAccessGroup -> CreateVerifiedAccessGroup -> Bool
Prelude.Eq, ReadPrec [CreateVerifiedAccessGroup]
ReadPrec CreateVerifiedAccessGroup
Int -> ReadS CreateVerifiedAccessGroup
ReadS [CreateVerifiedAccessGroup]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [CreateVerifiedAccessGroup]
$creadListPrec :: ReadPrec [CreateVerifiedAccessGroup]
readPrec :: ReadPrec CreateVerifiedAccessGroup
$creadPrec :: ReadPrec CreateVerifiedAccessGroup
readList :: ReadS [CreateVerifiedAccessGroup]
$creadList :: ReadS [CreateVerifiedAccessGroup]
readsPrec :: Int -> ReadS CreateVerifiedAccessGroup
$creadsPrec :: Int -> ReadS CreateVerifiedAccessGroup
Prelude.Read, Int -> CreateVerifiedAccessGroup -> ShowS
[CreateVerifiedAccessGroup] -> ShowS
CreateVerifiedAccessGroup -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [CreateVerifiedAccessGroup] -> ShowS
$cshowList :: [CreateVerifiedAccessGroup] -> ShowS
show :: CreateVerifiedAccessGroup -> String
$cshow :: CreateVerifiedAccessGroup -> String
showsPrec :: Int -> CreateVerifiedAccessGroup -> ShowS
$cshowsPrec :: Int -> CreateVerifiedAccessGroup -> ShowS
Prelude.Show, forall x.
Rep CreateVerifiedAccessGroup x -> CreateVerifiedAccessGroup
forall x.
CreateVerifiedAccessGroup -> Rep CreateVerifiedAccessGroup x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep CreateVerifiedAccessGroup x -> CreateVerifiedAccessGroup
$cfrom :: forall x.
CreateVerifiedAccessGroup -> Rep CreateVerifiedAccessGroup x
Prelude.Generic)

-- |
-- Create a value of 'CreateVerifiedAccessGroup' 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:
--
-- 'clientToken', 'createVerifiedAccessGroup_clientToken' - A unique, case-sensitive token that you provide to ensure idempotency of
-- your modification request. For more information, see
-- <https://docs.aws.amazon.com/AWSEC2/latest/APIReference/Run_Instance_Idempotency.html Ensuring Idempotency>.
--
-- 'description', 'createVerifiedAccessGroup_description' - A description for the Amazon Web Services Verified Access group.
--
-- 'dryRun', 'createVerifiedAccessGroup_dryRun' - Checks whether you have the required permissions for the action, without
-- actually making the request, and provides an error response. If you have
-- the required permissions, the error response is @DryRunOperation@.
-- Otherwise, it is @UnauthorizedOperation@.
--
-- 'policyDocument', 'createVerifiedAccessGroup_policyDocument' - The Amazon Web Services Verified Access policy document.
--
-- 'tagSpecifications', 'createVerifiedAccessGroup_tagSpecifications' - The tags to assign to the Amazon Web Services Verified Access group.
--
-- 'verifiedAccessInstanceId', 'createVerifiedAccessGroup_verifiedAccessInstanceId' - The ID of the Amazon Web Services Verified Access instance.
newCreateVerifiedAccessGroup ::
  -- | 'verifiedAccessInstanceId'
  Prelude.Text ->
  CreateVerifiedAccessGroup
newCreateVerifiedAccessGroup :: Text -> CreateVerifiedAccessGroup
newCreateVerifiedAccessGroup
  Text
pVerifiedAccessInstanceId_ =
    CreateVerifiedAccessGroup'
      { $sel:clientToken:CreateVerifiedAccessGroup' :: Maybe Text
clientToken =
          forall a. Maybe a
Prelude.Nothing,
        $sel:description:CreateVerifiedAccessGroup' :: Maybe Text
description = forall a. Maybe a
Prelude.Nothing,
        $sel:dryRun:CreateVerifiedAccessGroup' :: Maybe Bool
dryRun = forall a. Maybe a
Prelude.Nothing,
        $sel:policyDocument:CreateVerifiedAccessGroup' :: Maybe Text
policyDocument = forall a. Maybe a
Prelude.Nothing,
        $sel:tagSpecifications:CreateVerifiedAccessGroup' :: Maybe [TagSpecification]
tagSpecifications = forall a. Maybe a
Prelude.Nothing,
        $sel:verifiedAccessInstanceId:CreateVerifiedAccessGroup' :: Text
verifiedAccessInstanceId =
          Text
pVerifiedAccessInstanceId_
      }

-- | A unique, case-sensitive token that you provide to ensure idempotency of
-- your modification request. For more information, see
-- <https://docs.aws.amazon.com/AWSEC2/latest/APIReference/Run_Instance_Idempotency.html Ensuring Idempotency>.
createVerifiedAccessGroup_clientToken :: Lens.Lens' CreateVerifiedAccessGroup (Prelude.Maybe Prelude.Text)
createVerifiedAccessGroup_clientToken :: Lens' CreateVerifiedAccessGroup (Maybe Text)
createVerifiedAccessGroup_clientToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVerifiedAccessGroup' {Maybe Text
clientToken :: Maybe Text
$sel:clientToken:CreateVerifiedAccessGroup' :: CreateVerifiedAccessGroup -> Maybe Text
clientToken} -> Maybe Text
clientToken) (\s :: CreateVerifiedAccessGroup
s@CreateVerifiedAccessGroup' {} Maybe Text
a -> CreateVerifiedAccessGroup
s {$sel:clientToken:CreateVerifiedAccessGroup' :: Maybe Text
clientToken = Maybe Text
a} :: CreateVerifiedAccessGroup)

-- | A description for the Amazon Web Services Verified Access group.
createVerifiedAccessGroup_description :: Lens.Lens' CreateVerifiedAccessGroup (Prelude.Maybe Prelude.Text)
createVerifiedAccessGroup_description :: Lens' CreateVerifiedAccessGroup (Maybe Text)
createVerifiedAccessGroup_description = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVerifiedAccessGroup' {Maybe Text
description :: Maybe Text
$sel:description:CreateVerifiedAccessGroup' :: CreateVerifiedAccessGroup -> Maybe Text
description} -> Maybe Text
description) (\s :: CreateVerifiedAccessGroup
s@CreateVerifiedAccessGroup' {} Maybe Text
a -> CreateVerifiedAccessGroup
s {$sel:description:CreateVerifiedAccessGroup' :: Maybe Text
description = Maybe Text
a} :: CreateVerifiedAccessGroup)

-- | Checks whether you have the required permissions for the action, without
-- actually making the request, and provides an error response. If you have
-- the required permissions, the error response is @DryRunOperation@.
-- Otherwise, it is @UnauthorizedOperation@.
createVerifiedAccessGroup_dryRun :: Lens.Lens' CreateVerifiedAccessGroup (Prelude.Maybe Prelude.Bool)
createVerifiedAccessGroup_dryRun :: Lens' CreateVerifiedAccessGroup (Maybe Bool)
createVerifiedAccessGroup_dryRun = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVerifiedAccessGroup' {Maybe Bool
dryRun :: Maybe Bool
$sel:dryRun:CreateVerifiedAccessGroup' :: CreateVerifiedAccessGroup -> Maybe Bool
dryRun} -> Maybe Bool
dryRun) (\s :: CreateVerifiedAccessGroup
s@CreateVerifiedAccessGroup' {} Maybe Bool
a -> CreateVerifiedAccessGroup
s {$sel:dryRun:CreateVerifiedAccessGroup' :: Maybe Bool
dryRun = Maybe Bool
a} :: CreateVerifiedAccessGroup)

-- | The Amazon Web Services Verified Access policy document.
createVerifiedAccessGroup_policyDocument :: Lens.Lens' CreateVerifiedAccessGroup (Prelude.Maybe Prelude.Text)
createVerifiedAccessGroup_policyDocument :: Lens' CreateVerifiedAccessGroup (Maybe Text)
createVerifiedAccessGroup_policyDocument = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVerifiedAccessGroup' {Maybe Text
policyDocument :: Maybe Text
$sel:policyDocument:CreateVerifiedAccessGroup' :: CreateVerifiedAccessGroup -> Maybe Text
policyDocument} -> Maybe Text
policyDocument) (\s :: CreateVerifiedAccessGroup
s@CreateVerifiedAccessGroup' {} Maybe Text
a -> CreateVerifiedAccessGroup
s {$sel:policyDocument:CreateVerifiedAccessGroup' :: Maybe Text
policyDocument = Maybe Text
a} :: CreateVerifiedAccessGroup)

-- | The tags to assign to the Amazon Web Services Verified Access group.
createVerifiedAccessGroup_tagSpecifications :: Lens.Lens' CreateVerifiedAccessGroup (Prelude.Maybe [TagSpecification])
createVerifiedAccessGroup_tagSpecifications :: Lens' CreateVerifiedAccessGroup (Maybe [TagSpecification])
createVerifiedAccessGroup_tagSpecifications = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVerifiedAccessGroup' {Maybe [TagSpecification]
tagSpecifications :: Maybe [TagSpecification]
$sel:tagSpecifications:CreateVerifiedAccessGroup' :: CreateVerifiedAccessGroup -> Maybe [TagSpecification]
tagSpecifications} -> Maybe [TagSpecification]
tagSpecifications) (\s :: CreateVerifiedAccessGroup
s@CreateVerifiedAccessGroup' {} Maybe [TagSpecification]
a -> CreateVerifiedAccessGroup
s {$sel:tagSpecifications:CreateVerifiedAccessGroup' :: Maybe [TagSpecification]
tagSpecifications = Maybe [TagSpecification]
a} :: CreateVerifiedAccessGroup) 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

-- | The ID of the Amazon Web Services Verified Access instance.
createVerifiedAccessGroup_verifiedAccessInstanceId :: Lens.Lens' CreateVerifiedAccessGroup Prelude.Text
createVerifiedAccessGroup_verifiedAccessInstanceId :: Lens' CreateVerifiedAccessGroup Text
createVerifiedAccessGroup_verifiedAccessInstanceId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVerifiedAccessGroup' {Text
verifiedAccessInstanceId :: Text
$sel:verifiedAccessInstanceId:CreateVerifiedAccessGroup' :: CreateVerifiedAccessGroup -> Text
verifiedAccessInstanceId} -> Text
verifiedAccessInstanceId) (\s :: CreateVerifiedAccessGroup
s@CreateVerifiedAccessGroup' {} Text
a -> CreateVerifiedAccessGroup
s {$sel:verifiedAccessInstanceId:CreateVerifiedAccessGroup' :: Text
verifiedAccessInstanceId = Text
a} :: CreateVerifiedAccessGroup)

instance Core.AWSRequest CreateVerifiedAccessGroup where
  type
    AWSResponse CreateVerifiedAccessGroup =
      CreateVerifiedAccessGroupResponse
  request :: (Service -> Service)
-> CreateVerifiedAccessGroup -> Request CreateVerifiedAccessGroup
request Service -> Service
overrides =
    forall a. ToRequest a => Service -> a -> Request a
Request.postQuery (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy CreateVerifiedAccessGroup
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse CreateVerifiedAccessGroup)))
response =
    forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> [Node] -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveXML
      ( \Int
s ResponseHeaders
h [Node]
x ->
          Maybe VerifiedAccessGroup
-> Int -> CreateVerifiedAccessGroupResponse
CreateVerifiedAccessGroupResponse'
            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
"verifiedAccessGroup")
            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 CreateVerifiedAccessGroup where
  hashWithSalt :: Int -> CreateVerifiedAccessGroup -> Int
hashWithSalt Int
_salt CreateVerifiedAccessGroup' {Maybe Bool
Maybe [TagSpecification]
Maybe Text
Text
verifiedAccessInstanceId :: Text
tagSpecifications :: Maybe [TagSpecification]
policyDocument :: Maybe Text
dryRun :: Maybe Bool
description :: Maybe Text
clientToken :: Maybe Text
$sel:verifiedAccessInstanceId:CreateVerifiedAccessGroup' :: CreateVerifiedAccessGroup -> Text
$sel:tagSpecifications:CreateVerifiedAccessGroup' :: CreateVerifiedAccessGroup -> Maybe [TagSpecification]
$sel:policyDocument:CreateVerifiedAccessGroup' :: CreateVerifiedAccessGroup -> Maybe Text
$sel:dryRun:CreateVerifiedAccessGroup' :: CreateVerifiedAccessGroup -> Maybe Bool
$sel:description:CreateVerifiedAccessGroup' :: CreateVerifiedAccessGroup -> Maybe Text
$sel:clientToken:CreateVerifiedAccessGroup' :: CreateVerifiedAccessGroup -> Maybe Text
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
clientToken
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
description
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Bool
dryRun
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
policyDocument
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [TagSpecification]
tagSpecifications
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
verifiedAccessInstanceId

instance Prelude.NFData CreateVerifiedAccessGroup where
  rnf :: CreateVerifiedAccessGroup -> ()
rnf CreateVerifiedAccessGroup' {Maybe Bool
Maybe [TagSpecification]
Maybe Text
Text
verifiedAccessInstanceId :: Text
tagSpecifications :: Maybe [TagSpecification]
policyDocument :: Maybe Text
dryRun :: Maybe Bool
description :: Maybe Text
clientToken :: Maybe Text
$sel:verifiedAccessInstanceId:CreateVerifiedAccessGroup' :: CreateVerifiedAccessGroup -> Text
$sel:tagSpecifications:CreateVerifiedAccessGroup' :: CreateVerifiedAccessGroup -> Maybe [TagSpecification]
$sel:policyDocument:CreateVerifiedAccessGroup' :: CreateVerifiedAccessGroup -> Maybe Text
$sel:dryRun:CreateVerifiedAccessGroup' :: CreateVerifiedAccessGroup -> Maybe Bool
$sel:description:CreateVerifiedAccessGroup' :: CreateVerifiedAccessGroup -> Maybe Text
$sel:clientToken:CreateVerifiedAccessGroup' :: CreateVerifiedAccessGroup -> Maybe Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
clientToken
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
description
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Bool
dryRun
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
policyDocument
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe [TagSpecification]
tagSpecifications
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
verifiedAccessInstanceId

instance Data.ToHeaders CreateVerifiedAccessGroup where
  toHeaders :: CreateVerifiedAccessGroup -> ResponseHeaders
toHeaders = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

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

instance Data.ToQuery CreateVerifiedAccessGroup where
  toQuery :: CreateVerifiedAccessGroup -> QueryString
toQuery CreateVerifiedAccessGroup' {Maybe Bool
Maybe [TagSpecification]
Maybe Text
Text
verifiedAccessInstanceId :: Text
tagSpecifications :: Maybe [TagSpecification]
policyDocument :: Maybe Text
dryRun :: Maybe Bool
description :: Maybe Text
clientToken :: Maybe Text
$sel:verifiedAccessInstanceId:CreateVerifiedAccessGroup' :: CreateVerifiedAccessGroup -> Text
$sel:tagSpecifications:CreateVerifiedAccessGroup' :: CreateVerifiedAccessGroup -> Maybe [TagSpecification]
$sel:policyDocument:CreateVerifiedAccessGroup' :: CreateVerifiedAccessGroup -> Maybe Text
$sel:dryRun:CreateVerifiedAccessGroup' :: CreateVerifiedAccessGroup -> Maybe Bool
$sel:description:CreateVerifiedAccessGroup' :: CreateVerifiedAccessGroup -> Maybe Text
$sel:clientToken:CreateVerifiedAccessGroup' :: CreateVerifiedAccessGroup -> Maybe Text
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"Action"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"CreateVerifiedAccessGroup" :: Prelude.ByteString),
        ByteString
"Version"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"2016-11-15" :: Prelude.ByteString),
        ByteString
"ClientToken" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
clientToken,
        ByteString
"Description" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
description,
        ByteString
"DryRun" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Bool
dryRun,
        ByteString
"PolicyDocument" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
policyDocument,
        forall a. ToQuery a => a -> QueryString
Data.toQuery
          ( forall a.
(IsList a, ToQuery (Item a)) =>
ByteString -> a -> QueryString
Data.toQueryList ByteString
"TagSpecification"
              forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe [TagSpecification]
tagSpecifications
          ),
        ByteString
"VerifiedAccessInstanceId"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Text
verifiedAccessInstanceId
      ]

-- | /See:/ 'newCreateVerifiedAccessGroupResponse' smart constructor.
data CreateVerifiedAccessGroupResponse = CreateVerifiedAccessGroupResponse'
  { -- | The ID of the Verified Access group.
    CreateVerifiedAccessGroupResponse -> Maybe VerifiedAccessGroup
verifiedAccessGroup :: Prelude.Maybe VerifiedAccessGroup,
    -- | The response's http status code.
    CreateVerifiedAccessGroupResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (CreateVerifiedAccessGroupResponse
-> CreateVerifiedAccessGroupResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: CreateVerifiedAccessGroupResponse
-> CreateVerifiedAccessGroupResponse -> Bool
$c/= :: CreateVerifiedAccessGroupResponse
-> CreateVerifiedAccessGroupResponse -> Bool
== :: CreateVerifiedAccessGroupResponse
-> CreateVerifiedAccessGroupResponse -> Bool
$c== :: CreateVerifiedAccessGroupResponse
-> CreateVerifiedAccessGroupResponse -> Bool
Prelude.Eq, ReadPrec [CreateVerifiedAccessGroupResponse]
ReadPrec CreateVerifiedAccessGroupResponse
Int -> ReadS CreateVerifiedAccessGroupResponse
ReadS [CreateVerifiedAccessGroupResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [CreateVerifiedAccessGroupResponse]
$creadListPrec :: ReadPrec [CreateVerifiedAccessGroupResponse]
readPrec :: ReadPrec CreateVerifiedAccessGroupResponse
$creadPrec :: ReadPrec CreateVerifiedAccessGroupResponse
readList :: ReadS [CreateVerifiedAccessGroupResponse]
$creadList :: ReadS [CreateVerifiedAccessGroupResponse]
readsPrec :: Int -> ReadS CreateVerifiedAccessGroupResponse
$creadsPrec :: Int -> ReadS CreateVerifiedAccessGroupResponse
Prelude.Read, Int -> CreateVerifiedAccessGroupResponse -> ShowS
[CreateVerifiedAccessGroupResponse] -> ShowS
CreateVerifiedAccessGroupResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [CreateVerifiedAccessGroupResponse] -> ShowS
$cshowList :: [CreateVerifiedAccessGroupResponse] -> ShowS
show :: CreateVerifiedAccessGroupResponse -> String
$cshow :: CreateVerifiedAccessGroupResponse -> String
showsPrec :: Int -> CreateVerifiedAccessGroupResponse -> ShowS
$cshowsPrec :: Int -> CreateVerifiedAccessGroupResponse -> ShowS
Prelude.Show, forall x.
Rep CreateVerifiedAccessGroupResponse x
-> CreateVerifiedAccessGroupResponse
forall x.
CreateVerifiedAccessGroupResponse
-> Rep CreateVerifiedAccessGroupResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep CreateVerifiedAccessGroupResponse x
-> CreateVerifiedAccessGroupResponse
$cfrom :: forall x.
CreateVerifiedAccessGroupResponse
-> Rep CreateVerifiedAccessGroupResponse x
Prelude.Generic)

-- |
-- Create a value of 'CreateVerifiedAccessGroupResponse' 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:
--
-- 'verifiedAccessGroup', 'createVerifiedAccessGroupResponse_verifiedAccessGroup' - The ID of the Verified Access group.
--
-- 'httpStatus', 'createVerifiedAccessGroupResponse_httpStatus' - The response's http status code.
newCreateVerifiedAccessGroupResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  CreateVerifiedAccessGroupResponse
newCreateVerifiedAccessGroupResponse :: Int -> CreateVerifiedAccessGroupResponse
newCreateVerifiedAccessGroupResponse Int
pHttpStatus_ =
  CreateVerifiedAccessGroupResponse'
    { $sel:verifiedAccessGroup:CreateVerifiedAccessGroupResponse' :: Maybe VerifiedAccessGroup
verifiedAccessGroup =
        forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:CreateVerifiedAccessGroupResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | The ID of the Verified Access group.
createVerifiedAccessGroupResponse_verifiedAccessGroup :: Lens.Lens' CreateVerifiedAccessGroupResponse (Prelude.Maybe VerifiedAccessGroup)
createVerifiedAccessGroupResponse_verifiedAccessGroup :: Lens' CreateVerifiedAccessGroupResponse (Maybe VerifiedAccessGroup)
createVerifiedAccessGroupResponse_verifiedAccessGroup = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVerifiedAccessGroupResponse' {Maybe VerifiedAccessGroup
verifiedAccessGroup :: Maybe VerifiedAccessGroup
$sel:verifiedAccessGroup:CreateVerifiedAccessGroupResponse' :: CreateVerifiedAccessGroupResponse -> Maybe VerifiedAccessGroup
verifiedAccessGroup} -> Maybe VerifiedAccessGroup
verifiedAccessGroup) (\s :: CreateVerifiedAccessGroupResponse
s@CreateVerifiedAccessGroupResponse' {} Maybe VerifiedAccessGroup
a -> CreateVerifiedAccessGroupResponse
s {$sel:verifiedAccessGroup:CreateVerifiedAccessGroupResponse' :: Maybe VerifiedAccessGroup
verifiedAccessGroup = Maybe VerifiedAccessGroup
a} :: CreateVerifiedAccessGroupResponse)

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

instance
  Prelude.NFData
    CreateVerifiedAccessGroupResponse
  where
  rnf :: CreateVerifiedAccessGroupResponse -> ()
rnf CreateVerifiedAccessGroupResponse' {Int
Maybe VerifiedAccessGroup
httpStatus :: Int
verifiedAccessGroup :: Maybe VerifiedAccessGroup
$sel:httpStatus:CreateVerifiedAccessGroupResponse' :: CreateVerifiedAccessGroupResponse -> Int
$sel:verifiedAccessGroup:CreateVerifiedAccessGroupResponse' :: CreateVerifiedAccessGroupResponse -> Maybe VerifiedAccessGroup
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe VerifiedAccessGroup
verifiedAccessGroup
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus