{-# 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.SSM.DescribeOpsItems
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Query a set of OpsItems. You must have permission in Identity and Access
-- Management (IAM) to query a list of OpsItems. For more information, see
-- <https://docs.aws.amazon.com/systems-manager/latest/userguide/OpsCenter-getting-started.html Getting started with OpsCenter>
-- in the /Amazon Web Services Systems Manager User Guide/.
--
-- Operations engineers and IT professionals use Amazon Web Services
-- Systems Manager OpsCenter to view, investigate, and remediate
-- operational issues impacting the performance and health of their Amazon
-- Web Services resources. For more information, see
-- <https://docs.aws.amazon.com/systems-manager/latest/userguide/OpsCenter.html OpsCenter>
-- in the /Amazon Web Services Systems Manager User Guide/.
--
-- This operation returns paginated results.
module Amazonka.SSM.DescribeOpsItems
  ( -- * Creating a Request
    DescribeOpsItems (..),
    newDescribeOpsItems,

    -- * Request Lenses
    describeOpsItems_maxResults,
    describeOpsItems_nextToken,
    describeOpsItems_opsItemFilters,

    -- * Destructuring the Response
    DescribeOpsItemsResponse (..),
    newDescribeOpsItemsResponse,

    -- * Response Lenses
    describeOpsItemsResponse_nextToken,
    describeOpsItemsResponse_opsItemSummaries,
    describeOpsItemsResponse_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.SSM.Types

-- | /See:/ 'newDescribeOpsItems' smart constructor.
data DescribeOpsItems = DescribeOpsItems'
  { -- | The maximum number of items to return for this call. The call also
    -- returns a token that you can specify in a subsequent call to get the
    -- next set of results.
    DescribeOpsItems -> Maybe Natural
maxResults :: Prelude.Maybe Prelude.Natural,
    -- | A token to start the list. Use this token to get the next set of
    -- results.
    DescribeOpsItems -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | One or more filters to limit the response.
    --
    -- -   Key: CreatedTime
    --
    --     Operations: GreaterThan, LessThan
    --
    -- -   Key: LastModifiedBy
    --
    --     Operations: Contains, Equals
    --
    -- -   Key: LastModifiedTime
    --
    --     Operations: GreaterThan, LessThan
    --
    -- -   Key: Priority
    --
    --     Operations: Equals
    --
    -- -   Key: Source
    --
    --     Operations: Contains, Equals
    --
    -- -   Key: Status
    --
    --     Operations: Equals
    --
    -- -   Key: Title*
    --
    --     Operations: Equals,Contains
    --
    -- -   Key: OperationalData**
    --
    --     Operations: Equals
    --
    -- -   Key: OperationalDataKey
    --
    --     Operations: Equals
    --
    -- -   Key: OperationalDataValue
    --
    --     Operations: Equals, Contains
    --
    -- -   Key: OpsItemId
    --
    --     Operations: Equals
    --
    -- -   Key: ResourceId
    --
    --     Operations: Contains
    --
    -- -   Key: AutomationId
    --
    --     Operations: Equals
    --
    -- *The Equals operator for Title matches the first 100 characters. If you
    -- specify more than 100 characters, they system returns an error that the
    -- filter value exceeds the length limit.
    --
    -- **If you filter the response by using the OperationalData operator,
    -- specify a key-value pair by using the following JSON format:
    -- {\"key\":\"key_name\",\"value\":\"a_value\"}
    DescribeOpsItems -> Maybe [OpsItemFilter]
opsItemFilters :: Prelude.Maybe [OpsItemFilter]
  }
  deriving (DescribeOpsItems -> DescribeOpsItems -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeOpsItems -> DescribeOpsItems -> Bool
$c/= :: DescribeOpsItems -> DescribeOpsItems -> Bool
== :: DescribeOpsItems -> DescribeOpsItems -> Bool
$c== :: DescribeOpsItems -> DescribeOpsItems -> Bool
Prelude.Eq, ReadPrec [DescribeOpsItems]
ReadPrec DescribeOpsItems
Int -> ReadS DescribeOpsItems
ReadS [DescribeOpsItems]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeOpsItems]
$creadListPrec :: ReadPrec [DescribeOpsItems]
readPrec :: ReadPrec DescribeOpsItems
$creadPrec :: ReadPrec DescribeOpsItems
readList :: ReadS [DescribeOpsItems]
$creadList :: ReadS [DescribeOpsItems]
readsPrec :: Int -> ReadS DescribeOpsItems
$creadsPrec :: Int -> ReadS DescribeOpsItems
Prelude.Read, Int -> DescribeOpsItems -> ShowS
[DescribeOpsItems] -> ShowS
DescribeOpsItems -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeOpsItems] -> ShowS
$cshowList :: [DescribeOpsItems] -> ShowS
show :: DescribeOpsItems -> String
$cshow :: DescribeOpsItems -> String
showsPrec :: Int -> DescribeOpsItems -> ShowS
$cshowsPrec :: Int -> DescribeOpsItems -> ShowS
Prelude.Show, forall x. Rep DescribeOpsItems x -> DescribeOpsItems
forall x. DescribeOpsItems -> Rep DescribeOpsItems x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DescribeOpsItems x -> DescribeOpsItems
$cfrom :: forall x. DescribeOpsItems -> Rep DescribeOpsItems x
Prelude.Generic)

-- |
-- Create a value of 'DescribeOpsItems' 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:
--
-- 'maxResults', 'describeOpsItems_maxResults' - The maximum number of items to return for this call. The call also
-- returns a token that you can specify in a subsequent call to get the
-- next set of results.
--
-- 'nextToken', 'describeOpsItems_nextToken' - A token to start the list. Use this token to get the next set of
-- results.
--
-- 'opsItemFilters', 'describeOpsItems_opsItemFilters' - One or more filters to limit the response.
--
-- -   Key: CreatedTime
--
--     Operations: GreaterThan, LessThan
--
-- -   Key: LastModifiedBy
--
--     Operations: Contains, Equals
--
-- -   Key: LastModifiedTime
--
--     Operations: GreaterThan, LessThan
--
-- -   Key: Priority
--
--     Operations: Equals
--
-- -   Key: Source
--
--     Operations: Contains, Equals
--
-- -   Key: Status
--
--     Operations: Equals
--
-- -   Key: Title*
--
--     Operations: Equals,Contains
--
-- -   Key: OperationalData**
--
--     Operations: Equals
--
-- -   Key: OperationalDataKey
--
--     Operations: Equals
--
-- -   Key: OperationalDataValue
--
--     Operations: Equals, Contains
--
-- -   Key: OpsItemId
--
--     Operations: Equals
--
-- -   Key: ResourceId
--
--     Operations: Contains
--
-- -   Key: AutomationId
--
--     Operations: Equals
--
-- *The Equals operator for Title matches the first 100 characters. If you
-- specify more than 100 characters, they system returns an error that the
-- filter value exceeds the length limit.
--
-- **If you filter the response by using the OperationalData operator,
-- specify a key-value pair by using the following JSON format:
-- {\"key\":\"key_name\",\"value\":\"a_value\"}
newDescribeOpsItems ::
  DescribeOpsItems
newDescribeOpsItems :: DescribeOpsItems
newDescribeOpsItems =
  DescribeOpsItems'
    { $sel:maxResults:DescribeOpsItems' :: Maybe Natural
maxResults = forall a. Maybe a
Prelude.Nothing,
      $sel:nextToken:DescribeOpsItems' :: Maybe Text
nextToken = forall a. Maybe a
Prelude.Nothing,
      $sel:opsItemFilters:DescribeOpsItems' :: Maybe [OpsItemFilter]
opsItemFilters = forall a. Maybe a
Prelude.Nothing
    }

-- | The maximum number of items to return for this call. The call also
-- returns a token that you can specify in a subsequent call to get the
-- next set of results.
describeOpsItems_maxResults :: Lens.Lens' DescribeOpsItems (Prelude.Maybe Prelude.Natural)
describeOpsItems_maxResults :: Lens' DescribeOpsItems (Maybe Natural)
describeOpsItems_maxResults = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeOpsItems' {Maybe Natural
maxResults :: Maybe Natural
$sel:maxResults:DescribeOpsItems' :: DescribeOpsItems -> Maybe Natural
maxResults} -> Maybe Natural
maxResults) (\s :: DescribeOpsItems
s@DescribeOpsItems' {} Maybe Natural
a -> DescribeOpsItems
s {$sel:maxResults:DescribeOpsItems' :: Maybe Natural
maxResults = Maybe Natural
a} :: DescribeOpsItems)

-- | A token to start the list. Use this token to get the next set of
-- results.
describeOpsItems_nextToken :: Lens.Lens' DescribeOpsItems (Prelude.Maybe Prelude.Text)
describeOpsItems_nextToken :: Lens' DescribeOpsItems (Maybe Text)
describeOpsItems_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeOpsItems' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:DescribeOpsItems' :: DescribeOpsItems -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: DescribeOpsItems
s@DescribeOpsItems' {} Maybe Text
a -> DescribeOpsItems
s {$sel:nextToken:DescribeOpsItems' :: Maybe Text
nextToken = Maybe Text
a} :: DescribeOpsItems)

-- | One or more filters to limit the response.
--
-- -   Key: CreatedTime
--
--     Operations: GreaterThan, LessThan
--
-- -   Key: LastModifiedBy
--
--     Operations: Contains, Equals
--
-- -   Key: LastModifiedTime
--
--     Operations: GreaterThan, LessThan
--
-- -   Key: Priority
--
--     Operations: Equals
--
-- -   Key: Source
--
--     Operations: Contains, Equals
--
-- -   Key: Status
--
--     Operations: Equals
--
-- -   Key: Title*
--
--     Operations: Equals,Contains
--
-- -   Key: OperationalData**
--
--     Operations: Equals
--
-- -   Key: OperationalDataKey
--
--     Operations: Equals
--
-- -   Key: OperationalDataValue
--
--     Operations: Equals, Contains
--
-- -   Key: OpsItemId
--
--     Operations: Equals
--
-- -   Key: ResourceId
--
--     Operations: Contains
--
-- -   Key: AutomationId
--
--     Operations: Equals
--
-- *The Equals operator for Title matches the first 100 characters. If you
-- specify more than 100 characters, they system returns an error that the
-- filter value exceeds the length limit.
--
-- **If you filter the response by using the OperationalData operator,
-- specify a key-value pair by using the following JSON format:
-- {\"key\":\"key_name\",\"value\":\"a_value\"}
describeOpsItems_opsItemFilters :: Lens.Lens' DescribeOpsItems (Prelude.Maybe [OpsItemFilter])
describeOpsItems_opsItemFilters :: Lens' DescribeOpsItems (Maybe [OpsItemFilter])
describeOpsItems_opsItemFilters = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeOpsItems' {Maybe [OpsItemFilter]
opsItemFilters :: Maybe [OpsItemFilter]
$sel:opsItemFilters:DescribeOpsItems' :: DescribeOpsItems -> Maybe [OpsItemFilter]
opsItemFilters} -> Maybe [OpsItemFilter]
opsItemFilters) (\s :: DescribeOpsItems
s@DescribeOpsItems' {} Maybe [OpsItemFilter]
a -> DescribeOpsItems
s {$sel:opsItemFilters:DescribeOpsItems' :: Maybe [OpsItemFilter]
opsItemFilters = Maybe [OpsItemFilter]
a} :: DescribeOpsItems) 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 s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced

instance Core.AWSPager DescribeOpsItems where
  page :: DescribeOpsItems
-> AWSResponse DescribeOpsItems -> Maybe DescribeOpsItems
page DescribeOpsItems
rq AWSResponse DescribeOpsItems
rs
    | forall a. AWSTruncated a => a -> Bool
Core.stop
        ( AWSResponse DescribeOpsItems
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' DescribeOpsItemsResponse (Maybe Text)
describeOpsItemsResponse_nextToken
            forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall a b. Prism (Maybe a) (Maybe b) a b
Lens._Just
        ) =
        forall a. Maybe a
Prelude.Nothing
    | forall a. AWSTruncated a => a -> Bool
Core.stop
        ( AWSResponse DescribeOpsItems
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' DescribeOpsItemsResponse (Maybe [OpsItemSummary])
describeOpsItemsResponse_opsItemSummaries
            forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall a b. Prism (Maybe a) (Maybe b) a b
Lens._Just
        ) =
        forall a. Maybe a
Prelude.Nothing
    | Bool
Prelude.otherwise =
        forall a. a -> Maybe a
Prelude.Just
          forall a b. (a -> b) -> a -> b
Prelude.$ DescribeOpsItems
rq
          forall a b. a -> (a -> b) -> b
Prelude.& Lens' DescribeOpsItems (Maybe Text)
describeOpsItems_nextToken
          forall s t a b. ASetter s t a b -> b -> s -> t
Lens..~ AWSResponse DescribeOpsItems
rs
          forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' DescribeOpsItemsResponse (Maybe Text)
describeOpsItemsResponse_nextToken
          forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall a b. Prism (Maybe a) (Maybe b) a b
Lens._Just

instance Core.AWSRequest DescribeOpsItems where
  type
    AWSResponse DescribeOpsItems =
      DescribeOpsItemsResponse
  request :: (Service -> Service)
-> DescribeOpsItems -> Request DescribeOpsItems
request Service -> Service
overrides =
    forall a. (ToRequest a, ToJSON a) => Service -> a -> Request a
Request.postJSON (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy DescribeOpsItems
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse DescribeOpsItems)))
response =
    forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> Object -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveJSON
      ( \Int
s ResponseHeaders
h Object
x ->
          Maybe Text
-> Maybe [OpsItemSummary] -> Int -> DescribeOpsItemsResponse
DescribeOpsItemsResponse'
            forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"NextToken")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> ( Object
x
                            forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"OpsItemSummaries"
                            forall (f :: * -> *) a. Functor f => f (Maybe a) -> a -> f a
Core..!@ forall a. Monoid a => a
Prelude.mempty
                        )
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (forall (f :: * -> *) a. Applicative f => a -> f a
Prelude.pure (forall a. Enum a => a -> Int
Prelude.fromEnum Int
s))
      )

instance Prelude.Hashable DescribeOpsItems where
  hashWithSalt :: Int -> DescribeOpsItems -> Int
hashWithSalt Int
_salt DescribeOpsItems' {Maybe Natural
Maybe [OpsItemFilter]
Maybe Text
opsItemFilters :: Maybe [OpsItemFilter]
nextToken :: Maybe Text
maxResults :: Maybe Natural
$sel:opsItemFilters:DescribeOpsItems' :: DescribeOpsItems -> Maybe [OpsItemFilter]
$sel:nextToken:DescribeOpsItems' :: DescribeOpsItems -> Maybe Text
$sel:maxResults:DescribeOpsItems' :: DescribeOpsItems -> Maybe Natural
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Natural
maxResults
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
nextToken
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [OpsItemFilter]
opsItemFilters

instance Prelude.NFData DescribeOpsItems where
  rnf :: DescribeOpsItems -> ()
rnf DescribeOpsItems' {Maybe Natural
Maybe [OpsItemFilter]
Maybe Text
opsItemFilters :: Maybe [OpsItemFilter]
nextToken :: Maybe Text
maxResults :: Maybe Natural
$sel:opsItemFilters:DescribeOpsItems' :: DescribeOpsItems -> Maybe [OpsItemFilter]
$sel:nextToken:DescribeOpsItems' :: DescribeOpsItems -> Maybe Text
$sel:maxResults:DescribeOpsItems' :: DescribeOpsItems -> Maybe Natural
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Natural
maxResults
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
nextToken
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe [OpsItemFilter]
opsItemFilters

instance Data.ToHeaders DescribeOpsItems where
  toHeaders :: DescribeOpsItems -> ResponseHeaders
toHeaders =
    forall a b. a -> b -> a
Prelude.const
      ( forall a. Monoid a => [a] -> a
Prelude.mconcat
          [ HeaderName
"X-Amz-Target"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# (ByteString
"AmazonSSM.DescribeOpsItems" :: Prelude.ByteString),
            HeaderName
"Content-Type"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
                          Prelude.ByteString
                      )
          ]
      )

instance Data.ToJSON DescribeOpsItems where
  toJSON :: DescribeOpsItems -> Value
toJSON DescribeOpsItems' {Maybe Natural
Maybe [OpsItemFilter]
Maybe Text
opsItemFilters :: Maybe [OpsItemFilter]
nextToken :: Maybe Text
maxResults :: Maybe Natural
$sel:opsItemFilters:DescribeOpsItems' :: DescribeOpsItems -> Maybe [OpsItemFilter]
$sel:nextToken:DescribeOpsItems' :: DescribeOpsItems -> Maybe Text
$sel:maxResults:DescribeOpsItems' :: DescribeOpsItems -> Maybe Natural
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [ (Key
"MaxResults" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe Natural
maxResults,
            (Key
"NextToken" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe Text
nextToken,
            (Key
"OpsItemFilters" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=)
              forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe [OpsItemFilter]
opsItemFilters
          ]
      )

instance Data.ToPath DescribeOpsItems where
  toPath :: DescribeOpsItems -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"

instance Data.ToQuery DescribeOpsItems where
  toQuery :: DescribeOpsItems -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

-- | /See:/ 'newDescribeOpsItemsResponse' smart constructor.
data DescribeOpsItemsResponse = DescribeOpsItemsResponse'
  { -- | The token for the next set of items to return. Use this token to get the
    -- next set of results.
    DescribeOpsItemsResponse -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | A list of OpsItems.
    DescribeOpsItemsResponse -> Maybe [OpsItemSummary]
opsItemSummaries :: Prelude.Maybe [OpsItemSummary],
    -- | The response's http status code.
    DescribeOpsItemsResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (DescribeOpsItemsResponse -> DescribeOpsItemsResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeOpsItemsResponse -> DescribeOpsItemsResponse -> Bool
$c/= :: DescribeOpsItemsResponse -> DescribeOpsItemsResponse -> Bool
== :: DescribeOpsItemsResponse -> DescribeOpsItemsResponse -> Bool
$c== :: DescribeOpsItemsResponse -> DescribeOpsItemsResponse -> Bool
Prelude.Eq, ReadPrec [DescribeOpsItemsResponse]
ReadPrec DescribeOpsItemsResponse
Int -> ReadS DescribeOpsItemsResponse
ReadS [DescribeOpsItemsResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeOpsItemsResponse]
$creadListPrec :: ReadPrec [DescribeOpsItemsResponse]
readPrec :: ReadPrec DescribeOpsItemsResponse
$creadPrec :: ReadPrec DescribeOpsItemsResponse
readList :: ReadS [DescribeOpsItemsResponse]
$creadList :: ReadS [DescribeOpsItemsResponse]
readsPrec :: Int -> ReadS DescribeOpsItemsResponse
$creadsPrec :: Int -> ReadS DescribeOpsItemsResponse
Prelude.Read, Int -> DescribeOpsItemsResponse -> ShowS
[DescribeOpsItemsResponse] -> ShowS
DescribeOpsItemsResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeOpsItemsResponse] -> ShowS
$cshowList :: [DescribeOpsItemsResponse] -> ShowS
show :: DescribeOpsItemsResponse -> String
$cshow :: DescribeOpsItemsResponse -> String
showsPrec :: Int -> DescribeOpsItemsResponse -> ShowS
$cshowsPrec :: Int -> DescribeOpsItemsResponse -> ShowS
Prelude.Show, forall x.
Rep DescribeOpsItemsResponse x -> DescribeOpsItemsResponse
forall x.
DescribeOpsItemsResponse -> Rep DescribeOpsItemsResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeOpsItemsResponse x -> DescribeOpsItemsResponse
$cfrom :: forall x.
DescribeOpsItemsResponse -> Rep DescribeOpsItemsResponse x
Prelude.Generic)

-- |
-- Create a value of 'DescribeOpsItemsResponse' 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:
--
-- 'nextToken', 'describeOpsItemsResponse_nextToken' - The token for the next set of items to return. Use this token to get the
-- next set of results.
--
-- 'opsItemSummaries', 'describeOpsItemsResponse_opsItemSummaries' - A list of OpsItems.
--
-- 'httpStatus', 'describeOpsItemsResponse_httpStatus' - The response's http status code.
newDescribeOpsItemsResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DescribeOpsItemsResponse
newDescribeOpsItemsResponse :: Int -> DescribeOpsItemsResponse
newDescribeOpsItemsResponse Int
pHttpStatus_ =
  DescribeOpsItemsResponse'
    { $sel:nextToken:DescribeOpsItemsResponse' :: Maybe Text
nextToken =
        forall a. Maybe a
Prelude.Nothing,
      $sel:opsItemSummaries:DescribeOpsItemsResponse' :: Maybe [OpsItemSummary]
opsItemSummaries = forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:DescribeOpsItemsResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | The token for the next set of items to return. Use this token to get the
-- next set of results.
describeOpsItemsResponse_nextToken :: Lens.Lens' DescribeOpsItemsResponse (Prelude.Maybe Prelude.Text)
describeOpsItemsResponse_nextToken :: Lens' DescribeOpsItemsResponse (Maybe Text)
describeOpsItemsResponse_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeOpsItemsResponse' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:DescribeOpsItemsResponse' :: DescribeOpsItemsResponse -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: DescribeOpsItemsResponse
s@DescribeOpsItemsResponse' {} Maybe Text
a -> DescribeOpsItemsResponse
s {$sel:nextToken:DescribeOpsItemsResponse' :: Maybe Text
nextToken = Maybe Text
a} :: DescribeOpsItemsResponse)

-- | A list of OpsItems.
describeOpsItemsResponse_opsItemSummaries :: Lens.Lens' DescribeOpsItemsResponse (Prelude.Maybe [OpsItemSummary])
describeOpsItemsResponse_opsItemSummaries :: Lens' DescribeOpsItemsResponse (Maybe [OpsItemSummary])
describeOpsItemsResponse_opsItemSummaries = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeOpsItemsResponse' {Maybe [OpsItemSummary]
opsItemSummaries :: Maybe [OpsItemSummary]
$sel:opsItemSummaries:DescribeOpsItemsResponse' :: DescribeOpsItemsResponse -> Maybe [OpsItemSummary]
opsItemSummaries} -> Maybe [OpsItemSummary]
opsItemSummaries) (\s :: DescribeOpsItemsResponse
s@DescribeOpsItemsResponse' {} Maybe [OpsItemSummary]
a -> DescribeOpsItemsResponse
s {$sel:opsItemSummaries:DescribeOpsItemsResponse' :: Maybe [OpsItemSummary]
opsItemSummaries = Maybe [OpsItemSummary]
a} :: DescribeOpsItemsResponse) 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 s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced

-- | The response's http status code.
describeOpsItemsResponse_httpStatus :: Lens.Lens' DescribeOpsItemsResponse Prelude.Int
describeOpsItemsResponse_httpStatus :: Lens' DescribeOpsItemsResponse Int
describeOpsItemsResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeOpsItemsResponse' {Int
httpStatus :: Int
$sel:httpStatus:DescribeOpsItemsResponse' :: DescribeOpsItemsResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DescribeOpsItemsResponse
s@DescribeOpsItemsResponse' {} Int
a -> DescribeOpsItemsResponse
s {$sel:httpStatus:DescribeOpsItemsResponse' :: Int
httpStatus = Int
a} :: DescribeOpsItemsResponse)

instance Prelude.NFData DescribeOpsItemsResponse where
  rnf :: DescribeOpsItemsResponse -> ()
rnf DescribeOpsItemsResponse' {Int
Maybe [OpsItemSummary]
Maybe Text
httpStatus :: Int
opsItemSummaries :: Maybe [OpsItemSummary]
nextToken :: Maybe Text
$sel:httpStatus:DescribeOpsItemsResponse' :: DescribeOpsItemsResponse -> Int
$sel:opsItemSummaries:DescribeOpsItemsResponse' :: DescribeOpsItemsResponse -> Maybe [OpsItemSummary]
$sel:nextToken:DescribeOpsItemsResponse' :: DescribeOpsItemsResponse -> Maybe Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
nextToken
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe [OpsItemSummary]
opsItemSummaries
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus