{-# 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.Connect.CreateQueue -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- This API is in preview release for Amazon Connect and is subject to -- change. -- -- Creates a new queue for the specified Amazon Connect instance. -- -- If the number being used in the input is claimed to a traffic -- distribution group, and you are calling this API using an instance in -- the Amazon Web Services Region where the traffic distribution group was -- created, you can use either a full phone number ARN or UUID value for -- the @OutboundCallerIdNumberId@ value of the -- -- request body parameter. However, if the number is claimed to a traffic -- distribution group and you are calling this API using an instance in the -- alternate Amazon Web Services Region associated with the traffic -- distribution group, you must provide a full phone number ARN. If a UUID -- is provided in this scenario, you will receive a -- @ResourceNotFoundException@. module Amazonka.Connect.CreateQueue ( -- * Creating a Request CreateQueue (..), newCreateQueue, -- * Request Lenses createQueue_description, createQueue_maxContacts, createQueue_outboundCallerConfig, createQueue_quickConnectIds, createQueue_tags, createQueue_instanceId, createQueue_name, createQueue_hoursOfOperationId, -- * Destructuring the Response CreateQueueResponse (..), newCreateQueueResponse, -- * Response Lenses createQueueResponse_queueArn, createQueueResponse_queueId, createQueueResponse_httpStatus, ) where import Amazonka.Connect.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:/ 'newCreateQueue' smart constructor. data CreateQueue = CreateQueue' { -- | The description of the queue. description :: Prelude.Maybe Prelude.Text, -- | The maximum number of contacts that can be in the queue before it is -- considered full. maxContacts :: Prelude.Maybe Prelude.Natural, -- | The outbound caller ID name, number, and outbound whisper flow. outboundCallerConfig :: Prelude.Maybe OutboundCallerConfig, -- | The quick connects available to agents who are working the queue. quickConnectIds :: Prelude.Maybe (Prelude.NonEmpty Prelude.Text), -- | The tags used to organize, track, or control access for this resource. -- For example, { \"tags\": {\"key1\":\"value1\", \"key2\":\"value2\"} }. tags :: Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text), -- | The identifier of the Amazon Connect instance. You can find the -- instanceId in the ARN of the instance. instanceId :: Prelude.Text, -- | The name of the queue. name :: Prelude.Text, -- | The identifier for the hours of operation. hoursOfOperationId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'CreateQueue' 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: -- -- 'description', 'createQueue_description' - The description of the queue. -- -- 'maxContacts', 'createQueue_maxContacts' - The maximum number of contacts that can be in the queue before it is -- considered full. -- -- 'outboundCallerConfig', 'createQueue_outboundCallerConfig' - The outbound caller ID name, number, and outbound whisper flow. -- -- 'quickConnectIds', 'createQueue_quickConnectIds' - The quick connects available to agents who are working the queue. -- -- 'tags', 'createQueue_tags' - The tags used to organize, track, or control access for this resource. -- For example, { \"tags\": {\"key1\":\"value1\", \"key2\":\"value2\"} }. -- -- 'instanceId', 'createQueue_instanceId' - The identifier of the Amazon Connect instance. You can find the -- instanceId in the ARN of the instance. -- -- 'name', 'createQueue_name' - The name of the queue. -- -- 'hoursOfOperationId', 'createQueue_hoursOfOperationId' - The identifier for the hours of operation. newCreateQueue :: -- | 'instanceId' Prelude.Text -> -- | 'name' Prelude.Text -> -- | 'hoursOfOperationId' Prelude.Text -> CreateQueue newCreateQueue pInstanceId_ pName_ pHoursOfOperationId_ = CreateQueue' { description = Prelude.Nothing, maxContacts = Prelude.Nothing, outboundCallerConfig = Prelude.Nothing, quickConnectIds = Prelude.Nothing, tags = Prelude.Nothing, instanceId = pInstanceId_, name = pName_, hoursOfOperationId = pHoursOfOperationId_ } -- | The description of the queue. createQueue_description :: Lens.Lens' CreateQueue (Prelude.Maybe Prelude.Text) createQueue_description = Lens.lens (\CreateQueue' {description} -> description) (\s@CreateQueue' {} a -> s {description = a} :: CreateQueue) -- | The maximum number of contacts that can be in the queue before it is -- considered full. createQueue_maxContacts :: Lens.Lens' CreateQueue (Prelude.Maybe Prelude.Natural) createQueue_maxContacts = Lens.lens (\CreateQueue' {maxContacts} -> maxContacts) (\s@CreateQueue' {} a -> s {maxContacts = a} :: CreateQueue) -- | The outbound caller ID name, number, and outbound whisper flow. createQueue_outboundCallerConfig :: Lens.Lens' CreateQueue (Prelude.Maybe OutboundCallerConfig) createQueue_outboundCallerConfig = Lens.lens (\CreateQueue' {outboundCallerConfig} -> outboundCallerConfig) (\s@CreateQueue' {} a -> s {outboundCallerConfig = a} :: CreateQueue) -- | The quick connects available to agents who are working the queue. createQueue_quickConnectIds :: Lens.Lens' CreateQueue (Prelude.Maybe (Prelude.NonEmpty Prelude.Text)) createQueue_quickConnectIds = Lens.lens (\CreateQueue' {quickConnectIds} -> quickConnectIds) (\s@CreateQueue' {} a -> s {quickConnectIds = a} :: CreateQueue) Prelude.. Lens.mapping Lens.coerced -- | The tags used to organize, track, or control access for this resource. -- For example, { \"tags\": {\"key1\":\"value1\", \"key2\":\"value2\"} }. createQueue_tags :: Lens.Lens' CreateQueue (Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text)) createQueue_tags = Lens.lens (\CreateQueue' {tags} -> tags) (\s@CreateQueue' {} a -> s {tags = a} :: CreateQueue) Prelude.. Lens.mapping Lens.coerced -- | The identifier of the Amazon Connect instance. You can find the -- instanceId in the ARN of the instance. createQueue_instanceId :: Lens.Lens' CreateQueue Prelude.Text createQueue_instanceId = Lens.lens (\CreateQueue' {instanceId} -> instanceId) (\s@CreateQueue' {} a -> s {instanceId = a} :: CreateQueue) -- | The name of the queue. createQueue_name :: Lens.Lens' CreateQueue Prelude.Text createQueue_name = Lens.lens (\CreateQueue' {name} -> name) (\s@CreateQueue' {} a -> s {name = a} :: CreateQueue) -- | The identifier for the hours of operation. createQueue_hoursOfOperationId :: Lens.Lens' CreateQueue Prelude.Text createQueue_hoursOfOperationId = Lens.lens (\CreateQueue' {hoursOfOperationId} -> hoursOfOperationId) (\s@CreateQueue' {} a -> s {hoursOfOperationId = a} :: CreateQueue) instance Core.AWSRequest CreateQueue where type AWSResponse CreateQueue = CreateQueueResponse request overrides = Request.putJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> CreateQueueResponse' Prelude.<$> (x Data..?> "QueueArn") Prelude.<*> (x Data..?> "QueueId") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable CreateQueue where hashWithSalt _salt CreateQueue' {..} = _salt `Prelude.hashWithSalt` description `Prelude.hashWithSalt` maxContacts `Prelude.hashWithSalt` outboundCallerConfig `Prelude.hashWithSalt` quickConnectIds `Prelude.hashWithSalt` tags `Prelude.hashWithSalt` instanceId `Prelude.hashWithSalt` name `Prelude.hashWithSalt` hoursOfOperationId instance Prelude.NFData CreateQueue where rnf CreateQueue' {..} = Prelude.rnf description `Prelude.seq` Prelude.rnf maxContacts `Prelude.seq` Prelude.rnf outboundCallerConfig `Prelude.seq` Prelude.rnf quickConnectIds `Prelude.seq` Prelude.rnf tags `Prelude.seq` Prelude.rnf instanceId `Prelude.seq` Prelude.rnf name `Prelude.seq` Prelude.rnf hoursOfOperationId instance Data.ToHeaders CreateQueue where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON CreateQueue where toJSON CreateQueue' {..} = Data.object ( Prelude.catMaybes [ ("Description" Data..=) Prelude.<$> description, ("MaxContacts" Data..=) Prelude.<$> maxContacts, ("OutboundCallerConfig" Data..=) Prelude.<$> outboundCallerConfig, ("QuickConnectIds" Data..=) Prelude.<$> quickConnectIds, ("Tags" Data..=) Prelude.<$> tags, Prelude.Just ("Name" Data..= name), Prelude.Just ("HoursOfOperationId" Data..= hoursOfOperationId) ] ) instance Data.ToPath CreateQueue where toPath CreateQueue' {..} = Prelude.mconcat ["/queues/", Data.toBS instanceId] instance Data.ToQuery CreateQueue where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newCreateQueueResponse' smart constructor. data CreateQueueResponse = CreateQueueResponse' { -- | The Amazon Resource Name (ARN) of the queue. queueArn :: Prelude.Maybe Prelude.Text, -- | The identifier for the queue. queueId :: Prelude.Maybe Prelude.Text, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'CreateQueueResponse' 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: -- -- 'queueArn', 'createQueueResponse_queueArn' - The Amazon Resource Name (ARN) of the queue. -- -- 'queueId', 'createQueueResponse_queueId' - The identifier for the queue. -- -- 'httpStatus', 'createQueueResponse_httpStatus' - The response's http status code. newCreateQueueResponse :: -- | 'httpStatus' Prelude.Int -> CreateQueueResponse newCreateQueueResponse pHttpStatus_ = CreateQueueResponse' { queueArn = Prelude.Nothing, queueId = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The Amazon Resource Name (ARN) of the queue. createQueueResponse_queueArn :: Lens.Lens' CreateQueueResponse (Prelude.Maybe Prelude.Text) createQueueResponse_queueArn = Lens.lens (\CreateQueueResponse' {queueArn} -> queueArn) (\s@CreateQueueResponse' {} a -> s {queueArn = a} :: CreateQueueResponse) -- | The identifier for the queue. createQueueResponse_queueId :: Lens.Lens' CreateQueueResponse (Prelude.Maybe Prelude.Text) createQueueResponse_queueId = Lens.lens (\CreateQueueResponse' {queueId} -> queueId) (\s@CreateQueueResponse' {} a -> s {queueId = a} :: CreateQueueResponse) -- | The response's http status code. createQueueResponse_httpStatus :: Lens.Lens' CreateQueueResponse Prelude.Int createQueueResponse_httpStatus = Lens.lens (\CreateQueueResponse' {httpStatus} -> httpStatus) (\s@CreateQueueResponse' {} a -> s {httpStatus = a} :: CreateQueueResponse) instance Prelude.NFData CreateQueueResponse where rnf CreateQueueResponse' {..} = Prelude.rnf queueArn `Prelude.seq` Prelude.rnf queueId `Prelude.seq` Prelude.rnf httpStatus