{-# 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.ServiceCatalog.DeleteProvisionedProductPlan -- 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 the specified plan. module Amazonka.ServiceCatalog.DeleteProvisionedProductPlan ( -- * Creating a Request DeleteProvisionedProductPlan (..), newDeleteProvisionedProductPlan, -- * Request Lenses deleteProvisionedProductPlan_acceptLanguage, deleteProvisionedProductPlan_ignoreErrors, deleteProvisionedProductPlan_planId, -- * Destructuring the Response DeleteProvisionedProductPlanResponse (..), newDeleteProvisionedProductPlanResponse, -- * Response Lenses deleteProvisionedProductPlanResponse_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 qualified Amazonka.Request as Request import qualified Amazonka.Response as Response import Amazonka.ServiceCatalog.Types -- | /See:/ 'newDeleteProvisionedProductPlan' smart constructor. data DeleteProvisionedProductPlan = DeleteProvisionedProductPlan' { -- | The language code. -- -- - @en@ - English (default) -- -- - @jp@ - Japanese -- -- - @zh@ - Chinese acceptLanguage :: Prelude.Maybe Prelude.Text, -- | If set to true, Service Catalog stops managing the specified provisioned -- product even if it cannot delete the underlying resources. ignoreErrors :: Prelude.Maybe Prelude.Bool, -- | The plan identifier. planId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteProvisionedProductPlan' 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: -- -- 'acceptLanguage', 'deleteProvisionedProductPlan_acceptLanguage' - The language code. -- -- - @en@ - English (default) -- -- - @jp@ - Japanese -- -- - @zh@ - Chinese -- -- 'ignoreErrors', 'deleteProvisionedProductPlan_ignoreErrors' - If set to true, Service Catalog stops managing the specified provisioned -- product even if it cannot delete the underlying resources. -- -- 'planId', 'deleteProvisionedProductPlan_planId' - The plan identifier. newDeleteProvisionedProductPlan :: -- | 'planId' Prelude.Text -> DeleteProvisionedProductPlan newDeleteProvisionedProductPlan pPlanId_ = DeleteProvisionedProductPlan' { acceptLanguage = Prelude.Nothing, ignoreErrors = Prelude.Nothing, planId = pPlanId_ } -- | The language code. -- -- - @en@ - English (default) -- -- - @jp@ - Japanese -- -- - @zh@ - Chinese deleteProvisionedProductPlan_acceptLanguage :: Lens.Lens' DeleteProvisionedProductPlan (Prelude.Maybe Prelude.Text) deleteProvisionedProductPlan_acceptLanguage = Lens.lens (\DeleteProvisionedProductPlan' {acceptLanguage} -> acceptLanguage) (\s@DeleteProvisionedProductPlan' {} a -> s {acceptLanguage = a} :: DeleteProvisionedProductPlan) -- | If set to true, Service Catalog stops managing the specified provisioned -- product even if it cannot delete the underlying resources. deleteProvisionedProductPlan_ignoreErrors :: Lens.Lens' DeleteProvisionedProductPlan (Prelude.Maybe Prelude.Bool) deleteProvisionedProductPlan_ignoreErrors = Lens.lens (\DeleteProvisionedProductPlan' {ignoreErrors} -> ignoreErrors) (\s@DeleteProvisionedProductPlan' {} a -> s {ignoreErrors = a} :: DeleteProvisionedProductPlan) -- | The plan identifier. deleteProvisionedProductPlan_planId :: Lens.Lens' DeleteProvisionedProductPlan Prelude.Text deleteProvisionedProductPlan_planId = Lens.lens (\DeleteProvisionedProductPlan' {planId} -> planId) (\s@DeleteProvisionedProductPlan' {} a -> s {planId = a} :: DeleteProvisionedProductPlan) instance Core.AWSRequest DeleteProvisionedProductPlan where type AWSResponse DeleteProvisionedProductPlan = DeleteProvisionedProductPlanResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveEmpty ( \s h x -> DeleteProvisionedProductPlanResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DeleteProvisionedProductPlan where hashWithSalt _salt DeleteProvisionedProductPlan' {..} = _salt `Prelude.hashWithSalt` acceptLanguage `Prelude.hashWithSalt` ignoreErrors `Prelude.hashWithSalt` planId instance Prelude.NFData DeleteProvisionedProductPlan where rnf DeleteProvisionedProductPlan' {..} = Prelude.rnf acceptLanguage `Prelude.seq` Prelude.rnf ignoreErrors `Prelude.seq` Prelude.rnf planId instance Data.ToHeaders DeleteProvisionedProductPlan where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AWS242ServiceCatalogService.DeleteProvisionedProductPlan" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DeleteProvisionedProductPlan where toJSON DeleteProvisionedProductPlan' {..} = Data.object ( Prelude.catMaybes [ ("AcceptLanguage" Data..=) Prelude.<$> acceptLanguage, ("IgnoreErrors" Data..=) Prelude.<$> ignoreErrors, Prelude.Just ("PlanId" Data..= planId) ] ) instance Data.ToPath DeleteProvisionedProductPlan where toPath = Prelude.const "/" instance Data.ToQuery DeleteProvisionedProductPlan where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDeleteProvisionedProductPlanResponse' smart constructor. data DeleteProvisionedProductPlanResponse = DeleteProvisionedProductPlanResponse' { -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteProvisionedProductPlanResponse' 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', 'deleteProvisionedProductPlanResponse_httpStatus' - The response's http status code. newDeleteProvisionedProductPlanResponse :: -- | 'httpStatus' Prelude.Int -> DeleteProvisionedProductPlanResponse newDeleteProvisionedProductPlanResponse pHttpStatus_ = DeleteProvisionedProductPlanResponse' { httpStatus = pHttpStatus_ } -- | The response's http status code. deleteProvisionedProductPlanResponse_httpStatus :: Lens.Lens' DeleteProvisionedProductPlanResponse Prelude.Int deleteProvisionedProductPlanResponse_httpStatus = Lens.lens (\DeleteProvisionedProductPlanResponse' {httpStatus} -> httpStatus) (\s@DeleteProvisionedProductPlanResponse' {} a -> s {httpStatus = a} :: DeleteProvisionedProductPlanResponse) instance Prelude.NFData DeleteProvisionedProductPlanResponse where rnf DeleteProvisionedProductPlanResponse' {..} = Prelude.rnf httpStatus