{-# 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.IoT.DeprecateThingType -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Deprecates a thing type. You can not associate new things with -- deprecated thing type. -- -- Requires permission to access the -- -- action. module Amazonka.IoT.DeprecateThingType ( -- * Creating a Request DeprecateThingType (..), newDeprecateThingType, -- * Request Lenses deprecateThingType_undoDeprecate, deprecateThingType_thingTypeName, -- * Destructuring the Response DeprecateThingTypeResponse (..), newDeprecateThingTypeResponse, -- * Response Lenses deprecateThingTypeResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.IoT.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | The input for the DeprecateThingType operation. -- -- /See:/ 'newDeprecateThingType' smart constructor. data DeprecateThingType = DeprecateThingType' { -- | Whether to undeprecate a deprecated thing type. If __true__, the thing -- type will not be deprecated anymore and you can associate it with -- things. undoDeprecate :: Prelude.Maybe Prelude.Bool, -- | The name of the thing type to deprecate. thingTypeName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeprecateThingType' 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: -- -- 'undoDeprecate', 'deprecateThingType_undoDeprecate' - Whether to undeprecate a deprecated thing type. If __true__, the thing -- type will not be deprecated anymore and you can associate it with -- things. -- -- 'thingTypeName', 'deprecateThingType_thingTypeName' - The name of the thing type to deprecate. newDeprecateThingType :: -- | 'thingTypeName' Prelude.Text -> DeprecateThingType newDeprecateThingType pThingTypeName_ = DeprecateThingType' { undoDeprecate = Prelude.Nothing, thingTypeName = pThingTypeName_ } -- | Whether to undeprecate a deprecated thing type. If __true__, the thing -- type will not be deprecated anymore and you can associate it with -- things. deprecateThingType_undoDeprecate :: Lens.Lens' DeprecateThingType (Prelude.Maybe Prelude.Bool) deprecateThingType_undoDeprecate = Lens.lens (\DeprecateThingType' {undoDeprecate} -> undoDeprecate) (\s@DeprecateThingType' {} a -> s {undoDeprecate = a} :: DeprecateThingType) -- | The name of the thing type to deprecate. deprecateThingType_thingTypeName :: Lens.Lens' DeprecateThingType Prelude.Text deprecateThingType_thingTypeName = Lens.lens (\DeprecateThingType' {thingTypeName} -> thingTypeName) (\s@DeprecateThingType' {} a -> s {thingTypeName = a} :: DeprecateThingType) instance Core.AWSRequest DeprecateThingType where type AWSResponse DeprecateThingType = DeprecateThingTypeResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveEmpty ( \s h x -> DeprecateThingTypeResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DeprecateThingType where hashWithSalt _salt DeprecateThingType' {..} = _salt `Prelude.hashWithSalt` undoDeprecate `Prelude.hashWithSalt` thingTypeName instance Prelude.NFData DeprecateThingType where rnf DeprecateThingType' {..} = Prelude.rnf undoDeprecate `Prelude.seq` Prelude.rnf thingTypeName instance Data.ToHeaders DeprecateThingType where toHeaders = Prelude.const Prelude.mempty instance Data.ToJSON DeprecateThingType where toJSON DeprecateThingType' {..} = Data.object ( Prelude.catMaybes [ ("undoDeprecate" Data..=) Prelude.<$> undoDeprecate ] ) instance Data.ToPath DeprecateThingType where toPath DeprecateThingType' {..} = Prelude.mconcat [ "/thing-types/", Data.toBS thingTypeName, "/deprecate" ] instance Data.ToQuery DeprecateThingType where toQuery = Prelude.const Prelude.mempty -- | The output for the DeprecateThingType operation. -- -- /See:/ 'newDeprecateThingTypeResponse' smart constructor. data DeprecateThingTypeResponse = DeprecateThingTypeResponse' { -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeprecateThingTypeResponse' 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', 'deprecateThingTypeResponse_httpStatus' - The response's http status code. newDeprecateThingTypeResponse :: -- | 'httpStatus' Prelude.Int -> DeprecateThingTypeResponse newDeprecateThingTypeResponse pHttpStatus_ = DeprecateThingTypeResponse' { httpStatus = pHttpStatus_ } -- | The response's http status code. deprecateThingTypeResponse_httpStatus :: Lens.Lens' DeprecateThingTypeResponse Prelude.Int deprecateThingTypeResponse_httpStatus = Lens.lens (\DeprecateThingTypeResponse' {httpStatus} -> httpStatus) (\s@DeprecateThingTypeResponse' {} a -> s {httpStatus = a} :: DeprecateThingTypeResponse) instance Prelude.NFData DeprecateThingTypeResponse where rnf DeprecateThingTypeResponse' {..} = Prelude.rnf httpStatus