{-# 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.StartContactRecording -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Starts recording the contact: -- -- - If the API is called /before/ the agent joins the call, recording -- starts when the agent joins the call. -- -- - If the API is called /after/ the agent joins the call, recording -- starts at the time of the API call. -- -- StartContactRecording is a one-time action. For example, if you use -- StopContactRecording to stop recording an ongoing call, you can\'t use -- StartContactRecording to restart it. For scenarios where the recording -- has started and you want to suspend and resume it, such as when -- collecting sensitive information (for example, a credit card number), -- use SuspendContactRecording and ResumeContactRecording. -- -- You can use this API to override the recording behavior configured in -- the -- -- block. -- -- Only voice recordings are supported at this time. module Amazonka.Connect.StartContactRecording ( -- * Creating a Request StartContactRecording (..), newStartContactRecording, -- * Request Lenses startContactRecording_instanceId, startContactRecording_contactId, startContactRecording_initialContactId, startContactRecording_voiceRecordingConfiguration, -- * Destructuring the Response StartContactRecordingResponse (..), newStartContactRecordingResponse, -- * Response Lenses startContactRecordingResponse_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:/ 'newStartContactRecording' smart constructor. data StartContactRecording = StartContactRecording' { -- | The identifier of the Amazon Connect instance. You can find the -- instanceId in the ARN of the instance. instanceId :: Prelude.Text, -- | The identifier of the contact. contactId :: Prelude.Text, -- | The identifier of the contact. This is the identifier of the contact -- associated with the first interaction with the contact center. initialContactId :: Prelude.Text, -- | The person being recorded. voiceRecordingConfiguration :: VoiceRecordingConfiguration } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'StartContactRecording' 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: -- -- 'instanceId', 'startContactRecording_instanceId' - The identifier of the Amazon Connect instance. You can find the -- instanceId in the ARN of the instance. -- -- 'contactId', 'startContactRecording_contactId' - The identifier of the contact. -- -- 'initialContactId', 'startContactRecording_initialContactId' - The identifier of the contact. This is the identifier of the contact -- associated with the first interaction with the contact center. -- -- 'voiceRecordingConfiguration', 'startContactRecording_voiceRecordingConfiguration' - The person being recorded. newStartContactRecording :: -- | 'instanceId' Prelude.Text -> -- | 'contactId' Prelude.Text -> -- | 'initialContactId' Prelude.Text -> -- | 'voiceRecordingConfiguration' VoiceRecordingConfiguration -> StartContactRecording newStartContactRecording pInstanceId_ pContactId_ pInitialContactId_ pVoiceRecordingConfiguration_ = StartContactRecording' { instanceId = pInstanceId_, contactId = pContactId_, initialContactId = pInitialContactId_, voiceRecordingConfiguration = pVoiceRecordingConfiguration_ } -- | The identifier of the Amazon Connect instance. You can find the -- instanceId in the ARN of the instance. startContactRecording_instanceId :: Lens.Lens' StartContactRecording Prelude.Text startContactRecording_instanceId = Lens.lens (\StartContactRecording' {instanceId} -> instanceId) (\s@StartContactRecording' {} a -> s {instanceId = a} :: StartContactRecording) -- | The identifier of the contact. startContactRecording_contactId :: Lens.Lens' StartContactRecording Prelude.Text startContactRecording_contactId = Lens.lens (\StartContactRecording' {contactId} -> contactId) (\s@StartContactRecording' {} a -> s {contactId = a} :: StartContactRecording) -- | The identifier of the contact. This is the identifier of the contact -- associated with the first interaction with the contact center. startContactRecording_initialContactId :: Lens.Lens' StartContactRecording Prelude.Text startContactRecording_initialContactId = Lens.lens (\StartContactRecording' {initialContactId} -> initialContactId) (\s@StartContactRecording' {} a -> s {initialContactId = a} :: StartContactRecording) -- | The person being recorded. startContactRecording_voiceRecordingConfiguration :: Lens.Lens' StartContactRecording VoiceRecordingConfiguration startContactRecording_voiceRecordingConfiguration = Lens.lens (\StartContactRecording' {voiceRecordingConfiguration} -> voiceRecordingConfiguration) (\s@StartContactRecording' {} a -> s {voiceRecordingConfiguration = a} :: StartContactRecording) instance Core.AWSRequest StartContactRecording where type AWSResponse StartContactRecording = StartContactRecordingResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveEmpty ( \s h x -> StartContactRecordingResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable StartContactRecording where hashWithSalt _salt StartContactRecording' {..} = _salt `Prelude.hashWithSalt` instanceId `Prelude.hashWithSalt` contactId `Prelude.hashWithSalt` initialContactId `Prelude.hashWithSalt` voiceRecordingConfiguration instance Prelude.NFData StartContactRecording where rnf StartContactRecording' {..} = Prelude.rnf instanceId `Prelude.seq` Prelude.rnf contactId `Prelude.seq` Prelude.rnf initialContactId `Prelude.seq` Prelude.rnf voiceRecordingConfiguration instance Data.ToHeaders StartContactRecording where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON StartContactRecording where toJSON StartContactRecording' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("InstanceId" Data..= instanceId), Prelude.Just ("ContactId" Data..= contactId), Prelude.Just ("InitialContactId" Data..= initialContactId), Prelude.Just ( "VoiceRecordingConfiguration" Data..= voiceRecordingConfiguration ) ] ) instance Data.ToPath StartContactRecording where toPath = Prelude.const "/contact/start-recording" instance Data.ToQuery StartContactRecording where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newStartContactRecordingResponse' smart constructor. data StartContactRecordingResponse = StartContactRecordingResponse' { -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'StartContactRecordingResponse' 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: -- -- 'httpStatus', 'startContactRecordingResponse_httpStatus' - The response's http status code. newStartContactRecordingResponse :: -- | 'httpStatus' Prelude.Int -> StartContactRecordingResponse newStartContactRecordingResponse pHttpStatus_ = StartContactRecordingResponse' { httpStatus = pHttpStatus_ } -- | The response's http status code. startContactRecordingResponse_httpStatus :: Lens.Lens' StartContactRecordingResponse Prelude.Int startContactRecordingResponse_httpStatus = Lens.lens (\StartContactRecordingResponse' {httpStatus} -> httpStatus) (\s@StartContactRecordingResponse' {} a -> s {httpStatus = a} :: StartContactRecordingResponse) instance Prelude.NFData StartContactRecordingResponse where rnf StartContactRecordingResponse' {..} = Prelude.rnf httpStatus