{-# 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.StorageGateway.AddUploadBuffer -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Configures one or more gateway local disks as upload buffer for a -- specified gateway. This operation is supported for the stored volume, -- cached volume, and tape gateway types. -- -- In the request, you specify the gateway Amazon Resource Name (ARN) to -- which you want to add upload buffer, and one or more disk IDs that you -- want to configure as upload buffer. module Amazonka.StorageGateway.AddUploadBuffer ( -- * Creating a Request AddUploadBuffer (..), newAddUploadBuffer, -- * Request Lenses addUploadBuffer_gatewayARN, addUploadBuffer_diskIds, -- * Destructuring the Response AddUploadBufferResponse (..), newAddUploadBufferResponse, -- * Response Lenses addUploadBufferResponse_gatewayARN, addUploadBufferResponse_httpStatus, ) where 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 import Amazonka.StorageGateway.Types -- | /See:/ 'newAddUploadBuffer' smart constructor. data AddUploadBuffer = AddUploadBuffer' { gatewayARN :: Prelude.Text, -- | An array of strings that identify disks that are to be configured as -- working storage. Each string has a minimum length of 1 and maximum -- length of 300. You can get the disk IDs from the ListLocalDisks API. diskIds :: [Prelude.Text] } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'AddUploadBuffer' 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: -- -- 'gatewayARN', 'addUploadBuffer_gatewayARN' - Undocumented member. -- -- 'diskIds', 'addUploadBuffer_diskIds' - An array of strings that identify disks that are to be configured as -- working storage. Each string has a minimum length of 1 and maximum -- length of 300. You can get the disk IDs from the ListLocalDisks API. newAddUploadBuffer :: -- | 'gatewayARN' Prelude.Text -> AddUploadBuffer newAddUploadBuffer pGatewayARN_ = AddUploadBuffer' { gatewayARN = pGatewayARN_, diskIds = Prelude.mempty } -- | Undocumented member. addUploadBuffer_gatewayARN :: Lens.Lens' AddUploadBuffer Prelude.Text addUploadBuffer_gatewayARN = Lens.lens (\AddUploadBuffer' {gatewayARN} -> gatewayARN) (\s@AddUploadBuffer' {} a -> s {gatewayARN = a} :: AddUploadBuffer) -- | An array of strings that identify disks that are to be configured as -- working storage. Each string has a minimum length of 1 and maximum -- length of 300. You can get the disk IDs from the ListLocalDisks API. addUploadBuffer_diskIds :: Lens.Lens' AddUploadBuffer [Prelude.Text] addUploadBuffer_diskIds = Lens.lens (\AddUploadBuffer' {diskIds} -> diskIds) (\s@AddUploadBuffer' {} a -> s {diskIds = a} :: AddUploadBuffer) Prelude.. Lens.coerced instance Core.AWSRequest AddUploadBuffer where type AWSResponse AddUploadBuffer = AddUploadBufferResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> AddUploadBufferResponse' Prelude.<$> (x Data..?> "GatewayARN") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable AddUploadBuffer where hashWithSalt _salt AddUploadBuffer' {..} = _salt `Prelude.hashWithSalt` gatewayARN `Prelude.hashWithSalt` diskIds instance Prelude.NFData AddUploadBuffer where rnf AddUploadBuffer' {..} = Prelude.rnf gatewayARN `Prelude.seq` Prelude.rnf diskIds instance Data.ToHeaders AddUploadBuffer where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "StorageGateway_20130630.AddUploadBuffer" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON AddUploadBuffer where toJSON AddUploadBuffer' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("GatewayARN" Data..= gatewayARN), Prelude.Just ("DiskIds" Data..= diskIds) ] ) instance Data.ToPath AddUploadBuffer where toPath = Prelude.const "/" instance Data.ToQuery AddUploadBuffer where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newAddUploadBufferResponse' smart constructor. data AddUploadBufferResponse = AddUploadBufferResponse' { gatewayARN :: Prelude.Maybe Prelude.Text, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'AddUploadBufferResponse' 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: -- -- 'gatewayARN', 'addUploadBufferResponse_gatewayARN' - Undocumented member. -- -- 'httpStatus', 'addUploadBufferResponse_httpStatus' - The response's http status code. newAddUploadBufferResponse :: -- | 'httpStatus' Prelude.Int -> AddUploadBufferResponse newAddUploadBufferResponse pHttpStatus_ = AddUploadBufferResponse' { gatewayARN = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Undocumented member. addUploadBufferResponse_gatewayARN :: Lens.Lens' AddUploadBufferResponse (Prelude.Maybe Prelude.Text) addUploadBufferResponse_gatewayARN = Lens.lens (\AddUploadBufferResponse' {gatewayARN} -> gatewayARN) (\s@AddUploadBufferResponse' {} a -> s {gatewayARN = a} :: AddUploadBufferResponse) -- | The response's http status code. addUploadBufferResponse_httpStatus :: Lens.Lens' AddUploadBufferResponse Prelude.Int addUploadBufferResponse_httpStatus = Lens.lens (\AddUploadBufferResponse' {httpStatus} -> httpStatus) (\s@AddUploadBufferResponse' {} a -> s {httpStatus = a} :: AddUploadBufferResponse) instance Prelude.NFData AddUploadBufferResponse where rnf AddUploadBufferResponse' {..} = Prelude.rnf gatewayARN `Prelude.seq` Prelude.rnf httpStatus