{-# 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.ECS.DeleteTaskSet -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Deletes a specified task set within a service. This is used when a -- service uses the @EXTERNAL@ deployment controller type. For more -- information, see -- -- in the /Amazon Elastic Container Service Developer Guide/. module Amazonka.ECS.DeleteTaskSet ( -- * Creating a Request DeleteTaskSet (..), newDeleteTaskSet, -- * Request Lenses deleteTaskSet_force, deleteTaskSet_cluster, deleteTaskSet_service, deleteTaskSet_taskSet, -- * Destructuring the Response DeleteTaskSetResponse (..), newDeleteTaskSetResponse, -- * Response Lenses deleteTaskSetResponse_taskSet, deleteTaskSetResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.ECS.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newDeleteTaskSet' smart constructor. data DeleteTaskSet = DeleteTaskSet' { -- | If @true@, you can delete a task set even if it hasn\'t been scaled down -- to zero. force :: Prelude.Maybe Prelude.Bool, -- | The short name or full Amazon Resource Name (ARN) of the cluster that -- hosts the service that the task set found in to delete. cluster :: Prelude.Text, -- | The short name or full Amazon Resource Name (ARN) of the service that -- hosts the task set to delete. service :: Prelude.Text, -- | The task set ID or full Amazon Resource Name (ARN) of the task set to -- delete. taskSet :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteTaskSet' 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: -- -- 'force', 'deleteTaskSet_force' - If @true@, you can delete a task set even if it hasn\'t been scaled down -- to zero. -- -- 'cluster', 'deleteTaskSet_cluster' - The short name or full Amazon Resource Name (ARN) of the cluster that -- hosts the service that the task set found in to delete. -- -- 'service', 'deleteTaskSet_service' - The short name or full Amazon Resource Name (ARN) of the service that -- hosts the task set to delete. -- -- 'taskSet', 'deleteTaskSet_taskSet' - The task set ID or full Amazon Resource Name (ARN) of the task set to -- delete. newDeleteTaskSet :: -- | 'cluster' Prelude.Text -> -- | 'service' Prelude.Text -> -- | 'taskSet' Prelude.Text -> DeleteTaskSet newDeleteTaskSet pCluster_ pService_ pTaskSet_ = DeleteTaskSet' { force = Prelude.Nothing, cluster = pCluster_, service = pService_, taskSet = pTaskSet_ } -- | If @true@, you can delete a task set even if it hasn\'t been scaled down -- to zero. deleteTaskSet_force :: Lens.Lens' DeleteTaskSet (Prelude.Maybe Prelude.Bool) deleteTaskSet_force = Lens.lens (\DeleteTaskSet' {force} -> force) (\s@DeleteTaskSet' {} a -> s {force = a} :: DeleteTaskSet) -- | The short name or full Amazon Resource Name (ARN) of the cluster that -- hosts the service that the task set found in to delete. deleteTaskSet_cluster :: Lens.Lens' DeleteTaskSet Prelude.Text deleteTaskSet_cluster = Lens.lens (\DeleteTaskSet' {cluster} -> cluster) (\s@DeleteTaskSet' {} a -> s {cluster = a} :: DeleteTaskSet) -- | The short name or full Amazon Resource Name (ARN) of the service that -- hosts the task set to delete. deleteTaskSet_service :: Lens.Lens' DeleteTaskSet Prelude.Text deleteTaskSet_service = Lens.lens (\DeleteTaskSet' {service} -> service) (\s@DeleteTaskSet' {} a -> s {service = a} :: DeleteTaskSet) -- | The task set ID or full Amazon Resource Name (ARN) of the task set to -- delete. deleteTaskSet_taskSet :: Lens.Lens' DeleteTaskSet Prelude.Text deleteTaskSet_taskSet = Lens.lens (\DeleteTaskSet' {taskSet} -> taskSet) (\s@DeleteTaskSet' {} a -> s {taskSet = a} :: DeleteTaskSet) instance Core.AWSRequest DeleteTaskSet where type AWSResponse DeleteTaskSet = DeleteTaskSetResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> DeleteTaskSetResponse' Prelude.<$> (x Data..?> "taskSet") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DeleteTaskSet where hashWithSalt _salt DeleteTaskSet' {..} = _salt `Prelude.hashWithSalt` force `Prelude.hashWithSalt` cluster `Prelude.hashWithSalt` service `Prelude.hashWithSalt` taskSet instance Prelude.NFData DeleteTaskSet where rnf DeleteTaskSet' {..} = Prelude.rnf force `Prelude.seq` Prelude.rnf cluster `Prelude.seq` Prelude.rnf service `Prelude.seq` Prelude.rnf taskSet instance Data.ToHeaders DeleteTaskSet where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AmazonEC2ContainerServiceV20141113.DeleteTaskSet" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DeleteTaskSet where toJSON DeleteTaskSet' {..} = Data.object ( Prelude.catMaybes [ ("force" Data..=) Prelude.<$> force, Prelude.Just ("cluster" Data..= cluster), Prelude.Just ("service" Data..= service), Prelude.Just ("taskSet" Data..= taskSet) ] ) instance Data.ToPath DeleteTaskSet where toPath = Prelude.const "/" instance Data.ToQuery DeleteTaskSet where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDeleteTaskSetResponse' smart constructor. data DeleteTaskSetResponse = DeleteTaskSetResponse' { -- | Details about the task set. taskSet :: Prelude.Maybe TaskSet, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteTaskSetResponse' 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: -- -- 'taskSet', 'deleteTaskSetResponse_taskSet' - Details about the task set. -- -- 'httpStatus', 'deleteTaskSetResponse_httpStatus' - The response's http status code. newDeleteTaskSetResponse :: -- | 'httpStatus' Prelude.Int -> DeleteTaskSetResponse newDeleteTaskSetResponse pHttpStatus_ = DeleteTaskSetResponse' { taskSet = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Details about the task set. deleteTaskSetResponse_taskSet :: Lens.Lens' DeleteTaskSetResponse (Prelude.Maybe TaskSet) deleteTaskSetResponse_taskSet = Lens.lens (\DeleteTaskSetResponse' {taskSet} -> taskSet) (\s@DeleteTaskSetResponse' {} a -> s {taskSet = a} :: DeleteTaskSetResponse) -- | The response's http status code. deleteTaskSetResponse_httpStatus :: Lens.Lens' DeleteTaskSetResponse Prelude.Int deleteTaskSetResponse_httpStatus = Lens.lens (\DeleteTaskSetResponse' {httpStatus} -> httpStatus) (\s@DeleteTaskSetResponse' {} a -> s {httpStatus = a} :: DeleteTaskSetResponse) instance Prelude.NFData DeleteTaskSetResponse where rnf DeleteTaskSetResponse' {..} = Prelude.rnf taskSet `Prelude.seq` Prelude.rnf httpStatus