{-# 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.FinSpaceData.Types.UserByPermissionGroup
-- 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.FinSpaceData.Types.UserByPermissionGroup where

import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.FinSpaceData.Types.ApiAccess
import Amazonka.FinSpaceData.Types.PermissionGroupMembershipStatus
import Amazonka.FinSpaceData.Types.UserStatus
import Amazonka.FinSpaceData.Types.UserType
import qualified Amazonka.Prelude as Prelude

-- | The structure of a user account associated with a permission group.
--
-- /See:/ 'newUserByPermissionGroup' smart constructor.
data UserByPermissionGroup = UserByPermissionGroup'
  { -- | Indicates whether the user can access FinSpace API operations.
    --
    -- -   @ENABLED@ – The user has permissions to use the API operations.
    --
    -- -   @DISABLED@ – The user does not have permissions to use any API
    --     operations.
    UserByPermissionGroup -> Maybe ApiAccess
apiAccess :: Prelude.Maybe ApiAccess,
    -- | The IAM ARN identifier that is attached to FinSpace API calls.
    UserByPermissionGroup -> Maybe Text
apiAccessPrincipalArn :: Prelude.Maybe Prelude.Text,
    -- | The email address of the user. The email address serves as a unique
    -- identifier for each user and cannot be changed after it\'s created.
    UserByPermissionGroup -> Maybe (Sensitive Text)
emailAddress :: Prelude.Maybe (Data.Sensitive Prelude.Text),
    -- | The first name of the user.
    UserByPermissionGroup -> Maybe (Sensitive Text)
firstName :: Prelude.Maybe (Data.Sensitive Prelude.Text),
    -- | The last name of the user.
    UserByPermissionGroup -> Maybe (Sensitive Text)
lastName :: Prelude.Maybe (Data.Sensitive Prelude.Text),
    -- | Indicates the status of the user account within a permission group.
    --
    -- -   @ADDITION_IN_PROGRESS@ – The user account is currently being added
    --     to the permission group.
    --
    -- -   @ADDITION_SUCCESS@ – The user account is successfully added to the
    --     permission group.
    --
    -- -   @REMOVAL_IN_PROGRESS@ – The user is currently being removed from the
    --     permission group.
    UserByPermissionGroup -> Maybe PermissionGroupMembershipStatus
membershipStatus :: Prelude.Maybe PermissionGroupMembershipStatus,
    -- | The current status of the user account.
    --
    -- -   @CREATING@ – The user account creation is in progress.
    --
    -- -   @ENABLED@ – The user account is created and is currently active.
    --
    -- -   @DISABLED@ – The user account is currently inactive.
    UserByPermissionGroup -> Maybe UserStatus
status :: Prelude.Maybe UserStatus,
    -- | Indicates the type of user.
    --
    -- -   @SUPER_USER@ – A user with permission to all the functionality and
    --     data in FinSpace.
    --
    -- -   @APP_USER@ – A user with specific permissions in FinSpace. The users
    --     are assigned permissions by adding them to a permission group.
    UserByPermissionGroup -> Maybe UserType
type' :: Prelude.Maybe UserType,
    -- | The unique identifier for the user.
    UserByPermissionGroup -> Maybe Text
userId :: Prelude.Maybe Prelude.Text
  }
  deriving (UserByPermissionGroup -> UserByPermissionGroup -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: UserByPermissionGroup -> UserByPermissionGroup -> Bool
$c/= :: UserByPermissionGroup -> UserByPermissionGroup -> Bool
== :: UserByPermissionGroup -> UserByPermissionGroup -> Bool
$c== :: UserByPermissionGroup -> UserByPermissionGroup -> Bool
Prelude.Eq, Int -> UserByPermissionGroup -> ShowS
[UserByPermissionGroup] -> ShowS
UserByPermissionGroup -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [UserByPermissionGroup] -> ShowS
$cshowList :: [UserByPermissionGroup] -> ShowS
show :: UserByPermissionGroup -> String
$cshow :: UserByPermissionGroup -> String
showsPrec :: Int -> UserByPermissionGroup -> ShowS
$cshowsPrec :: Int -> UserByPermissionGroup -> ShowS
Prelude.Show, forall x. Rep UserByPermissionGroup x -> UserByPermissionGroup
forall x. UserByPermissionGroup -> Rep UserByPermissionGroup x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep UserByPermissionGroup x -> UserByPermissionGroup
$cfrom :: forall x. UserByPermissionGroup -> Rep UserByPermissionGroup x
Prelude.Generic)

-- |
-- Create a value of 'UserByPermissionGroup' 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:
--
-- 'apiAccess', 'userByPermissionGroup_apiAccess' - Indicates whether the user can access FinSpace API operations.
--
-- -   @ENABLED@ – The user has permissions to use the API operations.
--
-- -   @DISABLED@ – The user does not have permissions to use any API
--     operations.
--
-- 'apiAccessPrincipalArn', 'userByPermissionGroup_apiAccessPrincipalArn' - The IAM ARN identifier that is attached to FinSpace API calls.
--
-- 'emailAddress', 'userByPermissionGroup_emailAddress' - The email address of the user. The email address serves as a unique
-- identifier for each user and cannot be changed after it\'s created.
--
-- 'firstName', 'userByPermissionGroup_firstName' - The first name of the user.
--
-- 'lastName', 'userByPermissionGroup_lastName' - The last name of the user.
--
-- 'membershipStatus', 'userByPermissionGroup_membershipStatus' - Indicates the status of the user account within a permission group.
--
-- -   @ADDITION_IN_PROGRESS@ – The user account is currently being added
--     to the permission group.
--
-- -   @ADDITION_SUCCESS@ – The user account is successfully added to the
--     permission group.
--
-- -   @REMOVAL_IN_PROGRESS@ – The user is currently being removed from the
--     permission group.
--
-- 'status', 'userByPermissionGroup_status' - The current status of the user account.
--
-- -   @CREATING@ – The user account creation is in progress.
--
-- -   @ENABLED@ – The user account is created and is currently active.
--
-- -   @DISABLED@ – The user account is currently inactive.
--
-- 'type'', 'userByPermissionGroup_type' - Indicates the type of user.
--
-- -   @SUPER_USER@ – A user with permission to all the functionality and
--     data in FinSpace.
--
-- -   @APP_USER@ – A user with specific permissions in FinSpace. The users
--     are assigned permissions by adding them to a permission group.
--
-- 'userId', 'userByPermissionGroup_userId' - The unique identifier for the user.
newUserByPermissionGroup ::
  UserByPermissionGroup
newUserByPermissionGroup :: UserByPermissionGroup
newUserByPermissionGroup =
  UserByPermissionGroup'
    { $sel:apiAccess:UserByPermissionGroup' :: Maybe ApiAccess
apiAccess = forall a. Maybe a
Prelude.Nothing,
      $sel:apiAccessPrincipalArn:UserByPermissionGroup' :: Maybe Text
apiAccessPrincipalArn = forall a. Maybe a
Prelude.Nothing,
      $sel:emailAddress:UserByPermissionGroup' :: Maybe (Sensitive Text)
emailAddress = forall a. Maybe a
Prelude.Nothing,
      $sel:firstName:UserByPermissionGroup' :: Maybe (Sensitive Text)
firstName = forall a. Maybe a
Prelude.Nothing,
      $sel:lastName:UserByPermissionGroup' :: Maybe (Sensitive Text)
lastName = forall a. Maybe a
Prelude.Nothing,
      $sel:membershipStatus:UserByPermissionGroup' :: Maybe PermissionGroupMembershipStatus
membershipStatus = forall a. Maybe a
Prelude.Nothing,
      $sel:status:UserByPermissionGroup' :: Maybe UserStatus
status = forall a. Maybe a
Prelude.Nothing,
      $sel:type':UserByPermissionGroup' :: Maybe UserType
type' = forall a. Maybe a
Prelude.Nothing,
      $sel:userId:UserByPermissionGroup' :: Maybe Text
userId = forall a. Maybe a
Prelude.Nothing
    }

-- | Indicates whether the user can access FinSpace API operations.
--
-- -   @ENABLED@ – The user has permissions to use the API operations.
--
-- -   @DISABLED@ – The user does not have permissions to use any API
--     operations.
userByPermissionGroup_apiAccess :: Lens.Lens' UserByPermissionGroup (Prelude.Maybe ApiAccess)
userByPermissionGroup_apiAccess :: Lens' UserByPermissionGroup (Maybe ApiAccess)
userByPermissionGroup_apiAccess = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UserByPermissionGroup' {Maybe ApiAccess
apiAccess :: Maybe ApiAccess
$sel:apiAccess:UserByPermissionGroup' :: UserByPermissionGroup -> Maybe ApiAccess
apiAccess} -> Maybe ApiAccess
apiAccess) (\s :: UserByPermissionGroup
s@UserByPermissionGroup' {} Maybe ApiAccess
a -> UserByPermissionGroup
s {$sel:apiAccess:UserByPermissionGroup' :: Maybe ApiAccess
apiAccess = Maybe ApiAccess
a} :: UserByPermissionGroup)

-- | The IAM ARN identifier that is attached to FinSpace API calls.
userByPermissionGroup_apiAccessPrincipalArn :: Lens.Lens' UserByPermissionGroup (Prelude.Maybe Prelude.Text)
userByPermissionGroup_apiAccessPrincipalArn :: Lens' UserByPermissionGroup (Maybe Text)
userByPermissionGroup_apiAccessPrincipalArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UserByPermissionGroup' {Maybe Text
apiAccessPrincipalArn :: Maybe Text
$sel:apiAccessPrincipalArn:UserByPermissionGroup' :: UserByPermissionGroup -> Maybe Text
apiAccessPrincipalArn} -> Maybe Text
apiAccessPrincipalArn) (\s :: UserByPermissionGroup
s@UserByPermissionGroup' {} Maybe Text
a -> UserByPermissionGroup
s {$sel:apiAccessPrincipalArn:UserByPermissionGroup' :: Maybe Text
apiAccessPrincipalArn = Maybe Text
a} :: UserByPermissionGroup)

-- | The email address of the user. The email address serves as a unique
-- identifier for each user and cannot be changed after it\'s created.
userByPermissionGroup_emailAddress :: Lens.Lens' UserByPermissionGroup (Prelude.Maybe Prelude.Text)
userByPermissionGroup_emailAddress :: Lens' UserByPermissionGroup (Maybe Text)
userByPermissionGroup_emailAddress = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UserByPermissionGroup' {Maybe (Sensitive Text)
emailAddress :: Maybe (Sensitive Text)
$sel:emailAddress:UserByPermissionGroup' :: UserByPermissionGroup -> Maybe (Sensitive Text)
emailAddress} -> Maybe (Sensitive Text)
emailAddress) (\s :: UserByPermissionGroup
s@UserByPermissionGroup' {} Maybe (Sensitive Text)
a -> UserByPermissionGroup
s {$sel:emailAddress:UserByPermissionGroup' :: Maybe (Sensitive Text)
emailAddress = Maybe (Sensitive Text)
a} :: UserByPermissionGroup) 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 a. Iso' (Sensitive a) a
Data._Sensitive

-- | The first name of the user.
userByPermissionGroup_firstName :: Lens.Lens' UserByPermissionGroup (Prelude.Maybe Prelude.Text)
userByPermissionGroup_firstName :: Lens' UserByPermissionGroup (Maybe Text)
userByPermissionGroup_firstName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UserByPermissionGroup' {Maybe (Sensitive Text)
firstName :: Maybe (Sensitive Text)
$sel:firstName:UserByPermissionGroup' :: UserByPermissionGroup -> Maybe (Sensitive Text)
firstName} -> Maybe (Sensitive Text)
firstName) (\s :: UserByPermissionGroup
s@UserByPermissionGroup' {} Maybe (Sensitive Text)
a -> UserByPermissionGroup
s {$sel:firstName:UserByPermissionGroup' :: Maybe (Sensitive Text)
firstName = Maybe (Sensitive Text)
a} :: UserByPermissionGroup) 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 a. Iso' (Sensitive a) a
Data._Sensitive

-- | The last name of the user.
userByPermissionGroup_lastName :: Lens.Lens' UserByPermissionGroup (Prelude.Maybe Prelude.Text)
userByPermissionGroup_lastName :: Lens' UserByPermissionGroup (Maybe Text)
userByPermissionGroup_lastName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UserByPermissionGroup' {Maybe (Sensitive Text)
lastName :: Maybe (Sensitive Text)
$sel:lastName:UserByPermissionGroup' :: UserByPermissionGroup -> Maybe (Sensitive Text)
lastName} -> Maybe (Sensitive Text)
lastName) (\s :: UserByPermissionGroup
s@UserByPermissionGroup' {} Maybe (Sensitive Text)
a -> UserByPermissionGroup
s {$sel:lastName:UserByPermissionGroup' :: Maybe (Sensitive Text)
lastName = Maybe (Sensitive Text)
a} :: UserByPermissionGroup) 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 a. Iso' (Sensitive a) a
Data._Sensitive

-- | Indicates the status of the user account within a permission group.
--
-- -   @ADDITION_IN_PROGRESS@ – The user account is currently being added
--     to the permission group.
--
-- -   @ADDITION_SUCCESS@ – The user account is successfully added to the
--     permission group.
--
-- -   @REMOVAL_IN_PROGRESS@ – The user is currently being removed from the
--     permission group.
userByPermissionGroup_membershipStatus :: Lens.Lens' UserByPermissionGroup (Prelude.Maybe PermissionGroupMembershipStatus)
userByPermissionGroup_membershipStatus :: Lens' UserByPermissionGroup (Maybe PermissionGroupMembershipStatus)
userByPermissionGroup_membershipStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UserByPermissionGroup' {Maybe PermissionGroupMembershipStatus
membershipStatus :: Maybe PermissionGroupMembershipStatus
$sel:membershipStatus:UserByPermissionGroup' :: UserByPermissionGroup -> Maybe PermissionGroupMembershipStatus
membershipStatus} -> Maybe PermissionGroupMembershipStatus
membershipStatus) (\s :: UserByPermissionGroup
s@UserByPermissionGroup' {} Maybe PermissionGroupMembershipStatus
a -> UserByPermissionGroup
s {$sel:membershipStatus:UserByPermissionGroup' :: Maybe PermissionGroupMembershipStatus
membershipStatus = Maybe PermissionGroupMembershipStatus
a} :: UserByPermissionGroup)

-- | The current status of the user account.
--
-- -   @CREATING@ – The user account creation is in progress.
--
-- -   @ENABLED@ – The user account is created and is currently active.
--
-- -   @DISABLED@ – The user account is currently inactive.
userByPermissionGroup_status :: Lens.Lens' UserByPermissionGroup (Prelude.Maybe UserStatus)
userByPermissionGroup_status :: Lens' UserByPermissionGroup (Maybe UserStatus)
userByPermissionGroup_status = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UserByPermissionGroup' {Maybe UserStatus
status :: Maybe UserStatus
$sel:status:UserByPermissionGroup' :: UserByPermissionGroup -> Maybe UserStatus
status} -> Maybe UserStatus
status) (\s :: UserByPermissionGroup
s@UserByPermissionGroup' {} Maybe UserStatus
a -> UserByPermissionGroup
s {$sel:status:UserByPermissionGroup' :: Maybe UserStatus
status = Maybe UserStatus
a} :: UserByPermissionGroup)

-- | Indicates the type of user.
--
-- -   @SUPER_USER@ – A user with permission to all the functionality and
--     data in FinSpace.
--
-- -   @APP_USER@ – A user with specific permissions in FinSpace. The users
--     are assigned permissions by adding them to a permission group.
userByPermissionGroup_type :: Lens.Lens' UserByPermissionGroup (Prelude.Maybe UserType)
userByPermissionGroup_type :: Lens' UserByPermissionGroup (Maybe UserType)
userByPermissionGroup_type = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UserByPermissionGroup' {Maybe UserType
type' :: Maybe UserType
$sel:type':UserByPermissionGroup' :: UserByPermissionGroup -> Maybe UserType
type'} -> Maybe UserType
type') (\s :: UserByPermissionGroup
s@UserByPermissionGroup' {} Maybe UserType
a -> UserByPermissionGroup
s {$sel:type':UserByPermissionGroup' :: Maybe UserType
type' = Maybe UserType
a} :: UserByPermissionGroup)

-- | The unique identifier for the user.
userByPermissionGroup_userId :: Lens.Lens' UserByPermissionGroup (Prelude.Maybe Prelude.Text)
userByPermissionGroup_userId :: Lens' UserByPermissionGroup (Maybe Text)
userByPermissionGroup_userId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UserByPermissionGroup' {Maybe Text
userId :: Maybe Text
$sel:userId:UserByPermissionGroup' :: UserByPermissionGroup -> Maybe Text
userId} -> Maybe Text
userId) (\s :: UserByPermissionGroup
s@UserByPermissionGroup' {} Maybe Text
a -> UserByPermissionGroup
s {$sel:userId:UserByPermissionGroup' :: Maybe Text
userId = Maybe Text
a} :: UserByPermissionGroup)

instance Data.FromJSON UserByPermissionGroup where
  parseJSON :: Value -> Parser UserByPermissionGroup
parseJSON =
    forall a. String -> (Object -> Parser a) -> Value -> Parser a
Data.withObject
      String
"UserByPermissionGroup"
      ( \Object
x ->
          Maybe ApiAccess
-> Maybe Text
-> Maybe (Sensitive Text)
-> Maybe (Sensitive Text)
-> Maybe (Sensitive Text)
-> Maybe PermissionGroupMembershipStatus
-> Maybe UserStatus
-> Maybe UserType
-> Maybe Text
-> UserByPermissionGroup
UserByPermissionGroup'
            forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"apiAccess")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"apiAccessPrincipalArn")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"emailAddress")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"firstName")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"lastName")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"membershipStatus")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"status")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"type")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"userId")
      )

instance Prelude.Hashable UserByPermissionGroup where
  hashWithSalt :: Int -> UserByPermissionGroup -> Int
hashWithSalt Int
_salt UserByPermissionGroup' {Maybe Text
Maybe (Sensitive Text)
Maybe ApiAccess
Maybe PermissionGroupMembershipStatus
Maybe UserStatus
Maybe UserType
userId :: Maybe Text
type' :: Maybe UserType
status :: Maybe UserStatus
membershipStatus :: Maybe PermissionGroupMembershipStatus
lastName :: Maybe (Sensitive Text)
firstName :: Maybe (Sensitive Text)
emailAddress :: Maybe (Sensitive Text)
apiAccessPrincipalArn :: Maybe Text
apiAccess :: Maybe ApiAccess
$sel:userId:UserByPermissionGroup' :: UserByPermissionGroup -> Maybe Text
$sel:type':UserByPermissionGroup' :: UserByPermissionGroup -> Maybe UserType
$sel:status:UserByPermissionGroup' :: UserByPermissionGroup -> Maybe UserStatus
$sel:membershipStatus:UserByPermissionGroup' :: UserByPermissionGroup -> Maybe PermissionGroupMembershipStatus
$sel:lastName:UserByPermissionGroup' :: UserByPermissionGroup -> Maybe (Sensitive Text)
$sel:firstName:UserByPermissionGroup' :: UserByPermissionGroup -> Maybe (Sensitive Text)
$sel:emailAddress:UserByPermissionGroup' :: UserByPermissionGroup -> Maybe (Sensitive Text)
$sel:apiAccessPrincipalArn:UserByPermissionGroup' :: UserByPermissionGroup -> Maybe Text
$sel:apiAccess:UserByPermissionGroup' :: UserByPermissionGroup -> Maybe ApiAccess
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe ApiAccess
apiAccess
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
apiAccessPrincipalArn
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe (Sensitive Text)
emailAddress
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe (Sensitive Text)
firstName
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe (Sensitive Text)
lastName
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe PermissionGroupMembershipStatus
membershipStatus
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe UserStatus
status
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe UserType
type'
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
userId

instance Prelude.NFData UserByPermissionGroup where
  rnf :: UserByPermissionGroup -> ()
rnf UserByPermissionGroup' {Maybe Text
Maybe (Sensitive Text)
Maybe ApiAccess
Maybe PermissionGroupMembershipStatus
Maybe UserStatus
Maybe UserType
userId :: Maybe Text
type' :: Maybe UserType
status :: Maybe UserStatus
membershipStatus :: Maybe PermissionGroupMembershipStatus
lastName :: Maybe (Sensitive Text)
firstName :: Maybe (Sensitive Text)
emailAddress :: Maybe (Sensitive Text)
apiAccessPrincipalArn :: Maybe Text
apiAccess :: Maybe ApiAccess
$sel:userId:UserByPermissionGroup' :: UserByPermissionGroup -> Maybe Text
$sel:type':UserByPermissionGroup' :: UserByPermissionGroup -> Maybe UserType
$sel:status:UserByPermissionGroup' :: UserByPermissionGroup -> Maybe UserStatus
$sel:membershipStatus:UserByPermissionGroup' :: UserByPermissionGroup -> Maybe PermissionGroupMembershipStatus
$sel:lastName:UserByPermissionGroup' :: UserByPermissionGroup -> Maybe (Sensitive Text)
$sel:firstName:UserByPermissionGroup' :: UserByPermissionGroup -> Maybe (Sensitive Text)
$sel:emailAddress:UserByPermissionGroup' :: UserByPermissionGroup -> Maybe (Sensitive Text)
$sel:apiAccessPrincipalArn:UserByPermissionGroup' :: UserByPermissionGroup -> Maybe Text
$sel:apiAccess:UserByPermissionGroup' :: UserByPermissionGroup -> Maybe ApiAccess
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe ApiAccess
apiAccess
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
apiAccessPrincipalArn
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe (Sensitive Text)
emailAddress
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe (Sensitive Text)
firstName
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe (Sensitive Text)
lastName
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe PermissionGroupMembershipStatus
membershipStatus
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe UserStatus
status
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe UserType
type'
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
userId