{-# 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.MoveAddressToVpc
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Moves an Elastic IP address from the EC2-Classic platform to the EC2-VPC
-- platform. The Elastic IP address must be allocated to your account for
-- more than 24 hours, and it must not be associated with an instance.
-- After the Elastic IP address is moved, it is no longer available for use
-- in the EC2-Classic platform, unless you move it back using the
-- RestoreAddressToClassic request. You cannot move an Elastic IP address
-- that was originally allocated for use in the EC2-VPC platform to the
-- EC2-Classic platform.
--
-- We are retiring EC2-Classic. We recommend that you migrate from
-- EC2-Classic to a VPC. For more information, see
-- <https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/vpc-migrate.html Migrate from EC2-Classic to a VPC>
-- in the /Amazon Elastic Compute Cloud User Guide/.
module Amazonka.EC2.MoveAddressToVpc
  ( -- * Creating a Request
    MoveAddressToVpc (..),
    newMoveAddressToVpc,

    -- * Request Lenses
    moveAddressToVpc_dryRun,
    moveAddressToVpc_publicIp,

    -- * Destructuring the Response
    MoveAddressToVpcResponse (..),
    newMoveAddressToVpcResponse,

    -- * Response Lenses
    moveAddressToVpcResponse_allocationId,
    moveAddressToVpcResponse_status,
    moveAddressToVpcResponse_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:/ 'newMoveAddressToVpc' smart constructor.
data MoveAddressToVpc = MoveAddressToVpc'
  { -- | 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@.
    MoveAddressToVpc -> Maybe Bool
dryRun :: Prelude.Maybe Prelude.Bool,
    -- | The Elastic IP address.
    MoveAddressToVpc -> Text
publicIp :: Prelude.Text
  }
  deriving (MoveAddressToVpc -> MoveAddressToVpc -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: MoveAddressToVpc -> MoveAddressToVpc -> Bool
$c/= :: MoveAddressToVpc -> MoveAddressToVpc -> Bool
== :: MoveAddressToVpc -> MoveAddressToVpc -> Bool
$c== :: MoveAddressToVpc -> MoveAddressToVpc -> Bool
Prelude.Eq, ReadPrec [MoveAddressToVpc]
ReadPrec MoveAddressToVpc
Int -> ReadS MoveAddressToVpc
ReadS [MoveAddressToVpc]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [MoveAddressToVpc]
$creadListPrec :: ReadPrec [MoveAddressToVpc]
readPrec :: ReadPrec MoveAddressToVpc
$creadPrec :: ReadPrec MoveAddressToVpc
readList :: ReadS [MoveAddressToVpc]
$creadList :: ReadS [MoveAddressToVpc]
readsPrec :: Int -> ReadS MoveAddressToVpc
$creadsPrec :: Int -> ReadS MoveAddressToVpc
Prelude.Read, Int -> MoveAddressToVpc -> ShowS
[MoveAddressToVpc] -> ShowS
MoveAddressToVpc -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [MoveAddressToVpc] -> ShowS
$cshowList :: [MoveAddressToVpc] -> ShowS
show :: MoveAddressToVpc -> String
$cshow :: MoveAddressToVpc -> String
showsPrec :: Int -> MoveAddressToVpc -> ShowS
$cshowsPrec :: Int -> MoveAddressToVpc -> ShowS
Prelude.Show, forall x. Rep MoveAddressToVpc x -> MoveAddressToVpc
forall x. MoveAddressToVpc -> Rep MoveAddressToVpc x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep MoveAddressToVpc x -> MoveAddressToVpc
$cfrom :: forall x. MoveAddressToVpc -> Rep MoveAddressToVpc x
Prelude.Generic)

-- |
-- Create a value of 'MoveAddressToVpc' 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:
--
-- 'dryRun', 'moveAddressToVpc_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@.
--
-- 'publicIp', 'moveAddressToVpc_publicIp' - The Elastic IP address.
newMoveAddressToVpc ::
  -- | 'publicIp'
  Prelude.Text ->
  MoveAddressToVpc
newMoveAddressToVpc :: Text -> MoveAddressToVpc
newMoveAddressToVpc Text
pPublicIp_ =
  MoveAddressToVpc'
    { $sel:dryRun:MoveAddressToVpc' :: Maybe Bool
dryRun = forall a. Maybe a
Prelude.Nothing,
      $sel:publicIp:MoveAddressToVpc' :: Text
publicIp = Text
pPublicIp_
    }

-- | 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@.
moveAddressToVpc_dryRun :: Lens.Lens' MoveAddressToVpc (Prelude.Maybe Prelude.Bool)
moveAddressToVpc_dryRun :: Lens' MoveAddressToVpc (Maybe Bool)
moveAddressToVpc_dryRun = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\MoveAddressToVpc' {Maybe Bool
dryRun :: Maybe Bool
$sel:dryRun:MoveAddressToVpc' :: MoveAddressToVpc -> Maybe Bool
dryRun} -> Maybe Bool
dryRun) (\s :: MoveAddressToVpc
s@MoveAddressToVpc' {} Maybe Bool
a -> MoveAddressToVpc
s {$sel:dryRun:MoveAddressToVpc' :: Maybe Bool
dryRun = Maybe Bool
a} :: MoveAddressToVpc)

-- | The Elastic IP address.
moveAddressToVpc_publicIp :: Lens.Lens' MoveAddressToVpc Prelude.Text
moveAddressToVpc_publicIp :: Lens' MoveAddressToVpc Text
moveAddressToVpc_publicIp = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\MoveAddressToVpc' {Text
publicIp :: Text
$sel:publicIp:MoveAddressToVpc' :: MoveAddressToVpc -> Text
publicIp} -> Text
publicIp) (\s :: MoveAddressToVpc
s@MoveAddressToVpc' {} Text
a -> MoveAddressToVpc
s {$sel:publicIp:MoveAddressToVpc' :: Text
publicIp = Text
a} :: MoveAddressToVpc)

instance Core.AWSRequest MoveAddressToVpc where
  type
    AWSResponse MoveAddressToVpc =
      MoveAddressToVpcResponse
  request :: (Service -> Service)
-> MoveAddressToVpc -> Request MoveAddressToVpc
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 MoveAddressToVpc
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse MoveAddressToVpc)))
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 Text
-> Maybe AddressStatus -> Int -> MoveAddressToVpcResponse
MoveAddressToVpcResponse'
            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
"allocationId")
            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
"status")
            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 MoveAddressToVpc where
  hashWithSalt :: Int -> MoveAddressToVpc -> Int
hashWithSalt Int
_salt MoveAddressToVpc' {Maybe Bool
Text
publicIp :: Text
dryRun :: Maybe Bool
$sel:publicIp:MoveAddressToVpc' :: MoveAddressToVpc -> Text
$sel:dryRun:MoveAddressToVpc' :: MoveAddressToVpc -> Maybe Bool
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Bool
dryRun
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
publicIp

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

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

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

instance Data.ToQuery MoveAddressToVpc where
  toQuery :: MoveAddressToVpc -> QueryString
toQuery MoveAddressToVpc' {Maybe Bool
Text
publicIp :: Text
dryRun :: Maybe Bool
$sel:publicIp:MoveAddressToVpc' :: MoveAddressToVpc -> Text
$sel:dryRun:MoveAddressToVpc' :: MoveAddressToVpc -> Maybe Bool
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"Action"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"MoveAddressToVpc" :: Prelude.ByteString),
        ByteString
"Version"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"2016-11-15" :: Prelude.ByteString),
        ByteString
"DryRun" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Bool
dryRun,
        ByteString
"PublicIp" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Text
publicIp
      ]

-- | /See:/ 'newMoveAddressToVpcResponse' smart constructor.
data MoveAddressToVpcResponse = MoveAddressToVpcResponse'
  { -- | The allocation ID for the Elastic IP address.
    MoveAddressToVpcResponse -> Maybe Text
allocationId :: Prelude.Maybe Prelude.Text,
    -- | The status of the move of the IP address.
    MoveAddressToVpcResponse -> Maybe AddressStatus
status :: Prelude.Maybe AddressStatus,
    -- | The response's http status code.
    MoveAddressToVpcResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (MoveAddressToVpcResponse -> MoveAddressToVpcResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: MoveAddressToVpcResponse -> MoveAddressToVpcResponse -> Bool
$c/= :: MoveAddressToVpcResponse -> MoveAddressToVpcResponse -> Bool
== :: MoveAddressToVpcResponse -> MoveAddressToVpcResponse -> Bool
$c== :: MoveAddressToVpcResponse -> MoveAddressToVpcResponse -> Bool
Prelude.Eq, ReadPrec [MoveAddressToVpcResponse]
ReadPrec MoveAddressToVpcResponse
Int -> ReadS MoveAddressToVpcResponse
ReadS [MoveAddressToVpcResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [MoveAddressToVpcResponse]
$creadListPrec :: ReadPrec [MoveAddressToVpcResponse]
readPrec :: ReadPrec MoveAddressToVpcResponse
$creadPrec :: ReadPrec MoveAddressToVpcResponse
readList :: ReadS [MoveAddressToVpcResponse]
$creadList :: ReadS [MoveAddressToVpcResponse]
readsPrec :: Int -> ReadS MoveAddressToVpcResponse
$creadsPrec :: Int -> ReadS MoveAddressToVpcResponse
Prelude.Read, Int -> MoveAddressToVpcResponse -> ShowS
[MoveAddressToVpcResponse] -> ShowS
MoveAddressToVpcResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [MoveAddressToVpcResponse] -> ShowS
$cshowList :: [MoveAddressToVpcResponse] -> ShowS
show :: MoveAddressToVpcResponse -> String
$cshow :: MoveAddressToVpcResponse -> String
showsPrec :: Int -> MoveAddressToVpcResponse -> ShowS
$cshowsPrec :: Int -> MoveAddressToVpcResponse -> ShowS
Prelude.Show, forall x.
Rep MoveAddressToVpcResponse x -> MoveAddressToVpcResponse
forall x.
MoveAddressToVpcResponse -> Rep MoveAddressToVpcResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep MoveAddressToVpcResponse x -> MoveAddressToVpcResponse
$cfrom :: forall x.
MoveAddressToVpcResponse -> Rep MoveAddressToVpcResponse x
Prelude.Generic)

-- |
-- Create a value of 'MoveAddressToVpcResponse' 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:
--
-- 'allocationId', 'moveAddressToVpcResponse_allocationId' - The allocation ID for the Elastic IP address.
--
-- 'status', 'moveAddressToVpcResponse_status' - The status of the move of the IP address.
--
-- 'httpStatus', 'moveAddressToVpcResponse_httpStatus' - The response's http status code.
newMoveAddressToVpcResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  MoveAddressToVpcResponse
newMoveAddressToVpcResponse :: Int -> MoveAddressToVpcResponse
newMoveAddressToVpcResponse Int
pHttpStatus_ =
  MoveAddressToVpcResponse'
    { $sel:allocationId:MoveAddressToVpcResponse' :: Maybe Text
allocationId =
        forall a. Maybe a
Prelude.Nothing,
      $sel:status:MoveAddressToVpcResponse' :: Maybe AddressStatus
status = forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:MoveAddressToVpcResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | The allocation ID for the Elastic IP address.
moveAddressToVpcResponse_allocationId :: Lens.Lens' MoveAddressToVpcResponse (Prelude.Maybe Prelude.Text)
moveAddressToVpcResponse_allocationId :: Lens' MoveAddressToVpcResponse (Maybe Text)
moveAddressToVpcResponse_allocationId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\MoveAddressToVpcResponse' {Maybe Text
allocationId :: Maybe Text
$sel:allocationId:MoveAddressToVpcResponse' :: MoveAddressToVpcResponse -> Maybe Text
allocationId} -> Maybe Text
allocationId) (\s :: MoveAddressToVpcResponse
s@MoveAddressToVpcResponse' {} Maybe Text
a -> MoveAddressToVpcResponse
s {$sel:allocationId:MoveAddressToVpcResponse' :: Maybe Text
allocationId = Maybe Text
a} :: MoveAddressToVpcResponse)

-- | The status of the move of the IP address.
moveAddressToVpcResponse_status :: Lens.Lens' MoveAddressToVpcResponse (Prelude.Maybe AddressStatus)
moveAddressToVpcResponse_status :: Lens' MoveAddressToVpcResponse (Maybe AddressStatus)
moveAddressToVpcResponse_status = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\MoveAddressToVpcResponse' {Maybe AddressStatus
status :: Maybe AddressStatus
$sel:status:MoveAddressToVpcResponse' :: MoveAddressToVpcResponse -> Maybe AddressStatus
status} -> Maybe AddressStatus
status) (\s :: MoveAddressToVpcResponse
s@MoveAddressToVpcResponse' {} Maybe AddressStatus
a -> MoveAddressToVpcResponse
s {$sel:status:MoveAddressToVpcResponse' :: Maybe AddressStatus
status = Maybe AddressStatus
a} :: MoveAddressToVpcResponse)

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

instance Prelude.NFData MoveAddressToVpcResponse where
  rnf :: MoveAddressToVpcResponse -> ()
rnf MoveAddressToVpcResponse' {Int
Maybe Text
Maybe AddressStatus
httpStatus :: Int
status :: Maybe AddressStatus
allocationId :: Maybe Text
$sel:httpStatus:MoveAddressToVpcResponse' :: MoveAddressToVpcResponse -> Int
$sel:status:MoveAddressToVpcResponse' :: MoveAddressToVpcResponse -> Maybe AddressStatus
$sel:allocationId:MoveAddressToVpcResponse' :: MoveAddressToVpcResponse -> Maybe Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
allocationId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe AddressStatus
status
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus