{-# 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.EC2.DescribeConversionTasks
-- 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 the specified conversion tasks or all your conversion tasks.
-- For more information, see the
-- <https://docs.aws.amazon.com/vm-import/latest/userguide/ VM Import\/Export User Guide>.
--
-- For information about the import manifest referenced by this API action,
-- see
-- <https://docs.aws.amazon.com/AWSEC2/latest/APIReference/manifest.html VM Import Manifest>.
module Amazonka.EC2.DescribeConversionTasks
  ( -- * Creating a Request
    DescribeConversionTasks (..),
    newDescribeConversionTasks,

    -- * Request Lenses
    describeConversionTasks_conversionTaskIds,
    describeConversionTasks_dryRun,

    -- * Destructuring the Response
    DescribeConversionTasksResponse (..),
    newDescribeConversionTasksResponse,

    -- * Response Lenses
    describeConversionTasksResponse_conversionTasks,
    describeConversionTasksResponse_httpStatus,
  )
where

import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.EC2.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response

-- | /See:/ 'newDescribeConversionTasks' smart constructor.
data DescribeConversionTasks = DescribeConversionTasks'
  { -- | The conversion task IDs.
    DescribeConversionTasks -> Maybe [Text]
conversionTaskIds :: Prelude.Maybe [Prelude.Text],
    -- | Checks whether you have the required permissions for the action, without
    -- actually making the request, and provides an error response. If you have
    -- the required permissions, the error response is @DryRunOperation@.
    -- Otherwise, it is @UnauthorizedOperation@.
    DescribeConversionTasks -> Maybe Bool
dryRun :: Prelude.Maybe Prelude.Bool
  }
  deriving (DescribeConversionTasks -> DescribeConversionTasks -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeConversionTasks -> DescribeConversionTasks -> Bool
$c/= :: DescribeConversionTasks -> DescribeConversionTasks -> Bool
== :: DescribeConversionTasks -> DescribeConversionTasks -> Bool
$c== :: DescribeConversionTasks -> DescribeConversionTasks -> Bool
Prelude.Eq, ReadPrec [DescribeConversionTasks]
ReadPrec DescribeConversionTasks
Int -> ReadS DescribeConversionTasks
ReadS [DescribeConversionTasks]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeConversionTasks]
$creadListPrec :: ReadPrec [DescribeConversionTasks]
readPrec :: ReadPrec DescribeConversionTasks
$creadPrec :: ReadPrec DescribeConversionTasks
readList :: ReadS [DescribeConversionTasks]
$creadList :: ReadS [DescribeConversionTasks]
readsPrec :: Int -> ReadS DescribeConversionTasks
$creadsPrec :: Int -> ReadS DescribeConversionTasks
Prelude.Read, Int -> DescribeConversionTasks -> ShowS
[DescribeConversionTasks] -> ShowS
DescribeConversionTasks -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeConversionTasks] -> ShowS
$cshowList :: [DescribeConversionTasks] -> ShowS
show :: DescribeConversionTasks -> String
$cshow :: DescribeConversionTasks -> String
showsPrec :: Int -> DescribeConversionTasks -> ShowS
$cshowsPrec :: Int -> DescribeConversionTasks -> ShowS
Prelude.Show, forall x. Rep DescribeConversionTasks x -> DescribeConversionTasks
forall x. DescribeConversionTasks -> Rep DescribeConversionTasks x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DescribeConversionTasks x -> DescribeConversionTasks
$cfrom :: forall x. DescribeConversionTasks -> Rep DescribeConversionTasks x
Prelude.Generic)

-- |
-- Create a value of 'DescribeConversionTasks' 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:
--
-- 'conversionTaskIds', 'describeConversionTasks_conversionTaskIds' - The conversion task IDs.
--
-- 'dryRun', 'describeConversionTasks_dryRun' - Checks whether you have the required permissions for the action, without
-- actually making the request, and provides an error response. If you have
-- the required permissions, the error response is @DryRunOperation@.
-- Otherwise, it is @UnauthorizedOperation@.
newDescribeConversionTasks ::
  DescribeConversionTasks
newDescribeConversionTasks :: DescribeConversionTasks
newDescribeConversionTasks =
  DescribeConversionTasks'
    { $sel:conversionTaskIds:DescribeConversionTasks' :: Maybe [Text]
conversionTaskIds =
        forall a. Maybe a
Prelude.Nothing,
      $sel:dryRun:DescribeConversionTasks' :: Maybe Bool
dryRun = forall a. Maybe a
Prelude.Nothing
    }

-- | The conversion task IDs.
describeConversionTasks_conversionTaskIds :: Lens.Lens' DescribeConversionTasks (Prelude.Maybe [Prelude.Text])
describeConversionTasks_conversionTaskIds :: Lens' DescribeConversionTasks (Maybe [Text])
describeConversionTasks_conversionTaskIds = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeConversionTasks' {Maybe [Text]
conversionTaskIds :: Maybe [Text]
$sel:conversionTaskIds:DescribeConversionTasks' :: DescribeConversionTasks -> Maybe [Text]
conversionTaskIds} -> Maybe [Text]
conversionTaskIds) (\s :: DescribeConversionTasks
s@DescribeConversionTasks' {} Maybe [Text]
a -> DescribeConversionTasks
s {$sel:conversionTaskIds:DescribeConversionTasks' :: Maybe [Text]
conversionTaskIds = Maybe [Text]
a} :: DescribeConversionTasks) 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

-- | Checks whether you have the required permissions for the action, without
-- actually making the request, and provides an error response. If you have
-- the required permissions, the error response is @DryRunOperation@.
-- Otherwise, it is @UnauthorizedOperation@.
describeConversionTasks_dryRun :: Lens.Lens' DescribeConversionTasks (Prelude.Maybe Prelude.Bool)
describeConversionTasks_dryRun :: Lens' DescribeConversionTasks (Maybe Bool)
describeConversionTasks_dryRun = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeConversionTasks' {Maybe Bool
dryRun :: Maybe Bool
$sel:dryRun:DescribeConversionTasks' :: DescribeConversionTasks -> Maybe Bool
dryRun} -> Maybe Bool
dryRun) (\s :: DescribeConversionTasks
s@DescribeConversionTasks' {} Maybe Bool
a -> DescribeConversionTasks
s {$sel:dryRun:DescribeConversionTasks' :: Maybe Bool
dryRun = Maybe Bool
a} :: DescribeConversionTasks)

instance Core.AWSRequest DescribeConversionTasks where
  type
    AWSResponse DescribeConversionTasks =
      DescribeConversionTasksResponse
  request :: (Service -> Service)
-> DescribeConversionTasks -> Request DescribeConversionTasks
request Service -> Service
overrides =
    forall a. ToRequest a => Service -> a -> Request a
Request.postQuery (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy DescribeConversionTasks
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse DescribeConversionTasks)))
response =
    forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> [Node] -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveXML
      ( \Int
s ResponseHeaders
h [Node]
x ->
          Maybe [ConversionTask] -> Int -> DescribeConversionTasksResponse
DescribeConversionTasksResponse'
            forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> ( [Node]
x
                            forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"conversionTasks"
                            forall (f :: * -> *) a. Functor f => f (Maybe a) -> a -> f a
Core..!@ forall a. Monoid a => a
Prelude.mempty
                            forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
Prelude.>>= forall (f :: * -> *) a b.
Applicative f =>
([a] -> f b) -> [a] -> f (Maybe b)
Core.may (forall a. FromXML a => Text -> [Node] -> Either String [a]
Data.parseXMLList Text
"item")
                        )
            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 DescribeConversionTasks where
  hashWithSalt :: Int -> DescribeConversionTasks -> Int
hashWithSalt Int
_salt DescribeConversionTasks' {Maybe Bool
Maybe [Text]
dryRun :: Maybe Bool
conversionTaskIds :: Maybe [Text]
$sel:dryRun:DescribeConversionTasks' :: DescribeConversionTasks -> Maybe Bool
$sel:conversionTaskIds:DescribeConversionTasks' :: DescribeConversionTasks -> Maybe [Text]
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [Text]
conversionTaskIds
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Bool
dryRun

instance Prelude.NFData DescribeConversionTasks where
  rnf :: DescribeConversionTasks -> ()
rnf DescribeConversionTasks' {Maybe Bool
Maybe [Text]
dryRun :: Maybe Bool
conversionTaskIds :: Maybe [Text]
$sel:dryRun:DescribeConversionTasks' :: DescribeConversionTasks -> Maybe Bool
$sel:conversionTaskIds:DescribeConversionTasks' :: DescribeConversionTasks -> Maybe [Text]
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe [Text]
conversionTaskIds
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Bool
dryRun

instance Data.ToHeaders DescribeConversionTasks where
  toHeaders :: DescribeConversionTasks -> ResponseHeaders
toHeaders = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

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

instance Data.ToQuery DescribeConversionTasks where
  toQuery :: DescribeConversionTasks -> QueryString
toQuery DescribeConversionTasks' {Maybe Bool
Maybe [Text]
dryRun :: Maybe Bool
conversionTaskIds :: Maybe [Text]
$sel:dryRun:DescribeConversionTasks' :: DescribeConversionTasks -> Maybe Bool
$sel:conversionTaskIds:DescribeConversionTasks' :: DescribeConversionTasks -> Maybe [Text]
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"Action"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"DescribeConversionTasks" :: Prelude.ByteString),
        ByteString
"Version"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"2016-11-15" :: Prelude.ByteString),
        forall a. ToQuery a => a -> QueryString
Data.toQuery
          ( forall a.
(IsList a, ToQuery (Item a)) =>
ByteString -> a -> QueryString
Data.toQueryList ByteString
"ConversionTaskId"
              forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe [Text]
conversionTaskIds
          ),
        ByteString
"DryRun" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Bool
dryRun
      ]

-- | /See:/ 'newDescribeConversionTasksResponse' smart constructor.
data DescribeConversionTasksResponse = DescribeConversionTasksResponse'
  { -- | Information about the conversion tasks.
    DescribeConversionTasksResponse -> Maybe [ConversionTask]
conversionTasks :: Prelude.Maybe [ConversionTask],
    -- | The response's http status code.
    DescribeConversionTasksResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (DescribeConversionTasksResponse
-> DescribeConversionTasksResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeConversionTasksResponse
-> DescribeConversionTasksResponse -> Bool
$c/= :: DescribeConversionTasksResponse
-> DescribeConversionTasksResponse -> Bool
== :: DescribeConversionTasksResponse
-> DescribeConversionTasksResponse -> Bool
$c== :: DescribeConversionTasksResponse
-> DescribeConversionTasksResponse -> Bool
Prelude.Eq, ReadPrec [DescribeConversionTasksResponse]
ReadPrec DescribeConversionTasksResponse
Int -> ReadS DescribeConversionTasksResponse
ReadS [DescribeConversionTasksResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeConversionTasksResponse]
$creadListPrec :: ReadPrec [DescribeConversionTasksResponse]
readPrec :: ReadPrec DescribeConversionTasksResponse
$creadPrec :: ReadPrec DescribeConversionTasksResponse
readList :: ReadS [DescribeConversionTasksResponse]
$creadList :: ReadS [DescribeConversionTasksResponse]
readsPrec :: Int -> ReadS DescribeConversionTasksResponse
$creadsPrec :: Int -> ReadS DescribeConversionTasksResponse
Prelude.Read, Int -> DescribeConversionTasksResponse -> ShowS
[DescribeConversionTasksResponse] -> ShowS
DescribeConversionTasksResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeConversionTasksResponse] -> ShowS
$cshowList :: [DescribeConversionTasksResponse] -> ShowS
show :: DescribeConversionTasksResponse -> String
$cshow :: DescribeConversionTasksResponse -> String
showsPrec :: Int -> DescribeConversionTasksResponse -> ShowS
$cshowsPrec :: Int -> DescribeConversionTasksResponse -> ShowS
Prelude.Show, forall x.
Rep DescribeConversionTasksResponse x
-> DescribeConversionTasksResponse
forall x.
DescribeConversionTasksResponse
-> Rep DescribeConversionTasksResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeConversionTasksResponse x
-> DescribeConversionTasksResponse
$cfrom :: forall x.
DescribeConversionTasksResponse
-> Rep DescribeConversionTasksResponse x
Prelude.Generic)

-- |
-- Create a value of 'DescribeConversionTasksResponse' 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:
--
-- 'conversionTasks', 'describeConversionTasksResponse_conversionTasks' - Information about the conversion tasks.
--
-- 'httpStatus', 'describeConversionTasksResponse_httpStatus' - The response's http status code.
newDescribeConversionTasksResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DescribeConversionTasksResponse
newDescribeConversionTasksResponse :: Int -> DescribeConversionTasksResponse
newDescribeConversionTasksResponse Int
pHttpStatus_ =
  DescribeConversionTasksResponse'
    { $sel:conversionTasks:DescribeConversionTasksResponse' :: Maybe [ConversionTask]
conversionTasks =
        forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:DescribeConversionTasksResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | Information about the conversion tasks.
describeConversionTasksResponse_conversionTasks :: Lens.Lens' DescribeConversionTasksResponse (Prelude.Maybe [ConversionTask])
describeConversionTasksResponse_conversionTasks :: Lens' DescribeConversionTasksResponse (Maybe [ConversionTask])
describeConversionTasksResponse_conversionTasks = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeConversionTasksResponse' {Maybe [ConversionTask]
conversionTasks :: Maybe [ConversionTask]
$sel:conversionTasks:DescribeConversionTasksResponse' :: DescribeConversionTasksResponse -> Maybe [ConversionTask]
conversionTasks} -> Maybe [ConversionTask]
conversionTasks) (\s :: DescribeConversionTasksResponse
s@DescribeConversionTasksResponse' {} Maybe [ConversionTask]
a -> DescribeConversionTasksResponse
s {$sel:conversionTasks:DescribeConversionTasksResponse' :: Maybe [ConversionTask]
conversionTasks = Maybe [ConversionTask]
a} :: DescribeConversionTasksResponse) 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.
describeConversionTasksResponse_httpStatus :: Lens.Lens' DescribeConversionTasksResponse Prelude.Int
describeConversionTasksResponse_httpStatus :: Lens' DescribeConversionTasksResponse Int
describeConversionTasksResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeConversionTasksResponse' {Int
httpStatus :: Int
$sel:httpStatus:DescribeConversionTasksResponse' :: DescribeConversionTasksResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DescribeConversionTasksResponse
s@DescribeConversionTasksResponse' {} Int
a -> DescribeConversionTasksResponse
s {$sel:httpStatus:DescribeConversionTasksResponse' :: Int
httpStatus = Int
a} :: DescribeConversionTasksResponse)

instance
  Prelude.NFData
    DescribeConversionTasksResponse
  where
  rnf :: DescribeConversionTasksResponse -> ()
rnf DescribeConversionTasksResponse' {Int
Maybe [ConversionTask]
httpStatus :: Int
conversionTasks :: Maybe [ConversionTask]
$sel:httpStatus:DescribeConversionTasksResponse' :: DescribeConversionTasksResponse -> Int
$sel:conversionTasks:DescribeConversionTasksResponse' :: DescribeConversionTasksResponse -> Maybe [ConversionTask]
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe [ConversionTask]
conversionTasks
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus