{-# 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.ImportSnapshotTask
-- 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.ImportSnapshotTask 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.SnapshotTaskDetail
import Amazonka.EC2.Types.Tag
import qualified Amazonka.Prelude as Prelude

-- | Describes an import snapshot task.
--
-- /See:/ 'newImportSnapshotTask' smart constructor.
data ImportSnapshotTask = ImportSnapshotTask'
  { -- | A description of the import snapshot task.
    ImportSnapshotTask -> Maybe Text
description :: Prelude.Maybe Prelude.Text,
    -- | The ID of the import snapshot task.
    ImportSnapshotTask -> Maybe Text
importTaskId :: Prelude.Maybe Prelude.Text,
    -- | Describes an import snapshot task.
    ImportSnapshotTask -> Maybe SnapshotTaskDetail
snapshotTaskDetail :: Prelude.Maybe SnapshotTaskDetail,
    -- | The tags for the import snapshot task.
    ImportSnapshotTask -> Maybe [Tag]
tags :: Prelude.Maybe [Tag]
  }
  deriving (ImportSnapshotTask -> ImportSnapshotTask -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ImportSnapshotTask -> ImportSnapshotTask -> Bool
$c/= :: ImportSnapshotTask -> ImportSnapshotTask -> Bool
== :: ImportSnapshotTask -> ImportSnapshotTask -> Bool
$c== :: ImportSnapshotTask -> ImportSnapshotTask -> Bool
Prelude.Eq, ReadPrec [ImportSnapshotTask]
ReadPrec ImportSnapshotTask
Int -> ReadS ImportSnapshotTask
ReadS [ImportSnapshotTask]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ImportSnapshotTask]
$creadListPrec :: ReadPrec [ImportSnapshotTask]
readPrec :: ReadPrec ImportSnapshotTask
$creadPrec :: ReadPrec ImportSnapshotTask
readList :: ReadS [ImportSnapshotTask]
$creadList :: ReadS [ImportSnapshotTask]
readsPrec :: Int -> ReadS ImportSnapshotTask
$creadsPrec :: Int -> ReadS ImportSnapshotTask
Prelude.Read, Int -> ImportSnapshotTask -> ShowS
[ImportSnapshotTask] -> ShowS
ImportSnapshotTask -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ImportSnapshotTask] -> ShowS
$cshowList :: [ImportSnapshotTask] -> ShowS
show :: ImportSnapshotTask -> String
$cshow :: ImportSnapshotTask -> String
showsPrec :: Int -> ImportSnapshotTask -> ShowS
$cshowsPrec :: Int -> ImportSnapshotTask -> ShowS
Prelude.Show, forall x. Rep ImportSnapshotTask x -> ImportSnapshotTask
forall x. ImportSnapshotTask -> Rep ImportSnapshotTask x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep ImportSnapshotTask x -> ImportSnapshotTask
$cfrom :: forall x. ImportSnapshotTask -> Rep ImportSnapshotTask x
Prelude.Generic)

-- |
-- Create a value of 'ImportSnapshotTask' 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', 'importSnapshotTask_description' - A description of the import snapshot task.
--
-- 'importTaskId', 'importSnapshotTask_importTaskId' - The ID of the import snapshot task.
--
-- 'snapshotTaskDetail', 'importSnapshotTask_snapshotTaskDetail' - Describes an import snapshot task.
--
-- 'tags', 'importSnapshotTask_tags' - The tags for the import snapshot task.
newImportSnapshotTask ::
  ImportSnapshotTask
newImportSnapshotTask :: ImportSnapshotTask
newImportSnapshotTask =
  ImportSnapshotTask'
    { $sel:description:ImportSnapshotTask' :: Maybe Text
description = forall a. Maybe a
Prelude.Nothing,
      $sel:importTaskId:ImportSnapshotTask' :: Maybe Text
importTaskId = forall a. Maybe a
Prelude.Nothing,
      $sel:snapshotTaskDetail:ImportSnapshotTask' :: Maybe SnapshotTaskDetail
snapshotTaskDetail = forall a. Maybe a
Prelude.Nothing,
      $sel:tags:ImportSnapshotTask' :: Maybe [Tag]
tags = forall a. Maybe a
Prelude.Nothing
    }

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

-- | The ID of the import snapshot task.
importSnapshotTask_importTaskId :: Lens.Lens' ImportSnapshotTask (Prelude.Maybe Prelude.Text)
importSnapshotTask_importTaskId :: Lens' ImportSnapshotTask (Maybe Text)
importSnapshotTask_importTaskId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ImportSnapshotTask' {Maybe Text
importTaskId :: Maybe Text
$sel:importTaskId:ImportSnapshotTask' :: ImportSnapshotTask -> Maybe Text
importTaskId} -> Maybe Text
importTaskId) (\s :: ImportSnapshotTask
s@ImportSnapshotTask' {} Maybe Text
a -> ImportSnapshotTask
s {$sel:importTaskId:ImportSnapshotTask' :: Maybe Text
importTaskId = Maybe Text
a} :: ImportSnapshotTask)

-- | Describes an import snapshot task.
importSnapshotTask_snapshotTaskDetail :: Lens.Lens' ImportSnapshotTask (Prelude.Maybe SnapshotTaskDetail)
importSnapshotTask_snapshotTaskDetail :: Lens' ImportSnapshotTask (Maybe SnapshotTaskDetail)
importSnapshotTask_snapshotTaskDetail = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ImportSnapshotTask' {Maybe SnapshotTaskDetail
snapshotTaskDetail :: Maybe SnapshotTaskDetail
$sel:snapshotTaskDetail:ImportSnapshotTask' :: ImportSnapshotTask -> Maybe SnapshotTaskDetail
snapshotTaskDetail} -> Maybe SnapshotTaskDetail
snapshotTaskDetail) (\s :: ImportSnapshotTask
s@ImportSnapshotTask' {} Maybe SnapshotTaskDetail
a -> ImportSnapshotTask
s {$sel:snapshotTaskDetail:ImportSnapshotTask' :: Maybe SnapshotTaskDetail
snapshotTaskDetail = Maybe SnapshotTaskDetail
a} :: ImportSnapshotTask)

-- | The tags for the import snapshot task.
importSnapshotTask_tags :: Lens.Lens' ImportSnapshotTask (Prelude.Maybe [Tag])
importSnapshotTask_tags :: Lens' ImportSnapshotTask (Maybe [Tag])
importSnapshotTask_tags = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ImportSnapshotTask' {Maybe [Tag]
tags :: Maybe [Tag]
$sel:tags:ImportSnapshotTask' :: ImportSnapshotTask -> Maybe [Tag]
tags} -> Maybe [Tag]
tags) (\s :: ImportSnapshotTask
s@ImportSnapshotTask' {} Maybe [Tag]
a -> ImportSnapshotTask
s {$sel:tags:ImportSnapshotTask' :: Maybe [Tag]
tags = Maybe [Tag]
a} :: ImportSnapshotTask) 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 ImportSnapshotTask where
  parseXML :: [Node] -> Either String ImportSnapshotTask
parseXML [Node]
x =
    Maybe Text
-> Maybe Text
-> Maybe SnapshotTaskDetail
-> Maybe [Tag]
-> ImportSnapshotTask
ImportSnapshotTask'
      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
"importTaskId")
      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
"snapshotTaskDetail")
      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
"tagSet"
                      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 ImportSnapshotTask where
  hashWithSalt :: Int -> ImportSnapshotTask -> Int
hashWithSalt Int
_salt ImportSnapshotTask' {Maybe [Tag]
Maybe Text
Maybe SnapshotTaskDetail
tags :: Maybe [Tag]
snapshotTaskDetail :: Maybe SnapshotTaskDetail
importTaskId :: Maybe Text
description :: Maybe Text
$sel:tags:ImportSnapshotTask' :: ImportSnapshotTask -> Maybe [Tag]
$sel:snapshotTaskDetail:ImportSnapshotTask' :: ImportSnapshotTask -> Maybe SnapshotTaskDetail
$sel:importTaskId:ImportSnapshotTask' :: ImportSnapshotTask -> Maybe Text
$sel:description:ImportSnapshotTask' :: ImportSnapshotTask -> 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
importTaskId
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe SnapshotTaskDetail
snapshotTaskDetail
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [Tag]
tags

instance Prelude.NFData ImportSnapshotTask where
  rnf :: ImportSnapshotTask -> ()
rnf ImportSnapshotTask' {Maybe [Tag]
Maybe Text
Maybe SnapshotTaskDetail
tags :: Maybe [Tag]
snapshotTaskDetail :: Maybe SnapshotTaskDetail
importTaskId :: Maybe Text
description :: Maybe Text
$sel:tags:ImportSnapshotTask' :: ImportSnapshotTask -> Maybe [Tag]
$sel:snapshotTaskDetail:ImportSnapshotTask' :: ImportSnapshotTask -> Maybe SnapshotTaskDetail
$sel:importTaskId:ImportSnapshotTask' :: ImportSnapshotTask -> Maybe Text
$sel:description:ImportSnapshotTask' :: ImportSnapshotTask -> 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
importTaskId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe SnapshotTaskDetail
snapshotTaskDetail
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe [Tag]
tags