{-# 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.MechanicalTurk.RejectAssignment -- 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 @RejectAssignment@ operation rejects the results of a completed -- assignment. -- -- You can include an optional feedback message with the rejection, which -- the Worker can see in the Status section of the web site. When you -- include a feedback message with the rejection, it helps the Worker -- understand why the assignment was rejected, and can improve the quality -- of the results the Worker submits in the future. -- -- Only the Requester who created the HIT can reject an assignment for the -- HIT. module Amazonka.MechanicalTurk.RejectAssignment ( -- * Creating a Request RejectAssignment (..), newRejectAssignment, -- * Request Lenses rejectAssignment_assignmentId, rejectAssignment_requesterFeedback, -- * Destructuring the Response RejectAssignmentResponse (..), newRejectAssignmentResponse, -- * Response Lenses rejectAssignmentResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.MechanicalTurk.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newRejectAssignment' smart constructor. data RejectAssignment = RejectAssignment' { -- | The ID of the assignment. The assignment must correspond to a HIT -- created by the Requester. assignmentId :: Prelude.Text, -- | A message for the Worker, which the Worker can see in the Status section -- of the web site. requesterFeedback :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'RejectAssignment' 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: -- -- 'assignmentId', 'rejectAssignment_assignmentId' - The ID of the assignment. The assignment must correspond to a HIT -- created by the Requester. -- -- 'requesterFeedback', 'rejectAssignment_requesterFeedback' - A message for the Worker, which the Worker can see in the Status section -- of the web site. newRejectAssignment :: -- | 'assignmentId' Prelude.Text -> -- | 'requesterFeedback' Prelude.Text -> RejectAssignment newRejectAssignment pAssignmentId_ pRequesterFeedback_ = RejectAssignment' { assignmentId = pAssignmentId_, requesterFeedback = pRequesterFeedback_ } -- | The ID of the assignment. The assignment must correspond to a HIT -- created by the Requester. rejectAssignment_assignmentId :: Lens.Lens' RejectAssignment Prelude.Text rejectAssignment_assignmentId = Lens.lens (\RejectAssignment' {assignmentId} -> assignmentId) (\s@RejectAssignment' {} a -> s {assignmentId = a} :: RejectAssignment) -- | A message for the Worker, which the Worker can see in the Status section -- of the web site. rejectAssignment_requesterFeedback :: Lens.Lens' RejectAssignment Prelude.Text rejectAssignment_requesterFeedback = Lens.lens (\RejectAssignment' {requesterFeedback} -> requesterFeedback) (\s@RejectAssignment' {} a -> s {requesterFeedback = a} :: RejectAssignment) instance Core.AWSRequest RejectAssignment where type AWSResponse RejectAssignment = RejectAssignmentResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveEmpty ( \s h x -> RejectAssignmentResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable RejectAssignment where hashWithSalt _salt RejectAssignment' {..} = _salt `Prelude.hashWithSalt` assignmentId `Prelude.hashWithSalt` requesterFeedback instance Prelude.NFData RejectAssignment where rnf RejectAssignment' {..} = Prelude.rnf assignmentId `Prelude.seq` Prelude.rnf requesterFeedback instance Data.ToHeaders RejectAssignment where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "MTurkRequesterServiceV20170117.RejectAssignment" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON RejectAssignment where toJSON RejectAssignment' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("AssignmentId" Data..= assignmentId), Prelude.Just ("RequesterFeedback" Data..= requesterFeedback) ] ) instance Data.ToPath RejectAssignment where toPath = Prelude.const "/" instance Data.ToQuery RejectAssignment where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newRejectAssignmentResponse' smart constructor. data RejectAssignmentResponse = RejectAssignmentResponse' { -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'RejectAssignmentResponse' 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', 'rejectAssignmentResponse_httpStatus' - The response's http status code. newRejectAssignmentResponse :: -- | 'httpStatus' Prelude.Int -> RejectAssignmentResponse newRejectAssignmentResponse pHttpStatus_ = RejectAssignmentResponse' { httpStatus = pHttpStatus_ } -- | The response's http status code. rejectAssignmentResponse_httpStatus :: Lens.Lens' RejectAssignmentResponse Prelude.Int rejectAssignmentResponse_httpStatus = Lens.lens (\RejectAssignmentResponse' {httpStatus} -> httpStatus) (\s@RejectAssignmentResponse' {} a -> s {httpStatus = a} :: RejectAssignmentResponse) instance Prelude.NFData RejectAssignmentResponse where rnf RejectAssignmentResponse' {..} = Prelude.rnf httpStatus