{-# 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.Proton.DeleteService -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Delete a service, with its instances and pipeline. -- -- You can\'t delete a service if it has any service instances that have -- components attached to them. -- -- For more information about components, see -- -- in the /Proton User Guide/. module Amazonka.Proton.DeleteService ( -- * Creating a Request DeleteService (..), newDeleteService, -- * Request Lenses deleteService_name, -- * Destructuring the Response DeleteServiceResponse (..), newDeleteServiceResponse, -- * Response Lenses deleteServiceResponse_service, deleteServiceResponse_httpStatus, ) where 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 Amazonka.Proton.Types import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newDeleteService' smart constructor. data DeleteService = DeleteService' { -- | The name of the service to delete. name :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteService' 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: -- -- 'name', 'deleteService_name' - The name of the service to delete. newDeleteService :: -- | 'name' Prelude.Text -> DeleteService newDeleteService pName_ = DeleteService' {name = pName_} -- | The name of the service to delete. deleteService_name :: Lens.Lens' DeleteService Prelude.Text deleteService_name = Lens.lens (\DeleteService' {name} -> name) (\s@DeleteService' {} a -> s {name = a} :: DeleteService) instance Core.AWSRequest DeleteService where type AWSResponse DeleteService = DeleteServiceResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> DeleteServiceResponse' Prelude.<$> (x Data..?> "service") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DeleteService where hashWithSalt _salt DeleteService' {..} = _salt `Prelude.hashWithSalt` name instance Prelude.NFData DeleteService where rnf DeleteService' {..} = Prelude.rnf name instance Data.ToHeaders DeleteService where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AwsProton20200720.DeleteService" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.0" :: Prelude.ByteString ) ] ) instance Data.ToJSON DeleteService where toJSON DeleteService' {..} = Data.object ( Prelude.catMaybes [Prelude.Just ("name" Data..= name)] ) instance Data.ToPath DeleteService where toPath = Prelude.const "/" instance Data.ToQuery DeleteService where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDeleteServiceResponse' smart constructor. data DeleteServiceResponse = DeleteServiceResponse' { -- | The detailed data of the service being deleted. service :: Prelude.Maybe Service, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteServiceResponse' 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: -- -- 'service', 'deleteServiceResponse_service' - The detailed data of the service being deleted. -- -- 'httpStatus', 'deleteServiceResponse_httpStatus' - The response's http status code. newDeleteServiceResponse :: -- | 'httpStatus' Prelude.Int -> DeleteServiceResponse newDeleteServiceResponse pHttpStatus_ = DeleteServiceResponse' { service = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The detailed data of the service being deleted. deleteServiceResponse_service :: Lens.Lens' DeleteServiceResponse (Prelude.Maybe Service) deleteServiceResponse_service = Lens.lens (\DeleteServiceResponse' {service} -> service) (\s@DeleteServiceResponse' {} a -> s {service = a} :: DeleteServiceResponse) -- | The response's http status code. deleteServiceResponse_httpStatus :: Lens.Lens' DeleteServiceResponse Prelude.Int deleteServiceResponse_httpStatus = Lens.lens (\DeleteServiceResponse' {httpStatus} -> httpStatus) (\s@DeleteServiceResponse' {} a -> s {httpStatus = a} :: DeleteServiceResponse) instance Prelude.NFData DeleteServiceResponse where rnf DeleteServiceResponse' {..} = Prelude.rnf service `Prelude.seq` Prelude.rnf httpStatus