{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE DuplicateRecordFields #-}
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE StrictData #-}
{-# LANGUAGE NoImplicitPrelude #-}
{-# 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.Types.ImportInstanceTaskDetails
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
module Amazonka.EC2.Types.ImportInstanceTaskDetails where

import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.EC2.Internal
import Amazonka.EC2.Types.ImportInstanceVolumeDetailItem
import Amazonka.EC2.Types.PlatformValues
import qualified Amazonka.Prelude as Prelude

-- | Describes an import instance task.
--
-- /See:/ 'newImportInstanceTaskDetails' smart constructor.
data ImportInstanceTaskDetails = ImportInstanceTaskDetails'
  { -- | A description of the task.
    ImportInstanceTaskDetails -> Maybe Text
description :: Prelude.Maybe Prelude.Text,
    -- | The ID of the instance.
    ImportInstanceTaskDetails -> Maybe Text
instanceId :: Prelude.Maybe Prelude.Text,
    -- | The instance operating system.
    ImportInstanceTaskDetails -> Maybe PlatformValues
platform :: Prelude.Maybe PlatformValues,
    -- | The volumes.
    ImportInstanceTaskDetails -> Maybe [ImportInstanceVolumeDetailItem]
volumes :: Prelude.Maybe [ImportInstanceVolumeDetailItem]
  }
  deriving (ImportInstanceTaskDetails -> ImportInstanceTaskDetails -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ImportInstanceTaskDetails -> ImportInstanceTaskDetails -> Bool
$c/= :: ImportInstanceTaskDetails -> ImportInstanceTaskDetails -> Bool
== :: ImportInstanceTaskDetails -> ImportInstanceTaskDetails -> Bool
$c== :: ImportInstanceTaskDetails -> ImportInstanceTaskDetails -> Bool
Prelude.Eq, ReadPrec [ImportInstanceTaskDetails]
ReadPrec ImportInstanceTaskDetails
Int -> ReadS ImportInstanceTaskDetails
ReadS [ImportInstanceTaskDetails]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ImportInstanceTaskDetails]
$creadListPrec :: ReadPrec [ImportInstanceTaskDetails]
readPrec :: ReadPrec ImportInstanceTaskDetails
$creadPrec :: ReadPrec ImportInstanceTaskDetails
readList :: ReadS [ImportInstanceTaskDetails]
$creadList :: ReadS [ImportInstanceTaskDetails]
readsPrec :: Int -> ReadS ImportInstanceTaskDetails
$creadsPrec :: Int -> ReadS ImportInstanceTaskDetails
Prelude.Read, Int -> ImportInstanceTaskDetails -> ShowS
[ImportInstanceTaskDetails] -> ShowS
ImportInstanceTaskDetails -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ImportInstanceTaskDetails] -> ShowS
$cshowList :: [ImportInstanceTaskDetails] -> ShowS
show :: ImportInstanceTaskDetails -> String
$cshow :: ImportInstanceTaskDetails -> String
showsPrec :: Int -> ImportInstanceTaskDetails -> ShowS
$cshowsPrec :: Int -> ImportInstanceTaskDetails -> ShowS
Prelude.Show, forall x.
Rep ImportInstanceTaskDetails x -> ImportInstanceTaskDetails
forall x.
ImportInstanceTaskDetails -> Rep ImportInstanceTaskDetails x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep ImportInstanceTaskDetails x -> ImportInstanceTaskDetails
$cfrom :: forall x.
ImportInstanceTaskDetails -> Rep ImportInstanceTaskDetails x
Prelude.Generic)

-- |
-- Create a value of 'ImportInstanceTaskDetails' 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:
--
-- 'description', 'importInstanceTaskDetails_description' - A description of the task.
--
-- 'instanceId', 'importInstanceTaskDetails_instanceId' - The ID of the instance.
--
-- 'platform', 'importInstanceTaskDetails_platform' - The instance operating system.
--
-- 'volumes', 'importInstanceTaskDetails_volumes' - The volumes.
newImportInstanceTaskDetails ::
  ImportInstanceTaskDetails
newImportInstanceTaskDetails :: ImportInstanceTaskDetails
newImportInstanceTaskDetails =
  ImportInstanceTaskDetails'
    { $sel:description:ImportInstanceTaskDetails' :: Maybe Text
description =
        forall a. Maybe a
Prelude.Nothing,
      $sel:instanceId:ImportInstanceTaskDetails' :: Maybe Text
instanceId = forall a. Maybe a
Prelude.Nothing,
      $sel:platform:ImportInstanceTaskDetails' :: Maybe PlatformValues
platform = forall a. Maybe a
Prelude.Nothing,
      $sel:volumes:ImportInstanceTaskDetails' :: Maybe [ImportInstanceVolumeDetailItem]
volumes = forall a. Maybe a
Prelude.Nothing
    }

-- | A description of the task.
importInstanceTaskDetails_description :: Lens.Lens' ImportInstanceTaskDetails (Prelude.Maybe Prelude.Text)
importInstanceTaskDetails_description :: Lens' ImportInstanceTaskDetails (Maybe Text)
importInstanceTaskDetails_description = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ImportInstanceTaskDetails' {Maybe Text
description :: Maybe Text
$sel:description:ImportInstanceTaskDetails' :: ImportInstanceTaskDetails -> Maybe Text
description} -> Maybe Text
description) (\s :: ImportInstanceTaskDetails
s@ImportInstanceTaskDetails' {} Maybe Text
a -> ImportInstanceTaskDetails
s {$sel:description:ImportInstanceTaskDetails' :: Maybe Text
description = Maybe Text
a} :: ImportInstanceTaskDetails)

-- | The ID of the instance.
importInstanceTaskDetails_instanceId :: Lens.Lens' ImportInstanceTaskDetails (Prelude.Maybe Prelude.Text)
importInstanceTaskDetails_instanceId :: Lens' ImportInstanceTaskDetails (Maybe Text)
importInstanceTaskDetails_instanceId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ImportInstanceTaskDetails' {Maybe Text
instanceId :: Maybe Text
$sel:instanceId:ImportInstanceTaskDetails' :: ImportInstanceTaskDetails -> Maybe Text
instanceId} -> Maybe Text
instanceId) (\s :: ImportInstanceTaskDetails
s@ImportInstanceTaskDetails' {} Maybe Text
a -> ImportInstanceTaskDetails
s {$sel:instanceId:ImportInstanceTaskDetails' :: Maybe Text
instanceId = Maybe Text
a} :: ImportInstanceTaskDetails)

-- | The instance operating system.
importInstanceTaskDetails_platform :: Lens.Lens' ImportInstanceTaskDetails (Prelude.Maybe PlatformValues)
importInstanceTaskDetails_platform :: Lens' ImportInstanceTaskDetails (Maybe PlatformValues)
importInstanceTaskDetails_platform = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ImportInstanceTaskDetails' {Maybe PlatformValues
platform :: Maybe PlatformValues
$sel:platform:ImportInstanceTaskDetails' :: ImportInstanceTaskDetails -> Maybe PlatformValues
platform} -> Maybe PlatformValues
platform) (\s :: ImportInstanceTaskDetails
s@ImportInstanceTaskDetails' {} Maybe PlatformValues
a -> ImportInstanceTaskDetails
s {$sel:platform:ImportInstanceTaskDetails' :: Maybe PlatformValues
platform = Maybe PlatformValues
a} :: ImportInstanceTaskDetails)

-- | The volumes.
importInstanceTaskDetails_volumes :: Lens.Lens' ImportInstanceTaskDetails (Prelude.Maybe [ImportInstanceVolumeDetailItem])
importInstanceTaskDetails_volumes :: Lens'
  ImportInstanceTaskDetails (Maybe [ImportInstanceVolumeDetailItem])
importInstanceTaskDetails_volumes = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ImportInstanceTaskDetails' {Maybe [ImportInstanceVolumeDetailItem]
volumes :: Maybe [ImportInstanceVolumeDetailItem]
$sel:volumes:ImportInstanceTaskDetails' :: ImportInstanceTaskDetails -> Maybe [ImportInstanceVolumeDetailItem]
volumes} -> Maybe [ImportInstanceVolumeDetailItem]
volumes) (\s :: ImportInstanceTaskDetails
s@ImportInstanceTaskDetails' {} Maybe [ImportInstanceVolumeDetailItem]
a -> ImportInstanceTaskDetails
s {$sel:volumes:ImportInstanceTaskDetails' :: Maybe [ImportInstanceVolumeDetailItem]
volumes = Maybe [ImportInstanceVolumeDetailItem]
a} :: ImportInstanceTaskDetails) 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 Data.FromXML ImportInstanceTaskDetails where
  parseXML :: [Node] -> Either String ImportInstanceTaskDetails
parseXML [Node]
x =
    Maybe Text
-> Maybe Text
-> Maybe PlatformValues
-> Maybe [ImportInstanceVolumeDetailItem]
-> ImportInstanceTaskDetails
ImportInstanceTaskDetails'
      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
"description")
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> ([Node]
x forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"instanceId")
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> ([Node]
x forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"platform")
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> ( [Node]
x
                      forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"volumes"
                      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")
                  )

instance Prelude.Hashable ImportInstanceTaskDetails where
  hashWithSalt :: Int -> ImportInstanceTaskDetails -> Int
hashWithSalt Int
_salt ImportInstanceTaskDetails' {Maybe [ImportInstanceVolumeDetailItem]
Maybe Text
Maybe PlatformValues
volumes :: Maybe [ImportInstanceVolumeDetailItem]
platform :: Maybe PlatformValues
instanceId :: Maybe Text
description :: Maybe Text
$sel:volumes:ImportInstanceTaskDetails' :: ImportInstanceTaskDetails -> Maybe [ImportInstanceVolumeDetailItem]
$sel:platform:ImportInstanceTaskDetails' :: ImportInstanceTaskDetails -> Maybe PlatformValues
$sel:instanceId:ImportInstanceTaskDetails' :: ImportInstanceTaskDetails -> Maybe Text
$sel:description:ImportInstanceTaskDetails' :: ImportInstanceTaskDetails -> Maybe Text
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
description
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
instanceId
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe PlatformValues
platform
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [ImportInstanceVolumeDetailItem]
volumes

instance Prelude.NFData ImportInstanceTaskDetails where
  rnf :: ImportInstanceTaskDetails -> ()
rnf ImportInstanceTaskDetails' {Maybe [ImportInstanceVolumeDetailItem]
Maybe Text
Maybe PlatformValues
volumes :: Maybe [ImportInstanceVolumeDetailItem]
platform :: Maybe PlatformValues
instanceId :: Maybe Text
description :: Maybe Text
$sel:volumes:ImportInstanceTaskDetails' :: ImportInstanceTaskDetails -> Maybe [ImportInstanceVolumeDetailItem]
$sel:platform:ImportInstanceTaskDetails' :: ImportInstanceTaskDetails -> Maybe PlatformValues
$sel:instanceId:ImportInstanceTaskDetails' :: ImportInstanceTaskDetails -> Maybe Text
$sel:description:ImportInstanceTaskDetails' :: ImportInstanceTaskDetails -> Maybe Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
description
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
instanceId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe PlatformValues
platform
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe [ImportInstanceVolumeDetailItem]
volumes