{-# 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.AppStream.DescribeUserStackAssociations -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Retrieves a list that describes the UserStackAssociation objects. You -- must specify either or both of the following: -- -- - The stack name -- -- - The user name (email address of the user associated with the stack) -- and the authentication type for the user -- -- This operation returns paginated results. module Amazonka.AppStream.DescribeUserStackAssociations ( -- * Creating a Request DescribeUserStackAssociations (..), newDescribeUserStackAssociations, -- * Request Lenses describeUserStackAssociations_authenticationType, describeUserStackAssociations_maxResults, describeUserStackAssociations_nextToken, describeUserStackAssociations_stackName, describeUserStackAssociations_userName, -- * Destructuring the Response DescribeUserStackAssociationsResponse (..), newDescribeUserStackAssociationsResponse, -- * Response Lenses describeUserStackAssociationsResponse_nextToken, describeUserStackAssociationsResponse_userStackAssociations, describeUserStackAssociationsResponse_httpStatus, ) where import Amazonka.AppStream.Types 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 -- | /See:/ 'newDescribeUserStackAssociations' smart constructor. data DescribeUserStackAssociations = DescribeUserStackAssociations' { -- | The authentication type for the user who is associated with the stack. -- You must specify USERPOOL. authenticationType :: Prelude.Maybe AuthenticationType, -- | The maximum size of each page of results. maxResults :: Prelude.Maybe Prelude.Natural, -- | The pagination token to use to retrieve the next page of results for -- this operation. If this value is null, it retrieves the first page. nextToken :: Prelude.Maybe Prelude.Text, -- | The name of the stack that is associated with the user. stackName :: Prelude.Maybe Prelude.Text, -- | The email address of the user who is associated with the stack. -- -- Users\' email addresses are case-sensitive. userName :: Prelude.Maybe (Data.Sensitive Prelude.Text) } deriving (Prelude.Eq, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeUserStackAssociations' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'authenticationType', 'describeUserStackAssociations_authenticationType' - The authentication type for the user who is associated with the stack. -- You must specify USERPOOL. -- -- 'maxResults', 'describeUserStackAssociations_maxResults' - The maximum size of each page of results. -- -- 'nextToken', 'describeUserStackAssociations_nextToken' - The pagination token to use to retrieve the next page of results for -- this operation. If this value is null, it retrieves the first page. -- -- 'stackName', 'describeUserStackAssociations_stackName' - The name of the stack that is associated with the user. -- -- 'userName', 'describeUserStackAssociations_userName' - The email address of the user who is associated with the stack. -- -- Users\' email addresses are case-sensitive. newDescribeUserStackAssociations :: DescribeUserStackAssociations newDescribeUserStackAssociations = DescribeUserStackAssociations' { authenticationType = Prelude.Nothing, maxResults = Prelude.Nothing, nextToken = Prelude.Nothing, stackName = Prelude.Nothing, userName = Prelude.Nothing } -- | The authentication type for the user who is associated with the stack. -- You must specify USERPOOL. describeUserStackAssociations_authenticationType :: Lens.Lens' DescribeUserStackAssociations (Prelude.Maybe AuthenticationType) describeUserStackAssociations_authenticationType = Lens.lens (\DescribeUserStackAssociations' {authenticationType} -> authenticationType) (\s@DescribeUserStackAssociations' {} a -> s {authenticationType = a} :: DescribeUserStackAssociations) -- | The maximum size of each page of results. describeUserStackAssociations_maxResults :: Lens.Lens' DescribeUserStackAssociations (Prelude.Maybe Prelude.Natural) describeUserStackAssociations_maxResults = Lens.lens (\DescribeUserStackAssociations' {maxResults} -> maxResults) (\s@DescribeUserStackAssociations' {} a -> s {maxResults = a} :: DescribeUserStackAssociations) -- | The pagination token to use to retrieve the next page of results for -- this operation. If this value is null, it retrieves the first page. describeUserStackAssociations_nextToken :: Lens.Lens' DescribeUserStackAssociations (Prelude.Maybe Prelude.Text) describeUserStackAssociations_nextToken = Lens.lens (\DescribeUserStackAssociations' {nextToken} -> nextToken) (\s@DescribeUserStackAssociations' {} a -> s {nextToken = a} :: DescribeUserStackAssociations) -- | The name of the stack that is associated with the user. describeUserStackAssociations_stackName :: Lens.Lens' DescribeUserStackAssociations (Prelude.Maybe Prelude.Text) describeUserStackAssociations_stackName = Lens.lens (\DescribeUserStackAssociations' {stackName} -> stackName) (\s@DescribeUserStackAssociations' {} a -> s {stackName = a} :: DescribeUserStackAssociations) -- | The email address of the user who is associated with the stack. -- -- Users\' email addresses are case-sensitive. describeUserStackAssociations_userName :: Lens.Lens' DescribeUserStackAssociations (Prelude.Maybe Prelude.Text) describeUserStackAssociations_userName = Lens.lens (\DescribeUserStackAssociations' {userName} -> userName) (\s@DescribeUserStackAssociations' {} a -> s {userName = a} :: DescribeUserStackAssociations) Prelude.. Lens.mapping Data._Sensitive instance Core.AWSPager DescribeUserStackAssociations where page rq rs | Core.stop ( rs Lens.^? describeUserStackAssociationsResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? describeUserStackAssociationsResponse_userStackAssociations Prelude.. Lens._Just Prelude.. Lens.to Prelude.toList ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& describeUserStackAssociations_nextToken Lens..~ rs Lens.^? describeUserStackAssociationsResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest DescribeUserStackAssociations where type AWSResponse DescribeUserStackAssociations = DescribeUserStackAssociationsResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> DescribeUserStackAssociationsResponse' Prelude.<$> (x Data..?> "NextToken") Prelude.<*> (x Data..?> "UserStackAssociations") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DescribeUserStackAssociations where hashWithSalt _salt DescribeUserStackAssociations' {..} = _salt `Prelude.hashWithSalt` authenticationType `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken `Prelude.hashWithSalt` stackName `Prelude.hashWithSalt` userName instance Prelude.NFData DescribeUserStackAssociations where rnf DescribeUserStackAssociations' {..} = Prelude.rnf authenticationType `Prelude.seq` Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf stackName `Prelude.seq` Prelude.rnf userName instance Data.ToHeaders DescribeUserStackAssociations where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "PhotonAdminProxyService.DescribeUserStackAssociations" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DescribeUserStackAssociations where toJSON DescribeUserStackAssociations' {..} = Data.object ( Prelude.catMaybes [ ("AuthenticationType" Data..=) Prelude.<$> authenticationType, ("MaxResults" Data..=) Prelude.<$> maxResults, ("NextToken" Data..=) Prelude.<$> nextToken, ("StackName" Data..=) Prelude.<$> stackName, ("UserName" Data..=) Prelude.<$> userName ] ) instance Data.ToPath DescribeUserStackAssociations where toPath = Prelude.const "/" instance Data.ToQuery DescribeUserStackAssociations where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDescribeUserStackAssociationsResponse' smart constructor. data DescribeUserStackAssociationsResponse = DescribeUserStackAssociationsResponse' { -- | The pagination token to use to retrieve the next page of results for -- this operation. If there are no more pages, this value is null. nextToken :: Prelude.Maybe Prelude.Text, -- | The UserStackAssociation objects. userStackAssociations :: Prelude.Maybe (Prelude.NonEmpty UserStackAssociation), -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeUserStackAssociationsResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'nextToken', 'describeUserStackAssociationsResponse_nextToken' - The pagination token to use to retrieve the next page of results for -- this operation. If there are no more pages, this value is null. -- -- 'userStackAssociations', 'describeUserStackAssociationsResponse_userStackAssociations' - The UserStackAssociation objects. -- -- 'httpStatus', 'describeUserStackAssociationsResponse_httpStatus' - The response's http status code. newDescribeUserStackAssociationsResponse :: -- | 'httpStatus' Prelude.Int -> DescribeUserStackAssociationsResponse newDescribeUserStackAssociationsResponse pHttpStatus_ = DescribeUserStackAssociationsResponse' { nextToken = Prelude.Nothing, userStackAssociations = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The pagination token to use to retrieve the next page of results for -- this operation. If there are no more pages, this value is null. describeUserStackAssociationsResponse_nextToken :: Lens.Lens' DescribeUserStackAssociationsResponse (Prelude.Maybe Prelude.Text) describeUserStackAssociationsResponse_nextToken = Lens.lens (\DescribeUserStackAssociationsResponse' {nextToken} -> nextToken) (\s@DescribeUserStackAssociationsResponse' {} a -> s {nextToken = a} :: DescribeUserStackAssociationsResponse) -- | The UserStackAssociation objects. describeUserStackAssociationsResponse_userStackAssociations :: Lens.Lens' DescribeUserStackAssociationsResponse (Prelude.Maybe (Prelude.NonEmpty UserStackAssociation)) describeUserStackAssociationsResponse_userStackAssociations = Lens.lens (\DescribeUserStackAssociationsResponse' {userStackAssociations} -> userStackAssociations) (\s@DescribeUserStackAssociationsResponse' {} a -> s {userStackAssociations = a} :: DescribeUserStackAssociationsResponse) Prelude.. Lens.mapping Lens.coerced -- | The response's http status code. describeUserStackAssociationsResponse_httpStatus :: Lens.Lens' DescribeUserStackAssociationsResponse Prelude.Int describeUserStackAssociationsResponse_httpStatus = Lens.lens (\DescribeUserStackAssociationsResponse' {httpStatus} -> httpStatus) (\s@DescribeUserStackAssociationsResponse' {} a -> s {httpStatus = a} :: DescribeUserStackAssociationsResponse) instance Prelude.NFData DescribeUserStackAssociationsResponse where rnf DescribeUserStackAssociationsResponse' {..} = Prelude.rnf nextToken `Prelude.seq` Prelude.rnf userStackAssociations `Prelude.seq` Prelude.rnf httpStatus