{-# 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.ChimeSDKMessaging.GetMessagingSessionEndpoint -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- The details of the endpoint for the messaging session. module Amazonka.ChimeSDKMessaging.GetMessagingSessionEndpoint ( -- * Creating a Request GetMessagingSessionEndpoint (..), newGetMessagingSessionEndpoint, -- * Destructuring the Response GetMessagingSessionEndpointResponse (..), newGetMessagingSessionEndpointResponse, -- * Response Lenses getMessagingSessionEndpointResponse_endpoint, getMessagingSessionEndpointResponse_httpStatus, ) where import Amazonka.ChimeSDKMessaging.Types 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 -- | /See:/ 'newGetMessagingSessionEndpoint' smart constructor. data GetMessagingSessionEndpoint = GetMessagingSessionEndpoint' { } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'GetMessagingSessionEndpoint' with all optional fields omitted. -- -- Use or to modify other optional fields. newGetMessagingSessionEndpoint :: GetMessagingSessionEndpoint newGetMessagingSessionEndpoint = GetMessagingSessionEndpoint' instance Core.AWSRequest GetMessagingSessionEndpoint where type AWSResponse GetMessagingSessionEndpoint = GetMessagingSessionEndpointResponse request overrides = Request.get (overrides defaultService) response = Response.receiveJSON ( \s h x -> GetMessagingSessionEndpointResponse' Prelude.<$> (x Data..?> "Endpoint") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable GetMessagingSessionEndpoint where hashWithSalt _salt _ = _salt `Prelude.hashWithSalt` () instance Prelude.NFData GetMessagingSessionEndpoint where rnf _ = () instance Data.ToHeaders GetMessagingSessionEndpoint where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath GetMessagingSessionEndpoint where toPath = Prelude.const "/endpoints/messaging-session" instance Data.ToQuery GetMessagingSessionEndpoint where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newGetMessagingSessionEndpointResponse' smart constructor. data GetMessagingSessionEndpointResponse = GetMessagingSessionEndpointResponse' { -- | The endpoint returned in the response. endpoint :: Prelude.Maybe MessagingSessionEndpoint, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'GetMessagingSessionEndpointResponse' 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: -- -- 'endpoint', 'getMessagingSessionEndpointResponse_endpoint' - The endpoint returned in the response. -- -- 'httpStatus', 'getMessagingSessionEndpointResponse_httpStatus' - The response's http status code. newGetMessagingSessionEndpointResponse :: -- | 'httpStatus' Prelude.Int -> GetMessagingSessionEndpointResponse newGetMessagingSessionEndpointResponse pHttpStatus_ = GetMessagingSessionEndpointResponse' { endpoint = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The endpoint returned in the response. getMessagingSessionEndpointResponse_endpoint :: Lens.Lens' GetMessagingSessionEndpointResponse (Prelude.Maybe MessagingSessionEndpoint) getMessagingSessionEndpointResponse_endpoint = Lens.lens (\GetMessagingSessionEndpointResponse' {endpoint} -> endpoint) (\s@GetMessagingSessionEndpointResponse' {} a -> s {endpoint = a} :: GetMessagingSessionEndpointResponse) -- | The response's http status code. getMessagingSessionEndpointResponse_httpStatus :: Lens.Lens' GetMessagingSessionEndpointResponse Prelude.Int getMessagingSessionEndpointResponse_httpStatus = Lens.lens (\GetMessagingSessionEndpointResponse' {httpStatus} -> httpStatus) (\s@GetMessagingSessionEndpointResponse' {} a -> s {httpStatus = a} :: GetMessagingSessionEndpointResponse) instance Prelude.NFData GetMessagingSessionEndpointResponse where rnf GetMessagingSessionEndpointResponse' {..} = Prelude.rnf endpoint `Prelude.seq` Prelude.rnf httpStatus