{-# 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.CloudDirectory.DeleteFacet -- 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 given Facet. All attributes and Rules that are associated with -- the facet will be deleted. Only development schema facets are allowed -- deletion. module Amazonka.CloudDirectory.DeleteFacet ( -- * Creating a Request DeleteFacet (..), newDeleteFacet, -- * Request Lenses deleteFacet_schemaArn, deleteFacet_name, -- * Destructuring the Response DeleteFacetResponse (..), newDeleteFacetResponse, -- * Response Lenses deleteFacetResponse_httpStatus, ) where import Amazonka.CloudDirectory.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:/ 'newDeleteFacet' smart constructor. data DeleteFacet = DeleteFacet' { -- | The Amazon Resource Name (ARN) that is associated with the Facet. For -- more information, see arns. schemaArn :: Prelude.Text, -- | The name of the facet to delete. name :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteFacet' 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: -- -- 'schemaArn', 'deleteFacet_schemaArn' - The Amazon Resource Name (ARN) that is associated with the Facet. For -- more information, see arns. -- -- 'name', 'deleteFacet_name' - The name of the facet to delete. newDeleteFacet :: -- | 'schemaArn' Prelude.Text -> -- | 'name' Prelude.Text -> DeleteFacet newDeleteFacet pSchemaArn_ pName_ = DeleteFacet' { schemaArn = pSchemaArn_, name = pName_ } -- | The Amazon Resource Name (ARN) that is associated with the Facet. For -- more information, see arns. deleteFacet_schemaArn :: Lens.Lens' DeleteFacet Prelude.Text deleteFacet_schemaArn = Lens.lens (\DeleteFacet' {schemaArn} -> schemaArn) (\s@DeleteFacet' {} a -> s {schemaArn = a} :: DeleteFacet) -- | The name of the facet to delete. deleteFacet_name :: Lens.Lens' DeleteFacet Prelude.Text deleteFacet_name = Lens.lens (\DeleteFacet' {name} -> name) (\s@DeleteFacet' {} a -> s {name = a} :: DeleteFacet) instance Core.AWSRequest DeleteFacet where type AWSResponse DeleteFacet = DeleteFacetResponse request overrides = Request.putJSON (overrides defaultService) response = Response.receiveEmpty ( \s h x -> DeleteFacetResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DeleteFacet where hashWithSalt _salt DeleteFacet' {..} = _salt `Prelude.hashWithSalt` schemaArn `Prelude.hashWithSalt` name instance Prelude.NFData DeleteFacet where rnf DeleteFacet' {..} = Prelude.rnf schemaArn `Prelude.seq` Prelude.rnf name instance Data.ToHeaders DeleteFacet where toHeaders DeleteFacet' {..} = Prelude.mconcat ["x-amz-data-partition" Data.=# schemaArn] instance Data.ToJSON DeleteFacet where toJSON DeleteFacet' {..} = Data.object ( Prelude.catMaybes [Prelude.Just ("Name" Data..= name)] ) instance Data.ToPath DeleteFacet where toPath = Prelude.const "/amazonclouddirectory/2017-01-11/facet/delete" instance Data.ToQuery DeleteFacet where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDeleteFacetResponse' smart constructor. data DeleteFacetResponse = DeleteFacetResponse' { -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteFacetResponse' 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', 'deleteFacetResponse_httpStatus' - The response's http status code. newDeleteFacetResponse :: -- | 'httpStatus' Prelude.Int -> DeleteFacetResponse newDeleteFacetResponse pHttpStatus_ = DeleteFacetResponse' {httpStatus = pHttpStatus_} -- | The response's http status code. deleteFacetResponse_httpStatus :: Lens.Lens' DeleteFacetResponse Prelude.Int deleteFacetResponse_httpStatus = Lens.lens (\DeleteFacetResponse' {httpStatus} -> httpStatus) (\s@DeleteFacetResponse' {} a -> s {httpStatus = a} :: DeleteFacetResponse) instance Prelude.NFData DeleteFacetResponse where rnf DeleteFacetResponse' {..} = Prelude.rnf httpStatus