{-# 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.Batch.DeregisterJobDefinition -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Deregisters an Batch job definition. Job definitions are permanently -- deleted after 180 days. module Amazonka.Batch.DeregisterJobDefinition ( -- * Creating a Request DeregisterJobDefinition (..), newDeregisterJobDefinition, -- * Request Lenses deregisterJobDefinition_jobDefinition, -- * Destructuring the Response DeregisterJobDefinitionResponse (..), newDeregisterJobDefinitionResponse, -- * Response Lenses deregisterJobDefinitionResponse_httpStatus, ) where import Amazonka.Batch.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:/ 'newDeregisterJobDefinition' smart constructor. data DeregisterJobDefinition = DeregisterJobDefinition' { -- | The name and revision (@name:revision@) or full Amazon Resource Name -- (ARN) of the job definition to deregister. jobDefinition :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeregisterJobDefinition' 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: -- -- 'jobDefinition', 'deregisterJobDefinition_jobDefinition' - The name and revision (@name:revision@) or full Amazon Resource Name -- (ARN) of the job definition to deregister. newDeregisterJobDefinition :: -- | 'jobDefinition' Prelude.Text -> DeregisterJobDefinition newDeregisterJobDefinition pJobDefinition_ = DeregisterJobDefinition' { jobDefinition = pJobDefinition_ } -- | The name and revision (@name:revision@) or full Amazon Resource Name -- (ARN) of the job definition to deregister. deregisterJobDefinition_jobDefinition :: Lens.Lens' DeregisterJobDefinition Prelude.Text deregisterJobDefinition_jobDefinition = Lens.lens (\DeregisterJobDefinition' {jobDefinition} -> jobDefinition) (\s@DeregisterJobDefinition' {} a -> s {jobDefinition = a} :: DeregisterJobDefinition) instance Core.AWSRequest DeregisterJobDefinition where type AWSResponse DeregisterJobDefinition = DeregisterJobDefinitionResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveEmpty ( \s h x -> DeregisterJobDefinitionResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DeregisterJobDefinition where hashWithSalt _salt DeregisterJobDefinition' {..} = _salt `Prelude.hashWithSalt` jobDefinition instance Prelude.NFData DeregisterJobDefinition where rnf DeregisterJobDefinition' {..} = Prelude.rnf jobDefinition instance Data.ToHeaders DeregisterJobDefinition where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DeregisterJobDefinition where toJSON DeregisterJobDefinition' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("jobDefinition" Data..= jobDefinition) ] ) instance Data.ToPath DeregisterJobDefinition where toPath = Prelude.const "/v1/deregisterjobdefinition" instance Data.ToQuery DeregisterJobDefinition where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDeregisterJobDefinitionResponse' smart constructor. data DeregisterJobDefinitionResponse = DeregisterJobDefinitionResponse' { -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeregisterJobDefinitionResponse' 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', 'deregisterJobDefinitionResponse_httpStatus' - The response's http status code. newDeregisterJobDefinitionResponse :: -- | 'httpStatus' Prelude.Int -> DeregisterJobDefinitionResponse newDeregisterJobDefinitionResponse pHttpStatus_ = DeregisterJobDefinitionResponse' { httpStatus = pHttpStatus_ } -- | The response's http status code. deregisterJobDefinitionResponse_httpStatus :: Lens.Lens' DeregisterJobDefinitionResponse Prelude.Int deregisterJobDefinitionResponse_httpStatus = Lens.lens (\DeregisterJobDefinitionResponse' {httpStatus} -> httpStatus) (\s@DeregisterJobDefinitionResponse' {} a -> s {httpStatus = a} :: DeregisterJobDefinitionResponse) instance Prelude.NFData DeregisterJobDefinitionResponse where rnf DeregisterJobDefinitionResponse' {..} = Prelude.rnf httpStatus