{-# 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.PinpointSmsVoiceV2.DescribeAccountAttributes -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Describes attributes of your Amazon Web Services account. The supported -- account attributes include account tier, which indicates whether your -- account is in the sandbox or production environment. When you\'re ready -- to move your account out of the sandbox, create an Amazon Web Services -- Support case for a service limit increase request. -- -- New Amazon Pinpoint accounts are placed into an SMS or voice sandbox. -- The sandbox protects both Amazon Web Services end recipients and SMS or -- voice recipients from fraud and abuse. -- -- This operation returns paginated results. module Amazonka.PinpointSmsVoiceV2.DescribeAccountAttributes ( -- * Creating a Request DescribeAccountAttributes (..), newDescribeAccountAttributes, -- * Request Lenses describeAccountAttributes_maxResults, describeAccountAttributes_nextToken, -- * Destructuring the Response DescribeAccountAttributesResponse (..), newDescribeAccountAttributesResponse, -- * Response Lenses describeAccountAttributesResponse_accountAttributes, describeAccountAttributesResponse_nextToken, describeAccountAttributesResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.PinpointSmsVoiceV2.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newDescribeAccountAttributes' smart constructor. data DescribeAccountAttributes = DescribeAccountAttributes' { -- | The maximum number of results to return per each request. maxResults :: Prelude.Maybe Prelude.Natural, -- | The token to be used for the next set of paginated results. You don\'t -- need to supply a value for this field in the initial request. nextToken :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeAccountAttributes' 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: -- -- 'maxResults', 'describeAccountAttributes_maxResults' - The maximum number of results to return per each request. -- -- 'nextToken', 'describeAccountAttributes_nextToken' - The token to be used for the next set of paginated results. You don\'t -- need to supply a value for this field in the initial request. newDescribeAccountAttributes :: DescribeAccountAttributes newDescribeAccountAttributes = DescribeAccountAttributes' { maxResults = Prelude.Nothing, nextToken = Prelude.Nothing } -- | The maximum number of results to return per each request. describeAccountAttributes_maxResults :: Lens.Lens' DescribeAccountAttributes (Prelude.Maybe Prelude.Natural) describeAccountAttributes_maxResults = Lens.lens (\DescribeAccountAttributes' {maxResults} -> maxResults) (\s@DescribeAccountAttributes' {} a -> s {maxResults = a} :: DescribeAccountAttributes) -- | The token to be used for the next set of paginated results. You don\'t -- need to supply a value for this field in the initial request. describeAccountAttributes_nextToken :: Lens.Lens' DescribeAccountAttributes (Prelude.Maybe Prelude.Text) describeAccountAttributes_nextToken = Lens.lens (\DescribeAccountAttributes' {nextToken} -> nextToken) (\s@DescribeAccountAttributes' {} a -> s {nextToken = a} :: DescribeAccountAttributes) instance Core.AWSPager DescribeAccountAttributes where page rq rs | Core.stop ( rs Lens.^? describeAccountAttributesResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? describeAccountAttributesResponse_accountAttributes Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& describeAccountAttributes_nextToken Lens..~ rs Lens.^? describeAccountAttributesResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest DescribeAccountAttributes where type AWSResponse DescribeAccountAttributes = DescribeAccountAttributesResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> DescribeAccountAttributesResponse' Prelude.<$> ( x Data..?> "AccountAttributes" Core..!@ Prelude.mempty ) Prelude.<*> (x Data..?> "NextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DescribeAccountAttributes where hashWithSalt _salt DescribeAccountAttributes' {..} = _salt `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken instance Prelude.NFData DescribeAccountAttributes where rnf DescribeAccountAttributes' {..} = Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken instance Data.ToHeaders DescribeAccountAttributes where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "PinpointSMSVoiceV2.DescribeAccountAttributes" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.0" :: Prelude.ByteString ) ] ) instance Data.ToJSON DescribeAccountAttributes where toJSON DescribeAccountAttributes' {..} = Data.object ( Prelude.catMaybes [ ("MaxResults" Data..=) Prelude.<$> maxResults, ("NextToken" Data..=) Prelude.<$> nextToken ] ) instance Data.ToPath DescribeAccountAttributes where toPath = Prelude.const "/" instance Data.ToQuery DescribeAccountAttributes where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDescribeAccountAttributesResponse' smart constructor. data DescribeAccountAttributesResponse = DescribeAccountAttributesResponse' { -- | An array of AccountAttributes objects. accountAttributes :: Prelude.Maybe [AccountAttribute], -- | The token to be used for the next set of paginated results. If this -- field is empty then there are no more results. nextToken :: Prelude.Maybe Prelude.Text, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeAccountAttributesResponse' 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: -- -- 'accountAttributes', 'describeAccountAttributesResponse_accountAttributes' - An array of AccountAttributes objects. -- -- 'nextToken', 'describeAccountAttributesResponse_nextToken' - The token to be used for the next set of paginated results. If this -- field is empty then there are no more results. -- -- 'httpStatus', 'describeAccountAttributesResponse_httpStatus' - The response's http status code. newDescribeAccountAttributesResponse :: -- | 'httpStatus' Prelude.Int -> DescribeAccountAttributesResponse newDescribeAccountAttributesResponse pHttpStatus_ = DescribeAccountAttributesResponse' { accountAttributes = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | An array of AccountAttributes objects. describeAccountAttributesResponse_accountAttributes :: Lens.Lens' DescribeAccountAttributesResponse (Prelude.Maybe [AccountAttribute]) describeAccountAttributesResponse_accountAttributes = Lens.lens (\DescribeAccountAttributesResponse' {accountAttributes} -> accountAttributes) (\s@DescribeAccountAttributesResponse' {} a -> s {accountAttributes = a} :: DescribeAccountAttributesResponse) Prelude.. Lens.mapping Lens.coerced -- | The token to be used for the next set of paginated results. If this -- field is empty then there are no more results. describeAccountAttributesResponse_nextToken :: Lens.Lens' DescribeAccountAttributesResponse (Prelude.Maybe Prelude.Text) describeAccountAttributesResponse_nextToken = Lens.lens (\DescribeAccountAttributesResponse' {nextToken} -> nextToken) (\s@DescribeAccountAttributesResponse' {} a -> s {nextToken = a} :: DescribeAccountAttributesResponse) -- | The response's http status code. describeAccountAttributesResponse_httpStatus :: Lens.Lens' DescribeAccountAttributesResponse Prelude.Int describeAccountAttributesResponse_httpStatus = Lens.lens (\DescribeAccountAttributesResponse' {httpStatus} -> httpStatus) (\s@DescribeAccountAttributesResponse' {} a -> s {httpStatus = a} :: DescribeAccountAttributesResponse) instance Prelude.NFData DescribeAccountAttributesResponse where rnf DescribeAccountAttributesResponse' {..} = Prelude.rnf accountAttributes `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus