{-# 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.EMR.DeleteStudio -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Removes an Amazon EMR Studio from the Studio metadata store. module Amazonka.EMR.DeleteStudio ( -- * Creating a Request DeleteStudio (..), newDeleteStudio, -- * Request Lenses deleteStudio_studioId, -- * Destructuring the Response DeleteStudioResponse (..), newDeleteStudioResponse, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.EMR.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newDeleteStudio' smart constructor. data DeleteStudio = DeleteStudio' { -- | The ID of the Amazon EMR Studio. studioId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteStudio' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'studioId', 'deleteStudio_studioId' - The ID of the Amazon EMR Studio. newDeleteStudio :: -- | 'studioId' Prelude.Text -> DeleteStudio newDeleteStudio pStudioId_ = DeleteStudio' {studioId = pStudioId_} -- | The ID of the Amazon EMR Studio. deleteStudio_studioId :: Lens.Lens' DeleteStudio Prelude.Text deleteStudio_studioId = Lens.lens (\DeleteStudio' {studioId} -> studioId) (\s@DeleteStudio' {} a -> s {studioId = a} :: DeleteStudio) instance Core.AWSRequest DeleteStudio where type AWSResponse DeleteStudio = DeleteStudioResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveNull DeleteStudioResponse' instance Prelude.Hashable DeleteStudio where hashWithSalt _salt DeleteStudio' {..} = _salt `Prelude.hashWithSalt` studioId instance Prelude.NFData DeleteStudio where rnf DeleteStudio' {..} = Prelude.rnf studioId instance Data.ToHeaders DeleteStudio where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "ElasticMapReduce.DeleteStudio" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DeleteStudio where toJSON DeleteStudio' {..} = Data.object ( Prelude.catMaybes [Prelude.Just ("StudioId" Data..= studioId)] ) instance Data.ToPath DeleteStudio where toPath = Prelude.const "/" instance Data.ToQuery DeleteStudio where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDeleteStudioResponse' smart constructor. data DeleteStudioResponse = DeleteStudioResponse' { } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteStudioResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. newDeleteStudioResponse :: DeleteStudioResponse newDeleteStudioResponse = DeleteStudioResponse' instance Prelude.NFData DeleteStudioResponse where rnf _ = ()