{-# 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.SageMaker.DescribeWorkteam
-- 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 information about a specific work team. You can see information
-- such as the create date, the last updated date, membership information,
-- and the work team\'s Amazon Resource Name (ARN).
module Amazonka.SageMaker.DescribeWorkteam
  ( -- * Creating a Request
    DescribeWorkteam (..),
    newDescribeWorkteam,

    -- * Request Lenses
    describeWorkteam_workteamName,

    -- * Destructuring the Response
    DescribeWorkteamResponse (..),
    newDescribeWorkteamResponse,

    -- * Response Lenses
    describeWorkteamResponse_httpStatus,
    describeWorkteamResponse_workteam,
  )
where

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

-- | /See:/ 'newDescribeWorkteam' smart constructor.
data DescribeWorkteam = DescribeWorkteam'
  { -- | The name of the work team to return a description of.
    DescribeWorkteam -> Text
workteamName :: Prelude.Text
  }
  deriving (DescribeWorkteam -> DescribeWorkteam -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeWorkteam -> DescribeWorkteam -> Bool
$c/= :: DescribeWorkteam -> DescribeWorkteam -> Bool
== :: DescribeWorkteam -> DescribeWorkteam -> Bool
$c== :: DescribeWorkteam -> DescribeWorkteam -> Bool
Prelude.Eq, ReadPrec [DescribeWorkteam]
ReadPrec DescribeWorkteam
Int -> ReadS DescribeWorkteam
ReadS [DescribeWorkteam]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeWorkteam]
$creadListPrec :: ReadPrec [DescribeWorkteam]
readPrec :: ReadPrec DescribeWorkteam
$creadPrec :: ReadPrec DescribeWorkteam
readList :: ReadS [DescribeWorkteam]
$creadList :: ReadS [DescribeWorkteam]
readsPrec :: Int -> ReadS DescribeWorkteam
$creadsPrec :: Int -> ReadS DescribeWorkteam
Prelude.Read, Int -> DescribeWorkteam -> ShowS
[DescribeWorkteam] -> ShowS
DescribeWorkteam -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeWorkteam] -> ShowS
$cshowList :: [DescribeWorkteam] -> ShowS
show :: DescribeWorkteam -> String
$cshow :: DescribeWorkteam -> String
showsPrec :: Int -> DescribeWorkteam -> ShowS
$cshowsPrec :: Int -> DescribeWorkteam -> ShowS
Prelude.Show, forall x. Rep DescribeWorkteam x -> DescribeWorkteam
forall x. DescribeWorkteam -> Rep DescribeWorkteam x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DescribeWorkteam x -> DescribeWorkteam
$cfrom :: forall x. DescribeWorkteam -> Rep DescribeWorkteam x
Prelude.Generic)

-- |
-- Create a value of 'DescribeWorkteam' 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:
--
-- 'workteamName', 'describeWorkteam_workteamName' - The name of the work team to return a description of.
newDescribeWorkteam ::
  -- | 'workteamName'
  Prelude.Text ->
  DescribeWorkteam
newDescribeWorkteam :: Text -> DescribeWorkteam
newDescribeWorkteam Text
pWorkteamName_ =
  DescribeWorkteam' {$sel:workteamName:DescribeWorkteam' :: Text
workteamName = Text
pWorkteamName_}

-- | The name of the work team to return a description of.
describeWorkteam_workteamName :: Lens.Lens' DescribeWorkteam Prelude.Text
describeWorkteam_workteamName :: Lens' DescribeWorkteam Text
describeWorkteam_workteamName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeWorkteam' {Text
workteamName :: Text
$sel:workteamName:DescribeWorkteam' :: DescribeWorkteam -> Text
workteamName} -> Text
workteamName) (\s :: DescribeWorkteam
s@DescribeWorkteam' {} Text
a -> DescribeWorkteam
s {$sel:workteamName:DescribeWorkteam' :: Text
workteamName = Text
a} :: DescribeWorkteam)

instance Core.AWSRequest DescribeWorkteam where
  type
    AWSResponse DescribeWorkteam =
      DescribeWorkteamResponse
  request :: (Service -> Service)
-> DescribeWorkteam -> Request DescribeWorkteam
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 DescribeWorkteam
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse DescribeWorkteam)))
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 -> Workteam -> DescribeWorkteamResponse
DescribeWorkteamResponse'
            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
"Workteam")
      )

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

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

instance Data.ToHeaders DescribeWorkteam where
  toHeaders :: DescribeWorkteam -> 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
"SageMaker.DescribeWorkteam" :: 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 DescribeWorkteam where
  toJSON :: DescribeWorkteam -> Value
toJSON DescribeWorkteam' {Text
workteamName :: Text
$sel:workteamName:DescribeWorkteam' :: DescribeWorkteam -> Text
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [forall a. a -> Maybe a
Prelude.Just (Key
"WorkteamName" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
workteamName)]
      )

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

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

-- | /See:/ 'newDescribeWorkteamResponse' smart constructor.
data DescribeWorkteamResponse = DescribeWorkteamResponse'
  { -- | The response's http status code.
    DescribeWorkteamResponse -> Int
httpStatus :: Prelude.Int,
    -- | A @Workteam@ instance that contains information about the work team.
    DescribeWorkteamResponse -> Workteam
workteam :: Workteam
  }
  deriving (DescribeWorkteamResponse -> DescribeWorkteamResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeWorkteamResponse -> DescribeWorkteamResponse -> Bool
$c/= :: DescribeWorkteamResponse -> DescribeWorkteamResponse -> Bool
== :: DescribeWorkteamResponse -> DescribeWorkteamResponse -> Bool
$c== :: DescribeWorkteamResponse -> DescribeWorkteamResponse -> Bool
Prelude.Eq, ReadPrec [DescribeWorkteamResponse]
ReadPrec DescribeWorkteamResponse
Int -> ReadS DescribeWorkteamResponse
ReadS [DescribeWorkteamResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeWorkteamResponse]
$creadListPrec :: ReadPrec [DescribeWorkteamResponse]
readPrec :: ReadPrec DescribeWorkteamResponse
$creadPrec :: ReadPrec DescribeWorkteamResponse
readList :: ReadS [DescribeWorkteamResponse]
$creadList :: ReadS [DescribeWorkteamResponse]
readsPrec :: Int -> ReadS DescribeWorkteamResponse
$creadsPrec :: Int -> ReadS DescribeWorkteamResponse
Prelude.Read, Int -> DescribeWorkteamResponse -> ShowS
[DescribeWorkteamResponse] -> ShowS
DescribeWorkteamResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeWorkteamResponse] -> ShowS
$cshowList :: [DescribeWorkteamResponse] -> ShowS
show :: DescribeWorkteamResponse -> String
$cshow :: DescribeWorkteamResponse -> String
showsPrec :: Int -> DescribeWorkteamResponse -> ShowS
$cshowsPrec :: Int -> DescribeWorkteamResponse -> ShowS
Prelude.Show, forall x.
Rep DescribeWorkteamResponse x -> DescribeWorkteamResponse
forall x.
DescribeWorkteamResponse -> Rep DescribeWorkteamResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeWorkteamResponse x -> DescribeWorkteamResponse
$cfrom :: forall x.
DescribeWorkteamResponse -> Rep DescribeWorkteamResponse x
Prelude.Generic)

-- |
-- Create a value of 'DescribeWorkteamResponse' 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', 'describeWorkteamResponse_httpStatus' - The response's http status code.
--
-- 'workteam', 'describeWorkteamResponse_workteam' - A @Workteam@ instance that contains information about the work team.
newDescribeWorkteamResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  -- | 'workteam'
  Workteam ->
  DescribeWorkteamResponse
newDescribeWorkteamResponse :: Int -> Workteam -> DescribeWorkteamResponse
newDescribeWorkteamResponse Int
pHttpStatus_ Workteam
pWorkteam_ =
  DescribeWorkteamResponse'
    { $sel:httpStatus:DescribeWorkteamResponse' :: Int
httpStatus =
        Int
pHttpStatus_,
      $sel:workteam:DescribeWorkteamResponse' :: Workteam
workteam = Workteam
pWorkteam_
    }

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

-- | A @Workteam@ instance that contains information about the work team.
describeWorkteamResponse_workteam :: Lens.Lens' DescribeWorkteamResponse Workteam
describeWorkteamResponse_workteam :: Lens' DescribeWorkteamResponse Workteam
describeWorkteamResponse_workteam = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeWorkteamResponse' {Workteam
workteam :: Workteam
$sel:workteam:DescribeWorkteamResponse' :: DescribeWorkteamResponse -> Workteam
workteam} -> Workteam
workteam) (\s :: DescribeWorkteamResponse
s@DescribeWorkteamResponse' {} Workteam
a -> DescribeWorkteamResponse
s {$sel:workteam:DescribeWorkteamResponse' :: Workteam
workteam = Workteam
a} :: DescribeWorkteamResponse)

instance Prelude.NFData DescribeWorkteamResponse where
  rnf :: DescribeWorkteamResponse -> ()
rnf DescribeWorkteamResponse' {Int
Workteam
workteam :: Workteam
httpStatus :: Int
$sel:workteam:DescribeWorkteamResponse' :: DescribeWorkteamResponse -> Workteam
$sel:httpStatus:DescribeWorkteamResponse' :: DescribeWorkteamResponse -> 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 Workteam
workteam