{-# 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.DisableDirectory -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Disables the specified directory. Disabled directories cannot be read or -- written to. Only enabled directories can be disabled. Disabled -- directories may be reenabled. module Amazonka.CloudDirectory.DisableDirectory ( -- * Creating a Request DisableDirectory (..), newDisableDirectory, -- * Request Lenses disableDirectory_directoryArn, -- * Destructuring the Response DisableDirectoryResponse (..), newDisableDirectoryResponse, -- * Response Lenses disableDirectoryResponse_httpStatus, disableDirectoryResponse_directoryArn, ) 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:/ 'newDisableDirectory' smart constructor. data DisableDirectory = DisableDirectory' { -- | The ARN of the directory to disable. directoryArn :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DisableDirectory' 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: -- -- 'directoryArn', 'disableDirectory_directoryArn' - The ARN of the directory to disable. newDisableDirectory :: -- | 'directoryArn' Prelude.Text -> DisableDirectory newDisableDirectory pDirectoryArn_ = DisableDirectory' {directoryArn = pDirectoryArn_} -- | The ARN of the directory to disable. disableDirectory_directoryArn :: Lens.Lens' DisableDirectory Prelude.Text disableDirectory_directoryArn = Lens.lens (\DisableDirectory' {directoryArn} -> directoryArn) (\s@DisableDirectory' {} a -> s {directoryArn = a} :: DisableDirectory) instance Core.AWSRequest DisableDirectory where type AWSResponse DisableDirectory = DisableDirectoryResponse request overrides = Request.putJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> DisableDirectoryResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) Prelude.<*> (x Data..:> "DirectoryArn") ) instance Prelude.Hashable DisableDirectory where hashWithSalt _salt DisableDirectory' {..} = _salt `Prelude.hashWithSalt` directoryArn instance Prelude.NFData DisableDirectory where rnf DisableDirectory' {..} = Prelude.rnf directoryArn instance Data.ToHeaders DisableDirectory where toHeaders DisableDirectory' {..} = Prelude.mconcat ["x-amz-data-partition" Data.=# directoryArn] instance Data.ToJSON DisableDirectory where toJSON = Prelude.const (Data.Object Prelude.mempty) instance Data.ToPath DisableDirectory where toPath = Prelude.const "/amazonclouddirectory/2017-01-11/directory/disable" instance Data.ToQuery DisableDirectory where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDisableDirectoryResponse' smart constructor. data DisableDirectoryResponse = DisableDirectoryResponse' { -- | The response's http status code. httpStatus :: Prelude.Int, -- | The ARN of the directory that has been disabled. directoryArn :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DisableDirectoryResponse' 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', 'disableDirectoryResponse_httpStatus' - The response's http status code. -- -- 'directoryArn', 'disableDirectoryResponse_directoryArn' - The ARN of the directory that has been disabled. newDisableDirectoryResponse :: -- | 'httpStatus' Prelude.Int -> -- | 'directoryArn' Prelude.Text -> DisableDirectoryResponse newDisableDirectoryResponse pHttpStatus_ pDirectoryArn_ = DisableDirectoryResponse' { httpStatus = pHttpStatus_, directoryArn = pDirectoryArn_ } -- | The response's http status code. disableDirectoryResponse_httpStatus :: Lens.Lens' DisableDirectoryResponse Prelude.Int disableDirectoryResponse_httpStatus = Lens.lens (\DisableDirectoryResponse' {httpStatus} -> httpStatus) (\s@DisableDirectoryResponse' {} a -> s {httpStatus = a} :: DisableDirectoryResponse) -- | The ARN of the directory that has been disabled. disableDirectoryResponse_directoryArn :: Lens.Lens' DisableDirectoryResponse Prelude.Text disableDirectoryResponse_directoryArn = Lens.lens (\DisableDirectoryResponse' {directoryArn} -> directoryArn) (\s@DisableDirectoryResponse' {} a -> s {directoryArn = a} :: DisableDirectoryResponse) instance Prelude.NFData DisableDirectoryResponse where rnf DisableDirectoryResponse' {..} = Prelude.rnf httpStatus `Prelude.seq` Prelude.rnf directoryArn