{-# 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.Support.DescribeCases -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Returns a list of cases that you specify by passing one or more case -- IDs. You can use the @afterTime@ and @beforeTime@ parameters to filter -- the cases by date. You can set values for the @includeResolvedCases@ and -- @includeCommunications@ parameters to specify how much information to -- return. -- -- The response returns the following in JSON format: -- -- - One or more -- -- data types. -- -- - One or more @nextToken@ values, which specify where to paginate the -- returned records represented by the @CaseDetails@ objects. -- -- Case data is available for 12 months after creation. If a case was -- created more than 12 months ago, a request might return an error. -- -- - You must have a Business, Enterprise On-Ramp, or Enterprise Support -- plan to use the Amazon Web Services Support API. -- -- - If you call the Amazon Web Services Support API from an account that -- doesn\'t have a Business, Enterprise On-Ramp, or Enterprise Support -- plan, the @SubscriptionRequiredException@ error message appears. For -- information about changing your support plan, see -- . -- -- This operation returns paginated results. module Amazonka.Support.DescribeCases ( -- * Creating a Request DescribeCases (..), newDescribeCases, -- * Request Lenses describeCases_afterTime, describeCases_beforeTime, describeCases_caseIdList, describeCases_displayId, describeCases_includeCommunications, describeCases_includeResolvedCases, describeCases_language, describeCases_maxResults, describeCases_nextToken, -- * Destructuring the Response DescribeCasesResponse (..), newDescribeCasesResponse, -- * Response Lenses describeCasesResponse_cases, describeCasesResponse_nextToken, describeCasesResponse_httpStatus, ) where 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 import Amazonka.Support.Types -- | /See:/ 'newDescribeCases' smart constructor. data DescribeCases = DescribeCases' { -- | The start date for a filtered date search on support case -- communications. Case communications are available for 12 months after -- creation. afterTime :: Prelude.Maybe Prelude.Text, -- | The end date for a filtered date search on support case communications. -- Case communications are available for 12 months after creation. beforeTime :: Prelude.Maybe Prelude.Text, -- | A list of ID numbers of the support cases you want returned. The maximum -- number of cases is 100. caseIdList :: Prelude.Maybe [Prelude.Text], -- | The ID displayed for a case in the Amazon Web Services Support Center -- user interface. displayId :: Prelude.Maybe Prelude.Text, -- | Specifies whether to include communications in the @DescribeCases@ -- response. By default, communications are included. includeCommunications :: Prelude.Maybe Prelude.Bool, -- | Specifies whether to include resolved support cases in the -- @DescribeCases@ response. By default, resolved cases aren\'t included. includeResolvedCases :: Prelude.Maybe Prelude.Bool, -- | The language in which Amazon Web Services Support handles the case. -- Amazon Web Services Support currently supports English (\"en\") and -- Japanese (\"ja\"). You must specify the ISO 639-1 code for the -- @language@ parameter if you want support in that language. language :: Prelude.Maybe Prelude.Text, -- | The maximum number of results to return before paginating. maxResults :: Prelude.Maybe Prelude.Natural, -- | A resumption point for pagination. nextToken :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeCases' 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: -- -- 'afterTime', 'describeCases_afterTime' - The start date for a filtered date search on support case -- communications. Case communications are available for 12 months after -- creation. -- -- 'beforeTime', 'describeCases_beforeTime' - The end date for a filtered date search on support case communications. -- Case communications are available for 12 months after creation. -- -- 'caseIdList', 'describeCases_caseIdList' - A list of ID numbers of the support cases you want returned. The maximum -- number of cases is 100. -- -- 'displayId', 'describeCases_displayId' - The ID displayed for a case in the Amazon Web Services Support Center -- user interface. -- -- 'includeCommunications', 'describeCases_includeCommunications' - Specifies whether to include communications in the @DescribeCases@ -- response. By default, communications are included. -- -- 'includeResolvedCases', 'describeCases_includeResolvedCases' - Specifies whether to include resolved support cases in the -- @DescribeCases@ response. By default, resolved cases aren\'t included. -- -- 'language', 'describeCases_language' - The language in which Amazon Web Services Support handles the case. -- Amazon Web Services Support currently supports English (\"en\") and -- Japanese (\"ja\"). You must specify the ISO 639-1 code for the -- @language@ parameter if you want support in that language. -- -- 'maxResults', 'describeCases_maxResults' - The maximum number of results to return before paginating. -- -- 'nextToken', 'describeCases_nextToken' - A resumption point for pagination. newDescribeCases :: DescribeCases newDescribeCases = DescribeCases' { afterTime = Prelude.Nothing, beforeTime = Prelude.Nothing, caseIdList = Prelude.Nothing, displayId = Prelude.Nothing, includeCommunications = Prelude.Nothing, includeResolvedCases = Prelude.Nothing, language = Prelude.Nothing, maxResults = Prelude.Nothing, nextToken = Prelude.Nothing } -- | The start date for a filtered date search on support case -- communications. Case communications are available for 12 months after -- creation. describeCases_afterTime :: Lens.Lens' DescribeCases (Prelude.Maybe Prelude.Text) describeCases_afterTime = Lens.lens (\DescribeCases' {afterTime} -> afterTime) (\s@DescribeCases' {} a -> s {afterTime = a} :: DescribeCases) -- | The end date for a filtered date search on support case communications. -- Case communications are available for 12 months after creation. describeCases_beforeTime :: Lens.Lens' DescribeCases (Prelude.Maybe Prelude.Text) describeCases_beforeTime = Lens.lens (\DescribeCases' {beforeTime} -> beforeTime) (\s@DescribeCases' {} a -> s {beforeTime = a} :: DescribeCases) -- | A list of ID numbers of the support cases you want returned. The maximum -- number of cases is 100. describeCases_caseIdList :: Lens.Lens' DescribeCases (Prelude.Maybe [Prelude.Text]) describeCases_caseIdList = Lens.lens (\DescribeCases' {caseIdList} -> caseIdList) (\s@DescribeCases' {} a -> s {caseIdList = a} :: DescribeCases) Prelude.. Lens.mapping Lens.coerced -- | The ID displayed for a case in the Amazon Web Services Support Center -- user interface. describeCases_displayId :: Lens.Lens' DescribeCases (Prelude.Maybe Prelude.Text) describeCases_displayId = Lens.lens (\DescribeCases' {displayId} -> displayId) (\s@DescribeCases' {} a -> s {displayId = a} :: DescribeCases) -- | Specifies whether to include communications in the @DescribeCases@ -- response. By default, communications are included. describeCases_includeCommunications :: Lens.Lens' DescribeCases (Prelude.Maybe Prelude.Bool) describeCases_includeCommunications = Lens.lens (\DescribeCases' {includeCommunications} -> includeCommunications) (\s@DescribeCases' {} a -> s {includeCommunications = a} :: DescribeCases) -- | Specifies whether to include resolved support cases in the -- @DescribeCases@ response. By default, resolved cases aren\'t included. describeCases_includeResolvedCases :: Lens.Lens' DescribeCases (Prelude.Maybe Prelude.Bool) describeCases_includeResolvedCases = Lens.lens (\DescribeCases' {includeResolvedCases} -> includeResolvedCases) (\s@DescribeCases' {} a -> s {includeResolvedCases = a} :: DescribeCases) -- | The language in which Amazon Web Services Support handles the case. -- Amazon Web Services Support currently supports English (\"en\") and -- Japanese (\"ja\"). You must specify the ISO 639-1 code for the -- @language@ parameter if you want support in that language. describeCases_language :: Lens.Lens' DescribeCases (Prelude.Maybe Prelude.Text) describeCases_language = Lens.lens (\DescribeCases' {language} -> language) (\s@DescribeCases' {} a -> s {language = a} :: DescribeCases) -- | The maximum number of results to return before paginating. describeCases_maxResults :: Lens.Lens' DescribeCases (Prelude.Maybe Prelude.Natural) describeCases_maxResults = Lens.lens (\DescribeCases' {maxResults} -> maxResults) (\s@DescribeCases' {} a -> s {maxResults = a} :: DescribeCases) -- | A resumption point for pagination. describeCases_nextToken :: Lens.Lens' DescribeCases (Prelude.Maybe Prelude.Text) describeCases_nextToken = Lens.lens (\DescribeCases' {nextToken} -> nextToken) (\s@DescribeCases' {} a -> s {nextToken = a} :: DescribeCases) instance Core.AWSPager DescribeCases where page rq rs | Core.stop ( rs Lens.^? describeCasesResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? describeCasesResponse_cases Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& describeCases_nextToken Lens..~ rs Lens.^? describeCasesResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest DescribeCases where type AWSResponse DescribeCases = DescribeCasesResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> DescribeCasesResponse' Prelude.<$> (x Data..?> "cases" Core..!@ Prelude.mempty) Prelude.<*> (x Data..?> "nextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DescribeCases where hashWithSalt _salt DescribeCases' {..} = _salt `Prelude.hashWithSalt` afterTime `Prelude.hashWithSalt` beforeTime `Prelude.hashWithSalt` caseIdList `Prelude.hashWithSalt` displayId `Prelude.hashWithSalt` includeCommunications `Prelude.hashWithSalt` includeResolvedCases `Prelude.hashWithSalt` language `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken instance Prelude.NFData DescribeCases where rnf DescribeCases' {..} = Prelude.rnf afterTime `Prelude.seq` Prelude.rnf beforeTime `Prelude.seq` Prelude.rnf caseIdList `Prelude.seq` Prelude.rnf displayId `Prelude.seq` Prelude.rnf includeCommunications `Prelude.seq` Prelude.rnf includeResolvedCases `Prelude.seq` Prelude.rnf language `Prelude.seq` Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken instance Data.ToHeaders DescribeCases where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AWSSupport_20130415.DescribeCases" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DescribeCases where toJSON DescribeCases' {..} = Data.object ( Prelude.catMaybes [ ("afterTime" Data..=) Prelude.<$> afterTime, ("beforeTime" Data..=) Prelude.<$> beforeTime, ("caseIdList" Data..=) Prelude.<$> caseIdList, ("displayId" Data..=) Prelude.<$> displayId, ("includeCommunications" Data..=) Prelude.<$> includeCommunications, ("includeResolvedCases" Data..=) Prelude.<$> includeResolvedCases, ("language" Data..=) Prelude.<$> language, ("maxResults" Data..=) Prelude.<$> maxResults, ("nextToken" Data..=) Prelude.<$> nextToken ] ) instance Data.ToPath DescribeCases where toPath = Prelude.const "/" instance Data.ToQuery DescribeCases where toQuery = Prelude.const Prelude.mempty -- | Returns an array of -- -- objects and a @nextToken@ that defines a point for pagination in the -- result set. -- -- /See:/ 'newDescribeCasesResponse' smart constructor. data DescribeCasesResponse = DescribeCasesResponse' { -- | The details for the cases that match the request. cases :: Prelude.Maybe [CaseDetails], -- | A resumption point for pagination. 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 'DescribeCasesResponse' 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: -- -- 'cases', 'describeCasesResponse_cases' - The details for the cases that match the request. -- -- 'nextToken', 'describeCasesResponse_nextToken' - A resumption point for pagination. -- -- 'httpStatus', 'describeCasesResponse_httpStatus' - The response's http status code. newDescribeCasesResponse :: -- | 'httpStatus' Prelude.Int -> DescribeCasesResponse newDescribeCasesResponse pHttpStatus_ = DescribeCasesResponse' { cases = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The details for the cases that match the request. describeCasesResponse_cases :: Lens.Lens' DescribeCasesResponse (Prelude.Maybe [CaseDetails]) describeCasesResponse_cases = Lens.lens (\DescribeCasesResponse' {cases} -> cases) (\s@DescribeCasesResponse' {} a -> s {cases = a} :: DescribeCasesResponse) Prelude.. Lens.mapping Lens.coerced -- | A resumption point for pagination. describeCasesResponse_nextToken :: Lens.Lens' DescribeCasesResponse (Prelude.Maybe Prelude.Text) describeCasesResponse_nextToken = Lens.lens (\DescribeCasesResponse' {nextToken} -> nextToken) (\s@DescribeCasesResponse' {} a -> s {nextToken = a} :: DescribeCasesResponse) -- | The response's http status code. describeCasesResponse_httpStatus :: Lens.Lens' DescribeCasesResponse Prelude.Int describeCasesResponse_httpStatus = Lens.lens (\DescribeCasesResponse' {httpStatus} -> httpStatus) (\s@DescribeCasesResponse' {} a -> s {httpStatus = a} :: DescribeCasesResponse) instance Prelude.NFData DescribeCasesResponse where rnf DescribeCasesResponse' {..} = Prelude.rnf cases `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus