{-# 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.HealthLake.DescribeFHIRDatastore
-- 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 properties associated with the FHIR Data Store, including the
-- Data Store ID, Data Store ARN, Data Store name, Data Store status,
-- created at, Data Store type version, and Data Store endpoint.
module Amazonka.HealthLake.DescribeFHIRDatastore
  ( -- * Creating a Request
    DescribeFHIRDatastore (..),
    newDescribeFHIRDatastore,

    -- * Request Lenses
    describeFHIRDatastore_datastoreId,

    -- * Destructuring the Response
    DescribeFHIRDatastoreResponse (..),
    newDescribeFHIRDatastoreResponse,

    -- * Response Lenses
    describeFHIRDatastoreResponse_httpStatus,
    describeFHIRDatastoreResponse_datastoreProperties,
  )
where

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

-- | /See:/ 'newDescribeFHIRDatastore' smart constructor.
data DescribeFHIRDatastore = DescribeFHIRDatastore'
  { -- | The AWS-generated Data Store id. This is part of the
    -- ‘CreateFHIRDatastore’ output.
    DescribeFHIRDatastore -> Maybe Text
datastoreId :: Prelude.Maybe Prelude.Text
  }
  deriving (DescribeFHIRDatastore -> DescribeFHIRDatastore -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeFHIRDatastore -> DescribeFHIRDatastore -> Bool
$c/= :: DescribeFHIRDatastore -> DescribeFHIRDatastore -> Bool
== :: DescribeFHIRDatastore -> DescribeFHIRDatastore -> Bool
$c== :: DescribeFHIRDatastore -> DescribeFHIRDatastore -> Bool
Prelude.Eq, ReadPrec [DescribeFHIRDatastore]
ReadPrec DescribeFHIRDatastore
Int -> ReadS DescribeFHIRDatastore
ReadS [DescribeFHIRDatastore]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeFHIRDatastore]
$creadListPrec :: ReadPrec [DescribeFHIRDatastore]
readPrec :: ReadPrec DescribeFHIRDatastore
$creadPrec :: ReadPrec DescribeFHIRDatastore
readList :: ReadS [DescribeFHIRDatastore]
$creadList :: ReadS [DescribeFHIRDatastore]
readsPrec :: Int -> ReadS DescribeFHIRDatastore
$creadsPrec :: Int -> ReadS DescribeFHIRDatastore
Prelude.Read, Int -> DescribeFHIRDatastore -> ShowS
[DescribeFHIRDatastore] -> ShowS
DescribeFHIRDatastore -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeFHIRDatastore] -> ShowS
$cshowList :: [DescribeFHIRDatastore] -> ShowS
show :: DescribeFHIRDatastore -> String
$cshow :: DescribeFHIRDatastore -> String
showsPrec :: Int -> DescribeFHIRDatastore -> ShowS
$cshowsPrec :: Int -> DescribeFHIRDatastore -> ShowS
Prelude.Show, forall x. Rep DescribeFHIRDatastore x -> DescribeFHIRDatastore
forall x. DescribeFHIRDatastore -> Rep DescribeFHIRDatastore x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DescribeFHIRDatastore x -> DescribeFHIRDatastore
$cfrom :: forall x. DescribeFHIRDatastore -> Rep DescribeFHIRDatastore x
Prelude.Generic)

-- |
-- Create a value of 'DescribeFHIRDatastore' 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:
--
-- 'datastoreId', 'describeFHIRDatastore_datastoreId' - The AWS-generated Data Store id. This is part of the
-- ‘CreateFHIRDatastore’ output.
newDescribeFHIRDatastore ::
  DescribeFHIRDatastore
newDescribeFHIRDatastore :: DescribeFHIRDatastore
newDescribeFHIRDatastore =
  DescribeFHIRDatastore'
    { $sel:datastoreId:DescribeFHIRDatastore' :: Maybe Text
datastoreId =
        forall a. Maybe a
Prelude.Nothing
    }

-- | The AWS-generated Data Store id. This is part of the
-- ‘CreateFHIRDatastore’ output.
describeFHIRDatastore_datastoreId :: Lens.Lens' DescribeFHIRDatastore (Prelude.Maybe Prelude.Text)
describeFHIRDatastore_datastoreId :: Lens' DescribeFHIRDatastore (Maybe Text)
describeFHIRDatastore_datastoreId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeFHIRDatastore' {Maybe Text
datastoreId :: Maybe Text
$sel:datastoreId:DescribeFHIRDatastore' :: DescribeFHIRDatastore -> Maybe Text
datastoreId} -> Maybe Text
datastoreId) (\s :: DescribeFHIRDatastore
s@DescribeFHIRDatastore' {} Maybe Text
a -> DescribeFHIRDatastore
s {$sel:datastoreId:DescribeFHIRDatastore' :: Maybe Text
datastoreId = Maybe Text
a} :: DescribeFHIRDatastore)

instance Core.AWSRequest DescribeFHIRDatastore where
  type
    AWSResponse DescribeFHIRDatastore =
      DescribeFHIRDatastoreResponse
  request :: (Service -> Service)
-> DescribeFHIRDatastore -> Request DescribeFHIRDatastore
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 DescribeFHIRDatastore
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse DescribeFHIRDatastore)))
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 ->
          Int -> DatastoreProperties -> DescribeFHIRDatastoreResponse
DescribeFHIRDatastoreResponse'
            forall (f :: * -> *) a b. Functor 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
"DatastoreProperties")
      )

instance Prelude.Hashable DescribeFHIRDatastore where
  hashWithSalt :: Int -> DescribeFHIRDatastore -> Int
hashWithSalt Int
_salt DescribeFHIRDatastore' {Maybe Text
datastoreId :: Maybe Text
$sel:datastoreId:DescribeFHIRDatastore' :: DescribeFHIRDatastore -> Maybe Text
..} =
    Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
datastoreId

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

instance Data.ToHeaders DescribeFHIRDatastore where
  toHeaders :: DescribeFHIRDatastore -> 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
"HealthLake.DescribeFHIRDatastore" ::
                          Prelude.ByteString
                      ),
            HeaderName
"Content-Type"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.0" ::
                          Prelude.ByteString
                      )
          ]
      )

instance Data.ToJSON DescribeFHIRDatastore where
  toJSON :: DescribeFHIRDatastore -> Value
toJSON DescribeFHIRDatastore' {Maybe Text
datastoreId :: Maybe Text
$sel:datastoreId:DescribeFHIRDatastore' :: DescribeFHIRDatastore -> Maybe Text
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [(Key
"DatastoreId" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe Text
datastoreId]
      )

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

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

-- | /See:/ 'newDescribeFHIRDatastoreResponse' smart constructor.
data DescribeFHIRDatastoreResponse = DescribeFHIRDatastoreResponse'
  { -- | The response's http status code.
    DescribeFHIRDatastoreResponse -> Int
httpStatus :: Prelude.Int,
    -- | All properties associated with a Data Store, including the Data Store
    -- ID, Data Store ARN, Data Store name, Data Store status, created at, Data
    -- Store type version, and Data Store endpoint.
    DescribeFHIRDatastoreResponse -> DatastoreProperties
datastoreProperties :: DatastoreProperties
  }
  deriving (DescribeFHIRDatastoreResponse
-> DescribeFHIRDatastoreResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeFHIRDatastoreResponse
-> DescribeFHIRDatastoreResponse -> Bool
$c/= :: DescribeFHIRDatastoreResponse
-> DescribeFHIRDatastoreResponse -> Bool
== :: DescribeFHIRDatastoreResponse
-> DescribeFHIRDatastoreResponse -> Bool
$c== :: DescribeFHIRDatastoreResponse
-> DescribeFHIRDatastoreResponse -> Bool
Prelude.Eq, ReadPrec [DescribeFHIRDatastoreResponse]
ReadPrec DescribeFHIRDatastoreResponse
Int -> ReadS DescribeFHIRDatastoreResponse
ReadS [DescribeFHIRDatastoreResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeFHIRDatastoreResponse]
$creadListPrec :: ReadPrec [DescribeFHIRDatastoreResponse]
readPrec :: ReadPrec DescribeFHIRDatastoreResponse
$creadPrec :: ReadPrec DescribeFHIRDatastoreResponse
readList :: ReadS [DescribeFHIRDatastoreResponse]
$creadList :: ReadS [DescribeFHIRDatastoreResponse]
readsPrec :: Int -> ReadS DescribeFHIRDatastoreResponse
$creadsPrec :: Int -> ReadS DescribeFHIRDatastoreResponse
Prelude.Read, Int -> DescribeFHIRDatastoreResponse -> ShowS
[DescribeFHIRDatastoreResponse] -> ShowS
DescribeFHIRDatastoreResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeFHIRDatastoreResponse] -> ShowS
$cshowList :: [DescribeFHIRDatastoreResponse] -> ShowS
show :: DescribeFHIRDatastoreResponse -> String
$cshow :: DescribeFHIRDatastoreResponse -> String
showsPrec :: Int -> DescribeFHIRDatastoreResponse -> ShowS
$cshowsPrec :: Int -> DescribeFHIRDatastoreResponse -> ShowS
Prelude.Show, forall x.
Rep DescribeFHIRDatastoreResponse x
-> DescribeFHIRDatastoreResponse
forall x.
DescribeFHIRDatastoreResponse
-> Rep DescribeFHIRDatastoreResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeFHIRDatastoreResponse x
-> DescribeFHIRDatastoreResponse
$cfrom :: forall x.
DescribeFHIRDatastoreResponse
-> Rep DescribeFHIRDatastoreResponse x
Prelude.Generic)

-- |
-- Create a value of 'DescribeFHIRDatastoreResponse' 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:
--
-- 'httpStatus', 'describeFHIRDatastoreResponse_httpStatus' - The response's http status code.
--
-- 'datastoreProperties', 'describeFHIRDatastoreResponse_datastoreProperties' - All properties associated with a Data Store, including the Data Store
-- ID, Data Store ARN, Data Store name, Data Store status, created at, Data
-- Store type version, and Data Store endpoint.
newDescribeFHIRDatastoreResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  -- | 'datastoreProperties'
  DatastoreProperties ->
  DescribeFHIRDatastoreResponse
newDescribeFHIRDatastoreResponse :: Int -> DatastoreProperties -> DescribeFHIRDatastoreResponse
newDescribeFHIRDatastoreResponse
  Int
pHttpStatus_
  DatastoreProperties
pDatastoreProperties_ =
    DescribeFHIRDatastoreResponse'
      { $sel:httpStatus:DescribeFHIRDatastoreResponse' :: Int
httpStatus =
          Int
pHttpStatus_,
        $sel:datastoreProperties:DescribeFHIRDatastoreResponse' :: DatastoreProperties
datastoreProperties = DatastoreProperties
pDatastoreProperties_
      }

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

-- | All properties associated with a Data Store, including the Data Store
-- ID, Data Store ARN, Data Store name, Data Store status, created at, Data
-- Store type version, and Data Store endpoint.
describeFHIRDatastoreResponse_datastoreProperties :: Lens.Lens' DescribeFHIRDatastoreResponse DatastoreProperties
describeFHIRDatastoreResponse_datastoreProperties :: Lens' DescribeFHIRDatastoreResponse DatastoreProperties
describeFHIRDatastoreResponse_datastoreProperties = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeFHIRDatastoreResponse' {DatastoreProperties
datastoreProperties :: DatastoreProperties
$sel:datastoreProperties:DescribeFHIRDatastoreResponse' :: DescribeFHIRDatastoreResponse -> DatastoreProperties
datastoreProperties} -> DatastoreProperties
datastoreProperties) (\s :: DescribeFHIRDatastoreResponse
s@DescribeFHIRDatastoreResponse' {} DatastoreProperties
a -> DescribeFHIRDatastoreResponse
s {$sel:datastoreProperties:DescribeFHIRDatastoreResponse' :: DatastoreProperties
datastoreProperties = DatastoreProperties
a} :: DescribeFHIRDatastoreResponse)

instance Prelude.NFData DescribeFHIRDatastoreResponse where
  rnf :: DescribeFHIRDatastoreResponse -> ()
rnf DescribeFHIRDatastoreResponse' {Int
DatastoreProperties
datastoreProperties :: DatastoreProperties
httpStatus :: Int
$sel:datastoreProperties:DescribeFHIRDatastoreResponse' :: DescribeFHIRDatastoreResponse -> DatastoreProperties
$sel:httpStatus:DescribeFHIRDatastoreResponse' :: DescribeFHIRDatastoreResponse -> Int
..} =
    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 DatastoreProperties
datastoreProperties