{-# 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.Personalize.DeleteSchema -- 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 schema. Before deleting a schema, you must delete all datasets -- referencing the schema. For more information on schemas, see -- . module Amazonka.Personalize.DeleteSchema ( -- * Creating a Request DeleteSchema (..), newDeleteSchema, -- * Request Lenses deleteSchema_schemaArn, -- * Destructuring the Response DeleteSchemaResponse (..), newDeleteSchemaResponse, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.Personalize.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newDeleteSchema' smart constructor. data DeleteSchema = DeleteSchema' { -- | The Amazon Resource Name (ARN) of the schema to delete. schemaArn :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteSchema' 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', 'deleteSchema_schemaArn' - The Amazon Resource Name (ARN) of the schema to delete. newDeleteSchema :: -- | 'schemaArn' Prelude.Text -> DeleteSchema newDeleteSchema pSchemaArn_ = DeleteSchema' {schemaArn = pSchemaArn_} -- | The Amazon Resource Name (ARN) of the schema to delete. deleteSchema_schemaArn :: Lens.Lens' DeleteSchema Prelude.Text deleteSchema_schemaArn = Lens.lens (\DeleteSchema' {schemaArn} -> schemaArn) (\s@DeleteSchema' {} a -> s {schemaArn = a} :: DeleteSchema) instance Core.AWSRequest DeleteSchema where type AWSResponse DeleteSchema = DeleteSchemaResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveNull DeleteSchemaResponse' instance Prelude.Hashable DeleteSchema where hashWithSalt _salt DeleteSchema' {..} = _salt `Prelude.hashWithSalt` schemaArn instance Prelude.NFData DeleteSchema where rnf DeleteSchema' {..} = Prelude.rnf schemaArn instance Data.ToHeaders DeleteSchema where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AmazonPersonalize.DeleteSchema" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DeleteSchema where toJSON DeleteSchema' {..} = Data.object ( Prelude.catMaybes [Prelude.Just ("schemaArn" Data..= schemaArn)] ) instance Data.ToPath DeleteSchema where toPath = Prelude.const "/" instance Data.ToQuery DeleteSchema where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDeleteSchemaResponse' smart constructor. data DeleteSchemaResponse = DeleteSchemaResponse' { } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteSchemaResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. newDeleteSchemaResponse :: DeleteSchemaResponse newDeleteSchemaResponse = DeleteSchemaResponse' instance Prelude.NFData DeleteSchemaResponse where rnf _ = ()