{-# 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.Lightsail.GetDisk
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Returns information about a specific block storage disk.
module Amazonka.Lightsail.GetDisk
  ( -- * Creating a Request
    GetDisk (..),
    newGetDisk,

    -- * Request Lenses
    getDisk_diskName,

    -- * Destructuring the Response
    GetDiskResponse (..),
    newGetDiskResponse,

    -- * Response Lenses
    getDiskResponse_disk,
    getDiskResponse_httpStatus,
  )
where

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

-- | /See:/ 'newGetDisk' smart constructor.
data GetDisk = GetDisk'
  { -- | The name of the disk (e.g., @my-disk@).
    GetDisk -> Text
diskName :: Prelude.Text
  }
  deriving (GetDisk -> GetDisk -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: GetDisk -> GetDisk -> Bool
$c/= :: GetDisk -> GetDisk -> Bool
== :: GetDisk -> GetDisk -> Bool
$c== :: GetDisk -> GetDisk -> Bool
Prelude.Eq, ReadPrec [GetDisk]
ReadPrec GetDisk
Int -> ReadS GetDisk
ReadS [GetDisk]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [GetDisk]
$creadListPrec :: ReadPrec [GetDisk]
readPrec :: ReadPrec GetDisk
$creadPrec :: ReadPrec GetDisk
readList :: ReadS [GetDisk]
$creadList :: ReadS [GetDisk]
readsPrec :: Int -> ReadS GetDisk
$creadsPrec :: Int -> ReadS GetDisk
Prelude.Read, Int -> GetDisk -> ShowS
[GetDisk] -> ShowS
GetDisk -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [GetDisk] -> ShowS
$cshowList :: [GetDisk] -> ShowS
show :: GetDisk -> String
$cshow :: GetDisk -> String
showsPrec :: Int -> GetDisk -> ShowS
$cshowsPrec :: Int -> GetDisk -> ShowS
Prelude.Show, forall x. Rep GetDisk x -> GetDisk
forall x. GetDisk -> Rep GetDisk x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep GetDisk x -> GetDisk
$cfrom :: forall x. GetDisk -> Rep GetDisk x
Prelude.Generic)

-- |
-- Create a value of 'GetDisk' 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:
--
-- 'diskName', 'getDisk_diskName' - The name of the disk (e.g., @my-disk@).
newGetDisk ::
  -- | 'diskName'
  Prelude.Text ->
  GetDisk
newGetDisk :: Text -> GetDisk
newGetDisk Text
pDiskName_ =
  GetDisk' {$sel:diskName:GetDisk' :: Text
diskName = Text
pDiskName_}

-- | The name of the disk (e.g., @my-disk@).
getDisk_diskName :: Lens.Lens' GetDisk Prelude.Text
getDisk_diskName :: Lens' GetDisk Text
getDisk_diskName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetDisk' {Text
diskName :: Text
$sel:diskName:GetDisk' :: GetDisk -> Text
diskName} -> Text
diskName) (\s :: GetDisk
s@GetDisk' {} Text
a -> GetDisk
s {$sel:diskName:GetDisk' :: Text
diskName = Text
a} :: GetDisk)

instance Core.AWSRequest GetDisk where
  type AWSResponse GetDisk = GetDiskResponse
  request :: (Service -> Service) -> GetDisk -> Request GetDisk
request Service -> Service
overrides =
    forall a. (ToRequest a, ToJSON a) => Service -> a -> Request a
Request.postJSON (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy GetDisk
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse GetDisk)))
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 Disk -> Int -> GetDiskResponse
GetDiskResponse'
            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
"disk")
            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 GetDisk where
  hashWithSalt :: Int -> GetDisk -> Int
hashWithSalt Int
_salt GetDisk' {Text
diskName :: Text
$sel:diskName:GetDisk' :: GetDisk -> Text
..} =
    Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
diskName

instance Prelude.NFData GetDisk where
  rnf :: GetDisk -> ()
rnf GetDisk' {Text
diskName :: Text
$sel:diskName:GetDisk' :: GetDisk -> Text
..} = forall a. NFData a => a -> ()
Prelude.rnf Text
diskName

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

instance Data.ToJSON GetDisk where
  toJSON :: GetDisk -> Value
toJSON GetDisk' {Text
diskName :: Text
$sel:diskName:GetDisk' :: GetDisk -> Text
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [forall a. a -> Maybe a
Prelude.Just (Key
"diskName" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
diskName)]
      )

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

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

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

-- |
-- Create a value of 'GetDiskResponse' 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:
--
-- 'disk', 'getDiskResponse_disk' - An object containing information about the disk.
--
-- 'httpStatus', 'getDiskResponse_httpStatus' - The response's http status code.
newGetDiskResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  GetDiskResponse
newGetDiskResponse :: Int -> GetDiskResponse
newGetDiskResponse Int
pHttpStatus_ =
  GetDiskResponse'
    { $sel:disk:GetDiskResponse' :: Maybe Disk
disk = forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:GetDiskResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | An object containing information about the disk.
getDiskResponse_disk :: Lens.Lens' GetDiskResponse (Prelude.Maybe Disk)
getDiskResponse_disk :: Lens' GetDiskResponse (Maybe Disk)
getDiskResponse_disk = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetDiskResponse' {Maybe Disk
disk :: Maybe Disk
$sel:disk:GetDiskResponse' :: GetDiskResponse -> Maybe Disk
disk} -> Maybe Disk
disk) (\s :: GetDiskResponse
s@GetDiskResponse' {} Maybe Disk
a -> GetDiskResponse
s {$sel:disk:GetDiskResponse' :: Maybe Disk
disk = Maybe Disk
a} :: GetDiskResponse)

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

instance Prelude.NFData GetDiskResponse where
  rnf :: GetDiskResponse -> ()
rnf GetDiskResponse' {Int
Maybe Disk
httpStatus :: Int
disk :: Maybe Disk
$sel:httpStatus:GetDiskResponse' :: GetDiskResponse -> Int
$sel:disk:GetDiskResponse' :: GetDiskResponse -> Maybe Disk
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Disk
disk
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus