{-# 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.IVS.DeleteChannel -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Deletes the specified channel and its associated stream keys. -- -- If you try to delete a live channel, you will get an error (409 -- ConflictException). To delete a channel that is live, call StopStream, -- wait for the Amazon EventBridge \"Stream End\" event (to verify that the -- stream\'s state was changed from Live to Offline), then call -- DeleteChannel. (See -- .) module Amazonka.IVS.DeleteChannel ( -- * Creating a Request DeleteChannel (..), newDeleteChannel, -- * Request Lenses deleteChannel_arn, -- * Destructuring the Response DeleteChannelResponse (..), newDeleteChannelResponse, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.IVS.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newDeleteChannel' smart constructor. data DeleteChannel = DeleteChannel' { -- | ARN of the channel to be deleted. arn :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteChannel' 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: -- -- 'arn', 'deleteChannel_arn' - ARN of the channel to be deleted. newDeleteChannel :: -- | 'arn' Prelude.Text -> DeleteChannel newDeleteChannel pArn_ = DeleteChannel' {arn = pArn_} -- | ARN of the channel to be deleted. deleteChannel_arn :: Lens.Lens' DeleteChannel Prelude.Text deleteChannel_arn = Lens.lens (\DeleteChannel' {arn} -> arn) (\s@DeleteChannel' {} a -> s {arn = a} :: DeleteChannel) instance Core.AWSRequest DeleteChannel where type AWSResponse DeleteChannel = DeleteChannelResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveNull DeleteChannelResponse' instance Prelude.Hashable DeleteChannel where hashWithSalt _salt DeleteChannel' {..} = _salt `Prelude.hashWithSalt` arn instance Prelude.NFData DeleteChannel where rnf DeleteChannel' {..} = Prelude.rnf arn instance Data.ToHeaders DeleteChannel where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DeleteChannel where toJSON DeleteChannel' {..} = Data.object ( Prelude.catMaybes [Prelude.Just ("arn" Data..= arn)] ) instance Data.ToPath DeleteChannel where toPath = Prelude.const "/DeleteChannel" instance Data.ToQuery DeleteChannel where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDeleteChannelResponse' smart constructor. data DeleteChannelResponse = DeleteChannelResponse' { } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteChannelResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. newDeleteChannelResponse :: DeleteChannelResponse newDeleteChannelResponse = DeleteChannelResponse' instance Prelude.NFData DeleteChannelResponse where rnf _ = ()