{-# 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.EC2.Types.CreateVerifiedAccessTrustProviderOidcOptions
-- 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.EC2.Types.CreateVerifiedAccessTrustProviderOidcOptions where

import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.EC2.Internal
import qualified Amazonka.Prelude as Prelude

-- | Options for an OIDC-based, user-identity type trust provider.
--
-- /See:/ 'newCreateVerifiedAccessTrustProviderOidcOptions' smart constructor.
data CreateVerifiedAccessTrustProviderOidcOptions = CreateVerifiedAccessTrustProviderOidcOptions'
  { -- | The OIDC authorization endpoint.
    CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
authorizationEndpoint :: Prelude.Maybe Prelude.Text,
    -- | The client identifier.
    CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
clientId :: Prelude.Maybe Prelude.Text,
    -- | The client secret.
    CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
clientSecret :: Prelude.Maybe Prelude.Text,
    -- | The OIDC issuer.
    CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
issuer :: Prelude.Maybe Prelude.Text,
    -- | OpenID Connect (OIDC) scopes are used by an application during
    -- authentication to authorize access to a user\'s details. Each scope
    -- returns a specific set of user attributes.
    CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
scope :: Prelude.Maybe Prelude.Text,
    -- | The OIDC token endpoint.
    CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
tokenEndpoint :: Prelude.Maybe Prelude.Text,
    -- | The OIDC user info endpoint.
    CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
userInfoEndpoint :: Prelude.Maybe Prelude.Text
  }
  deriving (CreateVerifiedAccessTrustProviderOidcOptions
-> CreateVerifiedAccessTrustProviderOidcOptions -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: CreateVerifiedAccessTrustProviderOidcOptions
-> CreateVerifiedAccessTrustProviderOidcOptions -> Bool
$c/= :: CreateVerifiedAccessTrustProviderOidcOptions
-> CreateVerifiedAccessTrustProviderOidcOptions -> Bool
== :: CreateVerifiedAccessTrustProviderOidcOptions
-> CreateVerifiedAccessTrustProviderOidcOptions -> Bool
$c== :: CreateVerifiedAccessTrustProviderOidcOptions
-> CreateVerifiedAccessTrustProviderOidcOptions -> Bool
Prelude.Eq, ReadPrec [CreateVerifiedAccessTrustProviderOidcOptions]
ReadPrec CreateVerifiedAccessTrustProviderOidcOptions
Int -> ReadS CreateVerifiedAccessTrustProviderOidcOptions
ReadS [CreateVerifiedAccessTrustProviderOidcOptions]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [CreateVerifiedAccessTrustProviderOidcOptions]
$creadListPrec :: ReadPrec [CreateVerifiedAccessTrustProviderOidcOptions]
readPrec :: ReadPrec CreateVerifiedAccessTrustProviderOidcOptions
$creadPrec :: ReadPrec CreateVerifiedAccessTrustProviderOidcOptions
readList :: ReadS [CreateVerifiedAccessTrustProviderOidcOptions]
$creadList :: ReadS [CreateVerifiedAccessTrustProviderOidcOptions]
readsPrec :: Int -> ReadS CreateVerifiedAccessTrustProviderOidcOptions
$creadsPrec :: Int -> ReadS CreateVerifiedAccessTrustProviderOidcOptions
Prelude.Read, Int -> CreateVerifiedAccessTrustProviderOidcOptions -> ShowS
[CreateVerifiedAccessTrustProviderOidcOptions] -> ShowS
CreateVerifiedAccessTrustProviderOidcOptions -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [CreateVerifiedAccessTrustProviderOidcOptions] -> ShowS
$cshowList :: [CreateVerifiedAccessTrustProviderOidcOptions] -> ShowS
show :: CreateVerifiedAccessTrustProviderOidcOptions -> String
$cshow :: CreateVerifiedAccessTrustProviderOidcOptions -> String
showsPrec :: Int -> CreateVerifiedAccessTrustProviderOidcOptions -> ShowS
$cshowsPrec :: Int -> CreateVerifiedAccessTrustProviderOidcOptions -> ShowS
Prelude.Show, forall x.
Rep CreateVerifiedAccessTrustProviderOidcOptions x
-> CreateVerifiedAccessTrustProviderOidcOptions
forall x.
CreateVerifiedAccessTrustProviderOidcOptions
-> Rep CreateVerifiedAccessTrustProviderOidcOptions x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep CreateVerifiedAccessTrustProviderOidcOptions x
-> CreateVerifiedAccessTrustProviderOidcOptions
$cfrom :: forall x.
CreateVerifiedAccessTrustProviderOidcOptions
-> Rep CreateVerifiedAccessTrustProviderOidcOptions x
Prelude.Generic)

-- |
-- Create a value of 'CreateVerifiedAccessTrustProviderOidcOptions' 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:
--
-- 'authorizationEndpoint', 'createVerifiedAccessTrustProviderOidcOptions_authorizationEndpoint' - The OIDC authorization endpoint.
--
-- 'clientId', 'createVerifiedAccessTrustProviderOidcOptions_clientId' - The client identifier.
--
-- 'clientSecret', 'createVerifiedAccessTrustProviderOidcOptions_clientSecret' - The client secret.
--
-- 'issuer', 'createVerifiedAccessTrustProviderOidcOptions_issuer' - The OIDC issuer.
--
-- 'scope', 'createVerifiedAccessTrustProviderOidcOptions_scope' - OpenID Connect (OIDC) scopes are used by an application during
-- authentication to authorize access to a user\'s details. Each scope
-- returns a specific set of user attributes.
--
-- 'tokenEndpoint', 'createVerifiedAccessTrustProviderOidcOptions_tokenEndpoint' - The OIDC token endpoint.
--
-- 'userInfoEndpoint', 'createVerifiedAccessTrustProviderOidcOptions_userInfoEndpoint' - The OIDC user info endpoint.
newCreateVerifiedAccessTrustProviderOidcOptions ::
  CreateVerifiedAccessTrustProviderOidcOptions
newCreateVerifiedAccessTrustProviderOidcOptions :: CreateVerifiedAccessTrustProviderOidcOptions
newCreateVerifiedAccessTrustProviderOidcOptions =
  CreateVerifiedAccessTrustProviderOidcOptions'
    { $sel:authorizationEndpoint:CreateVerifiedAccessTrustProviderOidcOptions' :: Maybe Text
authorizationEndpoint =
        forall a. Maybe a
Prelude.Nothing,
      $sel:clientId:CreateVerifiedAccessTrustProviderOidcOptions' :: Maybe Text
clientId = forall a. Maybe a
Prelude.Nothing,
      $sel:clientSecret:CreateVerifiedAccessTrustProviderOidcOptions' :: Maybe Text
clientSecret =
        forall a. Maybe a
Prelude.Nothing,
      $sel:issuer:CreateVerifiedAccessTrustProviderOidcOptions' :: Maybe Text
issuer = forall a. Maybe a
Prelude.Nothing,
      $sel:scope:CreateVerifiedAccessTrustProviderOidcOptions' :: Maybe Text
scope = forall a. Maybe a
Prelude.Nothing,
      $sel:tokenEndpoint:CreateVerifiedAccessTrustProviderOidcOptions' :: Maybe Text
tokenEndpoint =
        forall a. Maybe a
Prelude.Nothing,
      $sel:userInfoEndpoint:CreateVerifiedAccessTrustProviderOidcOptions' :: Maybe Text
userInfoEndpoint =
        forall a. Maybe a
Prelude.Nothing
    }

-- | The OIDC authorization endpoint.
createVerifiedAccessTrustProviderOidcOptions_authorizationEndpoint :: Lens.Lens' CreateVerifiedAccessTrustProviderOidcOptions (Prelude.Maybe Prelude.Text)
createVerifiedAccessTrustProviderOidcOptions_authorizationEndpoint :: Lens' CreateVerifiedAccessTrustProviderOidcOptions (Maybe Text)
createVerifiedAccessTrustProviderOidcOptions_authorizationEndpoint = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVerifiedAccessTrustProviderOidcOptions' {Maybe Text
authorizationEndpoint :: Maybe Text
$sel:authorizationEndpoint:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
authorizationEndpoint} -> Maybe Text
authorizationEndpoint) (\s :: CreateVerifiedAccessTrustProviderOidcOptions
s@CreateVerifiedAccessTrustProviderOidcOptions' {} Maybe Text
a -> CreateVerifiedAccessTrustProviderOidcOptions
s {$sel:authorizationEndpoint:CreateVerifiedAccessTrustProviderOidcOptions' :: Maybe Text
authorizationEndpoint = Maybe Text
a} :: CreateVerifiedAccessTrustProviderOidcOptions)

-- | The client identifier.
createVerifiedAccessTrustProviderOidcOptions_clientId :: Lens.Lens' CreateVerifiedAccessTrustProviderOidcOptions (Prelude.Maybe Prelude.Text)
createVerifiedAccessTrustProviderOidcOptions_clientId :: Lens' CreateVerifiedAccessTrustProviderOidcOptions (Maybe Text)
createVerifiedAccessTrustProviderOidcOptions_clientId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVerifiedAccessTrustProviderOidcOptions' {Maybe Text
clientId :: Maybe Text
$sel:clientId:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
clientId} -> Maybe Text
clientId) (\s :: CreateVerifiedAccessTrustProviderOidcOptions
s@CreateVerifiedAccessTrustProviderOidcOptions' {} Maybe Text
a -> CreateVerifiedAccessTrustProviderOidcOptions
s {$sel:clientId:CreateVerifiedAccessTrustProviderOidcOptions' :: Maybe Text
clientId = Maybe Text
a} :: CreateVerifiedAccessTrustProviderOidcOptions)

-- | The client secret.
createVerifiedAccessTrustProviderOidcOptions_clientSecret :: Lens.Lens' CreateVerifiedAccessTrustProviderOidcOptions (Prelude.Maybe Prelude.Text)
createVerifiedAccessTrustProviderOidcOptions_clientSecret :: Lens' CreateVerifiedAccessTrustProviderOidcOptions (Maybe Text)
createVerifiedAccessTrustProviderOidcOptions_clientSecret = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVerifiedAccessTrustProviderOidcOptions' {Maybe Text
clientSecret :: Maybe Text
$sel:clientSecret:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
clientSecret} -> Maybe Text
clientSecret) (\s :: CreateVerifiedAccessTrustProviderOidcOptions
s@CreateVerifiedAccessTrustProviderOidcOptions' {} Maybe Text
a -> CreateVerifiedAccessTrustProviderOidcOptions
s {$sel:clientSecret:CreateVerifiedAccessTrustProviderOidcOptions' :: Maybe Text
clientSecret = Maybe Text
a} :: CreateVerifiedAccessTrustProviderOidcOptions)

-- | The OIDC issuer.
createVerifiedAccessTrustProviderOidcOptions_issuer :: Lens.Lens' CreateVerifiedAccessTrustProviderOidcOptions (Prelude.Maybe Prelude.Text)
createVerifiedAccessTrustProviderOidcOptions_issuer :: Lens' CreateVerifiedAccessTrustProviderOidcOptions (Maybe Text)
createVerifiedAccessTrustProviderOidcOptions_issuer = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVerifiedAccessTrustProviderOidcOptions' {Maybe Text
issuer :: Maybe Text
$sel:issuer:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
issuer} -> Maybe Text
issuer) (\s :: CreateVerifiedAccessTrustProviderOidcOptions
s@CreateVerifiedAccessTrustProviderOidcOptions' {} Maybe Text
a -> CreateVerifiedAccessTrustProviderOidcOptions
s {$sel:issuer:CreateVerifiedAccessTrustProviderOidcOptions' :: Maybe Text
issuer = Maybe Text
a} :: CreateVerifiedAccessTrustProviderOidcOptions)

-- | OpenID Connect (OIDC) scopes are used by an application during
-- authentication to authorize access to a user\'s details. Each scope
-- returns a specific set of user attributes.
createVerifiedAccessTrustProviderOidcOptions_scope :: Lens.Lens' CreateVerifiedAccessTrustProviderOidcOptions (Prelude.Maybe Prelude.Text)
createVerifiedAccessTrustProviderOidcOptions_scope :: Lens' CreateVerifiedAccessTrustProviderOidcOptions (Maybe Text)
createVerifiedAccessTrustProviderOidcOptions_scope = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVerifiedAccessTrustProviderOidcOptions' {Maybe Text
scope :: Maybe Text
$sel:scope:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
scope} -> Maybe Text
scope) (\s :: CreateVerifiedAccessTrustProviderOidcOptions
s@CreateVerifiedAccessTrustProviderOidcOptions' {} Maybe Text
a -> CreateVerifiedAccessTrustProviderOidcOptions
s {$sel:scope:CreateVerifiedAccessTrustProviderOidcOptions' :: Maybe Text
scope = Maybe Text
a} :: CreateVerifiedAccessTrustProviderOidcOptions)

-- | The OIDC token endpoint.
createVerifiedAccessTrustProviderOidcOptions_tokenEndpoint :: Lens.Lens' CreateVerifiedAccessTrustProviderOidcOptions (Prelude.Maybe Prelude.Text)
createVerifiedAccessTrustProviderOidcOptions_tokenEndpoint :: Lens' CreateVerifiedAccessTrustProviderOidcOptions (Maybe Text)
createVerifiedAccessTrustProviderOidcOptions_tokenEndpoint = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVerifiedAccessTrustProviderOidcOptions' {Maybe Text
tokenEndpoint :: Maybe Text
$sel:tokenEndpoint:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
tokenEndpoint} -> Maybe Text
tokenEndpoint) (\s :: CreateVerifiedAccessTrustProviderOidcOptions
s@CreateVerifiedAccessTrustProviderOidcOptions' {} Maybe Text
a -> CreateVerifiedAccessTrustProviderOidcOptions
s {$sel:tokenEndpoint:CreateVerifiedAccessTrustProviderOidcOptions' :: Maybe Text
tokenEndpoint = Maybe Text
a} :: CreateVerifiedAccessTrustProviderOidcOptions)

-- | The OIDC user info endpoint.
createVerifiedAccessTrustProviderOidcOptions_userInfoEndpoint :: Lens.Lens' CreateVerifiedAccessTrustProviderOidcOptions (Prelude.Maybe Prelude.Text)
createVerifiedAccessTrustProviderOidcOptions_userInfoEndpoint :: Lens' CreateVerifiedAccessTrustProviderOidcOptions (Maybe Text)
createVerifiedAccessTrustProviderOidcOptions_userInfoEndpoint = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVerifiedAccessTrustProviderOidcOptions' {Maybe Text
userInfoEndpoint :: Maybe Text
$sel:userInfoEndpoint:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
userInfoEndpoint} -> Maybe Text
userInfoEndpoint) (\s :: CreateVerifiedAccessTrustProviderOidcOptions
s@CreateVerifiedAccessTrustProviderOidcOptions' {} Maybe Text
a -> CreateVerifiedAccessTrustProviderOidcOptions
s {$sel:userInfoEndpoint:CreateVerifiedAccessTrustProviderOidcOptions' :: Maybe Text
userInfoEndpoint = Maybe Text
a} :: CreateVerifiedAccessTrustProviderOidcOptions)

instance
  Prelude.Hashable
    CreateVerifiedAccessTrustProviderOidcOptions
  where
  hashWithSalt :: Int -> CreateVerifiedAccessTrustProviderOidcOptions -> Int
hashWithSalt
    Int
_salt
    CreateVerifiedAccessTrustProviderOidcOptions' {Maybe Text
userInfoEndpoint :: Maybe Text
tokenEndpoint :: Maybe Text
scope :: Maybe Text
issuer :: Maybe Text
clientSecret :: Maybe Text
clientId :: Maybe Text
authorizationEndpoint :: Maybe Text
$sel:userInfoEndpoint:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
$sel:tokenEndpoint:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
$sel:scope:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
$sel:issuer:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
$sel:clientSecret:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
$sel:clientId:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
$sel:authorizationEndpoint:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
..} =
      Int
_salt
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
authorizationEndpoint
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
clientId
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
clientSecret
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
issuer
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
scope
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
tokenEndpoint
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
userInfoEndpoint

instance
  Prelude.NFData
    CreateVerifiedAccessTrustProviderOidcOptions
  where
  rnf :: CreateVerifiedAccessTrustProviderOidcOptions -> ()
rnf CreateVerifiedAccessTrustProviderOidcOptions' {Maybe Text
userInfoEndpoint :: Maybe Text
tokenEndpoint :: Maybe Text
scope :: Maybe Text
issuer :: Maybe Text
clientSecret :: Maybe Text
clientId :: Maybe Text
authorizationEndpoint :: Maybe Text
$sel:userInfoEndpoint:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
$sel:tokenEndpoint:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
$sel:scope:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
$sel:issuer:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
$sel:clientSecret:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
$sel:clientId:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
$sel:authorizationEndpoint:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
authorizationEndpoint
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
clientId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
clientSecret
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
issuer
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
scope
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
tokenEndpoint
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
userInfoEndpoint

instance
  Data.ToQuery
    CreateVerifiedAccessTrustProviderOidcOptions
  where
  toQuery :: CreateVerifiedAccessTrustProviderOidcOptions -> QueryString
toQuery
    CreateVerifiedAccessTrustProviderOidcOptions' {Maybe Text
userInfoEndpoint :: Maybe Text
tokenEndpoint :: Maybe Text
scope :: Maybe Text
issuer :: Maybe Text
clientSecret :: Maybe Text
clientId :: Maybe Text
authorizationEndpoint :: Maybe Text
$sel:userInfoEndpoint:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
$sel:tokenEndpoint:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
$sel:scope:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
$sel:issuer:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
$sel:clientSecret:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
$sel:clientId:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
$sel:authorizationEndpoint:CreateVerifiedAccessTrustProviderOidcOptions' :: CreateVerifiedAccessTrustProviderOidcOptions -> Maybe Text
..} =
      forall a. Monoid a => [a] -> a
Prelude.mconcat
        [ ByteString
"AuthorizationEndpoint"
            forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
authorizationEndpoint,
          ByteString
"ClientId" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
clientId,
          ByteString
"ClientSecret" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
clientSecret,
          ByteString
"Issuer" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
issuer,
          ByteString
"Scope" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
scope,
          ByteString
"TokenEndpoint" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
tokenEndpoint,
          ByteString
"UserInfoEndpoint" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
userInfoEndpoint
        ]