{-# 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.Nimble.DeleteStreamingSession -- 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 streaming session resource. -- -- After invoking this operation, use GetStreamingSession to poll the -- resource until it transitions to a @DELETED@ state. -- -- A streaming session will count against your streaming session quota -- until it is marked @DELETED@. module Amazonka.Nimble.DeleteStreamingSession ( -- * Creating a Request DeleteStreamingSession (..), newDeleteStreamingSession, -- * Request Lenses deleteStreamingSession_clientToken, deleteStreamingSession_sessionId, deleteStreamingSession_studioId, -- * Destructuring the Response DeleteStreamingSessionResponse (..), newDeleteStreamingSessionResponse, -- * Response Lenses deleteStreamingSessionResponse_session, deleteStreamingSessionResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.Nimble.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newDeleteStreamingSession' smart constructor. data DeleteStreamingSession = DeleteStreamingSession' { -- | Unique, case-sensitive identifier that you provide to ensure the -- idempotency of the request. If you don’t specify a client token, the -- Amazon Web Services SDK automatically generates a client token and uses -- it for the request to ensure idempotency. clientToken :: Prelude.Maybe Prelude.Text, -- | The streaming session ID. sessionId :: Prelude.Text, -- | The studio ID. studioId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteStreamingSession' 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: -- -- 'clientToken', 'deleteStreamingSession_clientToken' - Unique, case-sensitive identifier that you provide to ensure the -- idempotency of the request. If you don’t specify a client token, the -- Amazon Web Services SDK automatically generates a client token and uses -- it for the request to ensure idempotency. -- -- 'sessionId', 'deleteStreamingSession_sessionId' - The streaming session ID. -- -- 'studioId', 'deleteStreamingSession_studioId' - The studio ID. newDeleteStreamingSession :: -- | 'sessionId' Prelude.Text -> -- | 'studioId' Prelude.Text -> DeleteStreamingSession newDeleteStreamingSession pSessionId_ pStudioId_ = DeleteStreamingSession' { clientToken = Prelude.Nothing, sessionId = pSessionId_, studioId = pStudioId_ } -- | Unique, case-sensitive identifier that you provide to ensure the -- idempotency of the request. If you don’t specify a client token, the -- Amazon Web Services SDK automatically generates a client token and uses -- it for the request to ensure idempotency. deleteStreamingSession_clientToken :: Lens.Lens' DeleteStreamingSession (Prelude.Maybe Prelude.Text) deleteStreamingSession_clientToken = Lens.lens (\DeleteStreamingSession' {clientToken} -> clientToken) (\s@DeleteStreamingSession' {} a -> s {clientToken = a} :: DeleteStreamingSession) -- | The streaming session ID. deleteStreamingSession_sessionId :: Lens.Lens' DeleteStreamingSession Prelude.Text deleteStreamingSession_sessionId = Lens.lens (\DeleteStreamingSession' {sessionId} -> sessionId) (\s@DeleteStreamingSession' {} a -> s {sessionId = a} :: DeleteStreamingSession) -- | The studio ID. deleteStreamingSession_studioId :: Lens.Lens' DeleteStreamingSession Prelude.Text deleteStreamingSession_studioId = Lens.lens (\DeleteStreamingSession' {studioId} -> studioId) (\s@DeleteStreamingSession' {} a -> s {studioId = a} :: DeleteStreamingSession) instance Core.AWSRequest DeleteStreamingSession where type AWSResponse DeleteStreamingSession = DeleteStreamingSessionResponse request overrides = Request.delete (overrides defaultService) response = Response.receiveJSON ( \s h x -> DeleteStreamingSessionResponse' Prelude.<$> (x Data..?> "session") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DeleteStreamingSession where hashWithSalt _salt DeleteStreamingSession' {..} = _salt `Prelude.hashWithSalt` clientToken `Prelude.hashWithSalt` sessionId `Prelude.hashWithSalt` studioId instance Prelude.NFData DeleteStreamingSession where rnf DeleteStreamingSession' {..} = Prelude.rnf clientToken `Prelude.seq` Prelude.rnf sessionId `Prelude.seq` Prelude.rnf studioId instance Data.ToHeaders DeleteStreamingSession where toHeaders DeleteStreamingSession' {..} = Prelude.mconcat [ "X-Amz-Client-Token" Data.=# clientToken, "Content-Type" Data.=# ("application/x-amz-json-1.1" :: Prelude.ByteString) ] instance Data.ToPath DeleteStreamingSession where toPath DeleteStreamingSession' {..} = Prelude.mconcat [ "/2020-08-01/studios/", Data.toBS studioId, "/streaming-sessions/", Data.toBS sessionId ] instance Data.ToQuery DeleteStreamingSession where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDeleteStreamingSessionResponse' smart constructor. data DeleteStreamingSessionResponse = DeleteStreamingSessionResponse' { -- | The session. session :: Prelude.Maybe StreamingSession, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteStreamingSessionResponse' 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: -- -- 'session', 'deleteStreamingSessionResponse_session' - The session. -- -- 'httpStatus', 'deleteStreamingSessionResponse_httpStatus' - The response's http status code. newDeleteStreamingSessionResponse :: -- | 'httpStatus' Prelude.Int -> DeleteStreamingSessionResponse newDeleteStreamingSessionResponse pHttpStatus_ = DeleteStreamingSessionResponse' { session = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The session. deleteStreamingSessionResponse_session :: Lens.Lens' DeleteStreamingSessionResponse (Prelude.Maybe StreamingSession) deleteStreamingSessionResponse_session = Lens.lens (\DeleteStreamingSessionResponse' {session} -> session) (\s@DeleteStreamingSessionResponse' {} a -> s {session = a} :: DeleteStreamingSessionResponse) -- | The response's http status code. deleteStreamingSessionResponse_httpStatus :: Lens.Lens' DeleteStreamingSessionResponse Prelude.Int deleteStreamingSessionResponse_httpStatus = Lens.lens (\DeleteStreamingSessionResponse' {httpStatus} -> httpStatus) (\s@DeleteStreamingSessionResponse' {} a -> s {httpStatus = a} :: DeleteStreamingSessionResponse) instance Prelude.NFData DeleteStreamingSessionResponse where rnf DeleteStreamingSessionResponse' {..} = Prelude.rnf session `Prelude.seq` Prelude.rnf httpStatus