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