{-# 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.M2.GetDataSetImportTask
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Gets the status of a data set import task initiated with the
-- CreateDataSetImportTask operation.
module Amazonka.M2.GetDataSetImportTask
  ( -- * Creating a Request
    GetDataSetImportTask (..),
    newGetDataSetImportTask,

    -- * Request Lenses
    getDataSetImportTask_applicationId,
    getDataSetImportTask_taskId,

    -- * Destructuring the Response
    GetDataSetImportTaskResponse (..),
    newGetDataSetImportTaskResponse,

    -- * Response Lenses
    getDataSetImportTaskResponse_summary,
    getDataSetImportTaskResponse_httpStatus,
    getDataSetImportTaskResponse_status,
    getDataSetImportTaskResponse_taskId,
  )
where

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

-- | /See:/ 'newGetDataSetImportTask' smart constructor.
data GetDataSetImportTask = GetDataSetImportTask'
  { -- | The application identifier.
    GetDataSetImportTask -> Text
applicationId :: Prelude.Text,
    -- | The task identifier returned by the CreateDataSetImportTask operation.
    GetDataSetImportTask -> Text
taskId :: Prelude.Text
  }
  deriving (GetDataSetImportTask -> GetDataSetImportTask -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: GetDataSetImportTask -> GetDataSetImportTask -> Bool
$c/= :: GetDataSetImportTask -> GetDataSetImportTask -> Bool
== :: GetDataSetImportTask -> GetDataSetImportTask -> Bool
$c== :: GetDataSetImportTask -> GetDataSetImportTask -> Bool
Prelude.Eq, ReadPrec [GetDataSetImportTask]
ReadPrec GetDataSetImportTask
Int -> ReadS GetDataSetImportTask
ReadS [GetDataSetImportTask]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [GetDataSetImportTask]
$creadListPrec :: ReadPrec [GetDataSetImportTask]
readPrec :: ReadPrec GetDataSetImportTask
$creadPrec :: ReadPrec GetDataSetImportTask
readList :: ReadS [GetDataSetImportTask]
$creadList :: ReadS [GetDataSetImportTask]
readsPrec :: Int -> ReadS GetDataSetImportTask
$creadsPrec :: Int -> ReadS GetDataSetImportTask
Prelude.Read, Int -> GetDataSetImportTask -> ShowS
[GetDataSetImportTask] -> ShowS
GetDataSetImportTask -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [GetDataSetImportTask] -> ShowS
$cshowList :: [GetDataSetImportTask] -> ShowS
show :: GetDataSetImportTask -> String
$cshow :: GetDataSetImportTask -> String
showsPrec :: Int -> GetDataSetImportTask -> ShowS
$cshowsPrec :: Int -> GetDataSetImportTask -> ShowS
Prelude.Show, forall x. Rep GetDataSetImportTask x -> GetDataSetImportTask
forall x. GetDataSetImportTask -> Rep GetDataSetImportTask x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep GetDataSetImportTask x -> GetDataSetImportTask
$cfrom :: forall x. GetDataSetImportTask -> Rep GetDataSetImportTask x
Prelude.Generic)

-- |
-- Create a value of 'GetDataSetImportTask' 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:
--
-- 'applicationId', 'getDataSetImportTask_applicationId' - The application identifier.
--
-- 'taskId', 'getDataSetImportTask_taskId' - The task identifier returned by the CreateDataSetImportTask operation.
newGetDataSetImportTask ::
  -- | 'applicationId'
  Prelude.Text ->
  -- | 'taskId'
  Prelude.Text ->
  GetDataSetImportTask
newGetDataSetImportTask :: Text -> Text -> GetDataSetImportTask
newGetDataSetImportTask Text
pApplicationId_ Text
pTaskId_ =
  GetDataSetImportTask'
    { $sel:applicationId:GetDataSetImportTask' :: Text
applicationId =
        Text
pApplicationId_,
      $sel:taskId:GetDataSetImportTask' :: Text
taskId = Text
pTaskId_
    }

-- | The application identifier.
getDataSetImportTask_applicationId :: Lens.Lens' GetDataSetImportTask Prelude.Text
getDataSetImportTask_applicationId :: Lens' GetDataSetImportTask Text
getDataSetImportTask_applicationId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetDataSetImportTask' {Text
applicationId :: Text
$sel:applicationId:GetDataSetImportTask' :: GetDataSetImportTask -> Text
applicationId} -> Text
applicationId) (\s :: GetDataSetImportTask
s@GetDataSetImportTask' {} Text
a -> GetDataSetImportTask
s {$sel:applicationId:GetDataSetImportTask' :: Text
applicationId = Text
a} :: GetDataSetImportTask)

-- | The task identifier returned by the CreateDataSetImportTask operation.
getDataSetImportTask_taskId :: Lens.Lens' GetDataSetImportTask Prelude.Text
getDataSetImportTask_taskId :: Lens' GetDataSetImportTask Text
getDataSetImportTask_taskId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetDataSetImportTask' {Text
taskId :: Text
$sel:taskId:GetDataSetImportTask' :: GetDataSetImportTask -> Text
taskId} -> Text
taskId) (\s :: GetDataSetImportTask
s@GetDataSetImportTask' {} Text
a -> GetDataSetImportTask
s {$sel:taskId:GetDataSetImportTask' :: Text
taskId = Text
a} :: GetDataSetImportTask)

instance Core.AWSRequest GetDataSetImportTask where
  type
    AWSResponse GetDataSetImportTask =
      GetDataSetImportTaskResponse
  request :: (Service -> Service)
-> GetDataSetImportTask -> Request GetDataSetImportTask
request Service -> Service
overrides =
    forall a. ToRequest a => Service -> a -> Request a
Request.get (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy GetDataSetImportTask
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse GetDataSetImportTask)))
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 DataSetImportSummary
-> Int
-> DataSetTaskLifecycle
-> Text
-> GetDataSetImportTaskResponse
GetDataSetImportTaskResponse'
            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
"summary")
            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))
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String a
Data..:> Key
"status")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String a
Data..:> Key
"taskId")
      )

instance Prelude.Hashable GetDataSetImportTask where
  hashWithSalt :: Int -> GetDataSetImportTask -> Int
hashWithSalt Int
_salt GetDataSetImportTask' {Text
taskId :: Text
applicationId :: Text
$sel:taskId:GetDataSetImportTask' :: GetDataSetImportTask -> Text
$sel:applicationId:GetDataSetImportTask' :: GetDataSetImportTask -> Text
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
applicationId
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
taskId

instance Prelude.NFData GetDataSetImportTask where
  rnf :: GetDataSetImportTask -> ()
rnf GetDataSetImportTask' {Text
taskId :: Text
applicationId :: Text
$sel:taskId:GetDataSetImportTask' :: GetDataSetImportTask -> Text
$sel:applicationId:GetDataSetImportTask' :: GetDataSetImportTask -> Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Text
applicationId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
taskId

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

instance Data.ToPath GetDataSetImportTask where
  toPath :: GetDataSetImportTask -> ByteString
toPath GetDataSetImportTask' {Text
taskId :: Text
applicationId :: Text
$sel:taskId:GetDataSetImportTask' :: GetDataSetImportTask -> Text
$sel:applicationId:GetDataSetImportTask' :: GetDataSetImportTask -> Text
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"/applications/",
        forall a. ToByteString a => a -> ByteString
Data.toBS Text
applicationId,
        ByteString
"/dataset-import-tasks/",
        forall a. ToByteString a => a -> ByteString
Data.toBS Text
taskId
      ]

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

-- | /See:/ 'newGetDataSetImportTaskResponse' smart constructor.
data GetDataSetImportTaskResponse = GetDataSetImportTaskResponse'
  { -- | A summary of the status of the task.
    GetDataSetImportTaskResponse -> Maybe DataSetImportSummary
summary :: Prelude.Maybe DataSetImportSummary,
    -- | The response's http status code.
    GetDataSetImportTaskResponse -> Int
httpStatus :: Prelude.Int,
    -- | The status of the task.
    GetDataSetImportTaskResponse -> DataSetTaskLifecycle
status :: DataSetTaskLifecycle,
    -- | The task identifier.
    GetDataSetImportTaskResponse -> Text
taskId :: Prelude.Text
  }
  deriving (GetDataSetImportTaskResponse
-> GetDataSetImportTaskResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: GetDataSetImportTaskResponse
-> GetDataSetImportTaskResponse -> Bool
$c/= :: GetDataSetImportTaskResponse
-> GetDataSetImportTaskResponse -> Bool
== :: GetDataSetImportTaskResponse
-> GetDataSetImportTaskResponse -> Bool
$c== :: GetDataSetImportTaskResponse
-> GetDataSetImportTaskResponse -> Bool
Prelude.Eq, ReadPrec [GetDataSetImportTaskResponse]
ReadPrec GetDataSetImportTaskResponse
Int -> ReadS GetDataSetImportTaskResponse
ReadS [GetDataSetImportTaskResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [GetDataSetImportTaskResponse]
$creadListPrec :: ReadPrec [GetDataSetImportTaskResponse]
readPrec :: ReadPrec GetDataSetImportTaskResponse
$creadPrec :: ReadPrec GetDataSetImportTaskResponse
readList :: ReadS [GetDataSetImportTaskResponse]
$creadList :: ReadS [GetDataSetImportTaskResponse]
readsPrec :: Int -> ReadS GetDataSetImportTaskResponse
$creadsPrec :: Int -> ReadS GetDataSetImportTaskResponse
Prelude.Read, Int -> GetDataSetImportTaskResponse -> ShowS
[GetDataSetImportTaskResponse] -> ShowS
GetDataSetImportTaskResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [GetDataSetImportTaskResponse] -> ShowS
$cshowList :: [GetDataSetImportTaskResponse] -> ShowS
show :: GetDataSetImportTaskResponse -> String
$cshow :: GetDataSetImportTaskResponse -> String
showsPrec :: Int -> GetDataSetImportTaskResponse -> ShowS
$cshowsPrec :: Int -> GetDataSetImportTaskResponse -> ShowS
Prelude.Show, forall x.
Rep GetDataSetImportTaskResponse x -> GetDataSetImportTaskResponse
forall x.
GetDataSetImportTaskResponse -> Rep GetDataSetImportTaskResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep GetDataSetImportTaskResponse x -> GetDataSetImportTaskResponse
$cfrom :: forall x.
GetDataSetImportTaskResponse -> Rep GetDataSetImportTaskResponse x
Prelude.Generic)

-- |
-- Create a value of 'GetDataSetImportTaskResponse' 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:
--
-- 'summary', 'getDataSetImportTaskResponse_summary' - A summary of the status of the task.
--
-- 'httpStatus', 'getDataSetImportTaskResponse_httpStatus' - The response's http status code.
--
-- 'status', 'getDataSetImportTaskResponse_status' - The status of the task.
--
-- 'taskId', 'getDataSetImportTaskResponse_taskId' - The task identifier.
newGetDataSetImportTaskResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  -- | 'status'
  DataSetTaskLifecycle ->
  -- | 'taskId'
  Prelude.Text ->
  GetDataSetImportTaskResponse
newGetDataSetImportTaskResponse :: Int -> DataSetTaskLifecycle -> Text -> GetDataSetImportTaskResponse
newGetDataSetImportTaskResponse
  Int
pHttpStatus_
  DataSetTaskLifecycle
pStatus_
  Text
pTaskId_ =
    GetDataSetImportTaskResponse'
      { $sel:summary:GetDataSetImportTaskResponse' :: Maybe DataSetImportSummary
summary =
          forall a. Maybe a
Prelude.Nothing,
        $sel:httpStatus:GetDataSetImportTaskResponse' :: Int
httpStatus = Int
pHttpStatus_,
        $sel:status:GetDataSetImportTaskResponse' :: DataSetTaskLifecycle
status = DataSetTaskLifecycle
pStatus_,
        $sel:taskId:GetDataSetImportTaskResponse' :: Text
taskId = Text
pTaskId_
      }

-- | A summary of the status of the task.
getDataSetImportTaskResponse_summary :: Lens.Lens' GetDataSetImportTaskResponse (Prelude.Maybe DataSetImportSummary)
getDataSetImportTaskResponse_summary :: Lens' GetDataSetImportTaskResponse (Maybe DataSetImportSummary)
getDataSetImportTaskResponse_summary = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetDataSetImportTaskResponse' {Maybe DataSetImportSummary
summary :: Maybe DataSetImportSummary
$sel:summary:GetDataSetImportTaskResponse' :: GetDataSetImportTaskResponse -> Maybe DataSetImportSummary
summary} -> Maybe DataSetImportSummary
summary) (\s :: GetDataSetImportTaskResponse
s@GetDataSetImportTaskResponse' {} Maybe DataSetImportSummary
a -> GetDataSetImportTaskResponse
s {$sel:summary:GetDataSetImportTaskResponse' :: Maybe DataSetImportSummary
summary = Maybe DataSetImportSummary
a} :: GetDataSetImportTaskResponse)

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

-- | The status of the task.
getDataSetImportTaskResponse_status :: Lens.Lens' GetDataSetImportTaskResponse DataSetTaskLifecycle
getDataSetImportTaskResponse_status :: Lens' GetDataSetImportTaskResponse DataSetTaskLifecycle
getDataSetImportTaskResponse_status = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetDataSetImportTaskResponse' {DataSetTaskLifecycle
status :: DataSetTaskLifecycle
$sel:status:GetDataSetImportTaskResponse' :: GetDataSetImportTaskResponse -> DataSetTaskLifecycle
status} -> DataSetTaskLifecycle
status) (\s :: GetDataSetImportTaskResponse
s@GetDataSetImportTaskResponse' {} DataSetTaskLifecycle
a -> GetDataSetImportTaskResponse
s {$sel:status:GetDataSetImportTaskResponse' :: DataSetTaskLifecycle
status = DataSetTaskLifecycle
a} :: GetDataSetImportTaskResponse)

-- | The task identifier.
getDataSetImportTaskResponse_taskId :: Lens.Lens' GetDataSetImportTaskResponse Prelude.Text
getDataSetImportTaskResponse_taskId :: Lens' GetDataSetImportTaskResponse Text
getDataSetImportTaskResponse_taskId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetDataSetImportTaskResponse' {Text
taskId :: Text
$sel:taskId:GetDataSetImportTaskResponse' :: GetDataSetImportTaskResponse -> Text
taskId} -> Text
taskId) (\s :: GetDataSetImportTaskResponse
s@GetDataSetImportTaskResponse' {} Text
a -> GetDataSetImportTaskResponse
s {$sel:taskId:GetDataSetImportTaskResponse' :: Text
taskId = Text
a} :: GetDataSetImportTaskResponse)

instance Prelude.NFData GetDataSetImportTaskResponse where
  rnf :: GetDataSetImportTaskResponse -> ()
rnf GetDataSetImportTaskResponse' {Int
Maybe DataSetImportSummary
Text
DataSetTaskLifecycle
taskId :: Text
status :: DataSetTaskLifecycle
httpStatus :: Int
summary :: Maybe DataSetImportSummary
$sel:taskId:GetDataSetImportTaskResponse' :: GetDataSetImportTaskResponse -> Text
$sel:status:GetDataSetImportTaskResponse' :: GetDataSetImportTaskResponse -> DataSetTaskLifecycle
$sel:httpStatus:GetDataSetImportTaskResponse' :: GetDataSetImportTaskResponse -> Int
$sel:summary:GetDataSetImportTaskResponse' :: GetDataSetImportTaskResponse -> Maybe DataSetImportSummary
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe DataSetImportSummary
summary
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf DataSetTaskLifecycle
status
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
taskId