{-# 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.IVSChat.GetRoom -- 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 the specified room. module Amazonka.IVSChat.GetRoom ( -- * Creating a Request GetRoom (..), newGetRoom, -- * Request Lenses getRoom_identifier, -- * Destructuring the Response GetRoomResponse (..), newGetRoomResponse, -- * Response Lenses getRoomResponse_arn, getRoomResponse_createTime, getRoomResponse_id, getRoomResponse_loggingConfigurationIdentifiers, getRoomResponse_maximumMessageLength, getRoomResponse_maximumMessageRatePerSecond, getRoomResponse_messageReviewHandler, getRoomResponse_name, getRoomResponse_tags, getRoomResponse_updateTime, getRoomResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.IVSChat.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newGetRoom' smart constructor. data GetRoom = GetRoom' { -- | Identifier of the room for which the configuration is to be retrieved. -- Currently this must be an ARN. identifier :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'GetRoom' 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: -- -- 'identifier', 'getRoom_identifier' - Identifier of the room for which the configuration is to be retrieved. -- Currently this must be an ARN. newGetRoom :: -- | 'identifier' Prelude.Text -> GetRoom newGetRoom pIdentifier_ = GetRoom' {identifier = pIdentifier_} -- | Identifier of the room for which the configuration is to be retrieved. -- Currently this must be an ARN. getRoom_identifier :: Lens.Lens' GetRoom Prelude.Text getRoom_identifier = Lens.lens (\GetRoom' {identifier} -> identifier) (\s@GetRoom' {} a -> s {identifier = a} :: GetRoom) instance Core.AWSRequest GetRoom where type AWSResponse GetRoom = GetRoomResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> GetRoomResponse' Prelude.<$> (x Data..?> "arn") Prelude.<*> (x Data..?> "createTime") Prelude.<*> (x Data..?> "id") Prelude.<*> ( x Data..?> "loggingConfigurationIdentifiers" Core..!@ Prelude.mempty ) Prelude.<*> (x Data..?> "maximumMessageLength") Prelude.<*> (x Data..?> "maximumMessageRatePerSecond") Prelude.<*> (x Data..?> "messageReviewHandler") Prelude.<*> (x Data..?> "name") Prelude.<*> (x Data..?> "tags" Core..!@ Prelude.mempty) Prelude.<*> (x Data..?> "updateTime") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable GetRoom where hashWithSalt _salt GetRoom' {..} = _salt `Prelude.hashWithSalt` identifier instance Prelude.NFData GetRoom where rnf GetRoom' {..} = Prelude.rnf identifier instance Data.ToHeaders GetRoom where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON GetRoom where toJSON GetRoom' {..} = Data.object ( Prelude.catMaybes [Prelude.Just ("identifier" Data..= identifier)] ) instance Data.ToPath GetRoom where toPath = Prelude.const "/GetRoom" instance Data.ToQuery GetRoom where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newGetRoomResponse' smart constructor. data GetRoomResponse = GetRoomResponse' { -- | Room ARN, from the request (if @identifier@ was an ARN). arn :: Prelude.Maybe Prelude.Text, -- | Time when the room was created. This is an ISO 8601 timestamp; /note -- that this is returned as a string/. createTime :: Prelude.Maybe Data.ISO8601, -- | Room ID, generated by the system. This is a relative identifier, the -- part of the ARN that uniquely identifies the room. id :: Prelude.Maybe Prelude.Text, -- | Array of logging configurations attached to the room. loggingConfigurationIdentifiers :: Prelude.Maybe [Prelude.Text], -- | Maximum number of characters in a single message. Messages are expected -- to be UTF-8 encoded and this limit applies specifically to -- rune\/code-point count, not number of bytes. Default: 500. maximumMessageLength :: Prelude.Maybe Prelude.Natural, -- | Maximum number of messages per second that can be sent to the room (by -- all clients). Default: 10. maximumMessageRatePerSecond :: Prelude.Maybe Prelude.Natural, -- | Configuration information for optional review of messages. messageReviewHandler :: Prelude.Maybe MessageReviewHandler, -- | Room name. The value does not need to be unique. name :: Prelude.Maybe Prelude.Text, -- | Tags attached to the resource. Array of maps, each of the form -- @string:string (key:value)@. tags :: Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text), -- | Time of the room’s last update. This is an ISO 8601 timestamp; /note -- that this is returned as a string/. updateTime :: Prelude.Maybe Data.ISO8601, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'GetRoomResponse' 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', 'getRoomResponse_arn' - Room ARN, from the request (if @identifier@ was an ARN). -- -- 'createTime', 'getRoomResponse_createTime' - Time when the room was created. This is an ISO 8601 timestamp; /note -- that this is returned as a string/. -- -- 'id', 'getRoomResponse_id' - Room ID, generated by the system. This is a relative identifier, the -- part of the ARN that uniquely identifies the room. -- -- 'loggingConfigurationIdentifiers', 'getRoomResponse_loggingConfigurationIdentifiers' - Array of logging configurations attached to the room. -- -- 'maximumMessageLength', 'getRoomResponse_maximumMessageLength' - Maximum number of characters in a single message. Messages are expected -- to be UTF-8 encoded and this limit applies specifically to -- rune\/code-point count, not number of bytes. Default: 500. -- -- 'maximumMessageRatePerSecond', 'getRoomResponse_maximumMessageRatePerSecond' - Maximum number of messages per second that can be sent to the room (by -- all clients). Default: 10. -- -- 'messageReviewHandler', 'getRoomResponse_messageReviewHandler' - Configuration information for optional review of messages. -- -- 'name', 'getRoomResponse_name' - Room name. The value does not need to be unique. -- -- 'tags', 'getRoomResponse_tags' - Tags attached to the resource. Array of maps, each of the form -- @string:string (key:value)@. -- -- 'updateTime', 'getRoomResponse_updateTime' - Time of the room’s last update. This is an ISO 8601 timestamp; /note -- that this is returned as a string/. -- -- 'httpStatus', 'getRoomResponse_httpStatus' - The response's http status code. newGetRoomResponse :: -- | 'httpStatus' Prelude.Int -> GetRoomResponse newGetRoomResponse pHttpStatus_ = GetRoomResponse' { arn = Prelude.Nothing, createTime = Prelude.Nothing, id = Prelude.Nothing, loggingConfigurationIdentifiers = Prelude.Nothing, maximumMessageLength = Prelude.Nothing, maximumMessageRatePerSecond = Prelude.Nothing, messageReviewHandler = Prelude.Nothing, name = Prelude.Nothing, tags = Prelude.Nothing, updateTime = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Room ARN, from the request (if @identifier@ was an ARN). getRoomResponse_arn :: Lens.Lens' GetRoomResponse (Prelude.Maybe Prelude.Text) getRoomResponse_arn = Lens.lens (\GetRoomResponse' {arn} -> arn) (\s@GetRoomResponse' {} a -> s {arn = a} :: GetRoomResponse) -- | Time when the room was created. This is an ISO 8601 timestamp; /note -- that this is returned as a string/. getRoomResponse_createTime :: Lens.Lens' GetRoomResponse (Prelude.Maybe Prelude.UTCTime) getRoomResponse_createTime = Lens.lens (\GetRoomResponse' {createTime} -> createTime) (\s@GetRoomResponse' {} a -> s {createTime = a} :: GetRoomResponse) Prelude.. Lens.mapping Data._Time -- | Room ID, generated by the system. This is a relative identifier, the -- part of the ARN that uniquely identifies the room. getRoomResponse_id :: Lens.Lens' GetRoomResponse (Prelude.Maybe Prelude.Text) getRoomResponse_id = Lens.lens (\GetRoomResponse' {id} -> id) (\s@GetRoomResponse' {} a -> s {id = a} :: GetRoomResponse) -- | Array of logging configurations attached to the room. getRoomResponse_loggingConfigurationIdentifiers :: Lens.Lens' GetRoomResponse (Prelude.Maybe [Prelude.Text]) getRoomResponse_loggingConfigurationIdentifiers = Lens.lens (\GetRoomResponse' {loggingConfigurationIdentifiers} -> loggingConfigurationIdentifiers) (\s@GetRoomResponse' {} a -> s {loggingConfigurationIdentifiers = a} :: GetRoomResponse) Prelude.. Lens.mapping Lens.coerced -- | Maximum number of characters in a single message. Messages are expected -- to be UTF-8 encoded and this limit applies specifically to -- rune\/code-point count, not number of bytes. Default: 500. getRoomResponse_maximumMessageLength :: Lens.Lens' GetRoomResponse (Prelude.Maybe Prelude.Natural) getRoomResponse_maximumMessageLength = Lens.lens (\GetRoomResponse' {maximumMessageLength} -> maximumMessageLength) (\s@GetRoomResponse' {} a -> s {maximumMessageLength = a} :: GetRoomResponse) -- | Maximum number of messages per second that can be sent to the room (by -- all clients). Default: 10. getRoomResponse_maximumMessageRatePerSecond :: Lens.Lens' GetRoomResponse (Prelude.Maybe Prelude.Natural) getRoomResponse_maximumMessageRatePerSecond = Lens.lens (\GetRoomResponse' {maximumMessageRatePerSecond} -> maximumMessageRatePerSecond) (\s@GetRoomResponse' {} a -> s {maximumMessageRatePerSecond = a} :: GetRoomResponse) -- | Configuration information for optional review of messages. getRoomResponse_messageReviewHandler :: Lens.Lens' GetRoomResponse (Prelude.Maybe MessageReviewHandler) getRoomResponse_messageReviewHandler = Lens.lens (\GetRoomResponse' {messageReviewHandler} -> messageReviewHandler) (\s@GetRoomResponse' {} a -> s {messageReviewHandler = a} :: GetRoomResponse) -- | Room name. The value does not need to be unique. getRoomResponse_name :: Lens.Lens' GetRoomResponse (Prelude.Maybe Prelude.Text) getRoomResponse_name = Lens.lens (\GetRoomResponse' {name} -> name) (\s@GetRoomResponse' {} a -> s {name = a} :: GetRoomResponse) -- | Tags attached to the resource. Array of maps, each of the form -- @string:string (key:value)@. getRoomResponse_tags :: Lens.Lens' GetRoomResponse (Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text)) getRoomResponse_tags = Lens.lens (\GetRoomResponse' {tags} -> tags) (\s@GetRoomResponse' {} a -> s {tags = a} :: GetRoomResponse) Prelude.. Lens.mapping Lens.coerced -- | Time of the room’s last update. This is an ISO 8601 timestamp; /note -- that this is returned as a string/. getRoomResponse_updateTime :: Lens.Lens' GetRoomResponse (Prelude.Maybe Prelude.UTCTime) getRoomResponse_updateTime = Lens.lens (\GetRoomResponse' {updateTime} -> updateTime) (\s@GetRoomResponse' {} a -> s {updateTime = a} :: GetRoomResponse) Prelude.. Lens.mapping Data._Time -- | The response's http status code. getRoomResponse_httpStatus :: Lens.Lens' GetRoomResponse Prelude.Int getRoomResponse_httpStatus = Lens.lens (\GetRoomResponse' {httpStatus} -> httpStatus) (\s@GetRoomResponse' {} a -> s {httpStatus = a} :: GetRoomResponse) instance Prelude.NFData GetRoomResponse where rnf GetRoomResponse' {..} = Prelude.rnf arn `Prelude.seq` Prelude.rnf createTime `Prelude.seq` Prelude.rnf id `Prelude.seq` Prelude.rnf loggingConfigurationIdentifiers `Prelude.seq` Prelude.rnf maximumMessageLength `Prelude.seq` Prelude.rnf maximumMessageRatePerSecond `Prelude.seq` Prelude.rnf messageReviewHandler `Prelude.seq` Prelude.rnf name `Prelude.seq` Prelude.rnf tags `Prelude.seq` Prelude.rnf updateTime `Prelude.seq` Prelude.rnf httpStatus