{-# 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.CognitoIdentityProvider.StopUserImportJob -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Stops the user import job. module Amazonka.CognitoIdentityProvider.StopUserImportJob ( -- * Creating a Request StopUserImportJob (..), newStopUserImportJob, -- * Request Lenses stopUserImportJob_userPoolId, stopUserImportJob_jobId, -- * Destructuring the Response StopUserImportJobResponse (..), newStopUserImportJobResponse, -- * Response Lenses stopUserImportJobResponse_userImportJob, stopUserImportJobResponse_httpStatus, ) where import Amazonka.CognitoIdentityProvider.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 -- | Represents the request to stop the user import job. -- -- /See:/ 'newStopUserImportJob' smart constructor. data StopUserImportJob = StopUserImportJob' { -- | The user pool ID for the user pool that the users are being imported -- into. userPoolId :: Prelude.Text, -- | The job ID for the user import job. jobId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'StopUserImportJob' 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: -- -- 'userPoolId', 'stopUserImportJob_userPoolId' - The user pool ID for the user pool that the users are being imported -- into. -- -- 'jobId', 'stopUserImportJob_jobId' - The job ID for the user import job. newStopUserImportJob :: -- | 'userPoolId' Prelude.Text -> -- | 'jobId' Prelude.Text -> StopUserImportJob newStopUserImportJob pUserPoolId_ pJobId_ = StopUserImportJob' { userPoolId = pUserPoolId_, jobId = pJobId_ } -- | The user pool ID for the user pool that the users are being imported -- into. stopUserImportJob_userPoolId :: Lens.Lens' StopUserImportJob Prelude.Text stopUserImportJob_userPoolId = Lens.lens (\StopUserImportJob' {userPoolId} -> userPoolId) (\s@StopUserImportJob' {} a -> s {userPoolId = a} :: StopUserImportJob) -- | The job ID for the user import job. stopUserImportJob_jobId :: Lens.Lens' StopUserImportJob Prelude.Text stopUserImportJob_jobId = Lens.lens (\StopUserImportJob' {jobId} -> jobId) (\s@StopUserImportJob' {} a -> s {jobId = a} :: StopUserImportJob) instance Core.AWSRequest StopUserImportJob where type AWSResponse StopUserImportJob = StopUserImportJobResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> StopUserImportJobResponse' Prelude.<$> (x Data..?> "UserImportJob") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable StopUserImportJob where hashWithSalt _salt StopUserImportJob' {..} = _salt `Prelude.hashWithSalt` userPoolId `Prelude.hashWithSalt` jobId instance Prelude.NFData StopUserImportJob where rnf StopUserImportJob' {..} = Prelude.rnf userPoolId `Prelude.seq` Prelude.rnf jobId instance Data.ToHeaders StopUserImportJob where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AWSCognitoIdentityProviderService.StopUserImportJob" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON StopUserImportJob where toJSON StopUserImportJob' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("UserPoolId" Data..= userPoolId), Prelude.Just ("JobId" Data..= jobId) ] ) instance Data.ToPath StopUserImportJob where toPath = Prelude.const "/" instance Data.ToQuery StopUserImportJob where toQuery = Prelude.const Prelude.mempty -- | Represents the response from the server to the request to stop the user -- import job. -- -- /See:/ 'newStopUserImportJobResponse' smart constructor. data StopUserImportJobResponse = StopUserImportJobResponse' { -- | The job object that represents the user import job. userImportJob :: Prelude.Maybe UserImportJobType, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'StopUserImportJobResponse' 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: -- -- 'userImportJob', 'stopUserImportJobResponse_userImportJob' - The job object that represents the user import job. -- -- 'httpStatus', 'stopUserImportJobResponse_httpStatus' - The response's http status code. newStopUserImportJobResponse :: -- | 'httpStatus' Prelude.Int -> StopUserImportJobResponse newStopUserImportJobResponse pHttpStatus_ = StopUserImportJobResponse' { userImportJob = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The job object that represents the user import job. stopUserImportJobResponse_userImportJob :: Lens.Lens' StopUserImportJobResponse (Prelude.Maybe UserImportJobType) stopUserImportJobResponse_userImportJob = Lens.lens (\StopUserImportJobResponse' {userImportJob} -> userImportJob) (\s@StopUserImportJobResponse' {} a -> s {userImportJob = a} :: StopUserImportJobResponse) -- | The response's http status code. stopUserImportJobResponse_httpStatus :: Lens.Lens' StopUserImportJobResponse Prelude.Int stopUserImportJobResponse_httpStatus = Lens.lens (\StopUserImportJobResponse' {httpStatus} -> httpStatus) (\s@StopUserImportJobResponse' {} a -> s {httpStatus = a} :: StopUserImportJobResponse) instance Prelude.NFData StopUserImportJobResponse where rnf StopUserImportJobResponse' {..} = Prelude.rnf userImportJob `Prelude.seq` Prelude.rnf httpStatus