{-# 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.DescribeTapeArchives -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Returns a description of specified virtual tapes in the virtual tape -- shelf (VTS). This operation is only supported in the tape gateway type. -- -- If a specific @TapeARN@ is not specified, Storage Gateway returns a -- description of all virtual tapes found in the VTS associated with your -- account. -- -- This operation returns paginated results. module Amazonka.StorageGateway.DescribeTapeArchives ( -- * Creating a Request DescribeTapeArchives (..), newDescribeTapeArchives, -- * Request Lenses describeTapeArchives_limit, describeTapeArchives_marker, describeTapeArchives_tapeARNs, -- * Destructuring the Response DescribeTapeArchivesResponse (..), newDescribeTapeArchivesResponse, -- * Response Lenses describeTapeArchivesResponse_marker, describeTapeArchivesResponse_tapeArchives, describeTapeArchivesResponse_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 -- | DescribeTapeArchivesInput -- -- /See:/ 'newDescribeTapeArchives' smart constructor. data DescribeTapeArchives = DescribeTapeArchives' { -- | Specifies that the number of virtual tapes described be limited to the -- specified number. limit :: Prelude.Maybe Prelude.Natural, -- | An opaque string that indicates the position at which to begin -- describing virtual tapes. marker :: Prelude.Maybe Prelude.Text, -- | Specifies one or more unique Amazon Resource Names (ARNs) that represent -- the virtual tapes you want to describe. tapeARNs :: Prelude.Maybe [Prelude.Text] } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeTapeArchives' 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: -- -- 'limit', 'describeTapeArchives_limit' - Specifies that the number of virtual tapes described be limited to the -- specified number. -- -- 'marker', 'describeTapeArchives_marker' - An opaque string that indicates the position at which to begin -- describing virtual tapes. -- -- 'tapeARNs', 'describeTapeArchives_tapeARNs' - Specifies one or more unique Amazon Resource Names (ARNs) that represent -- the virtual tapes you want to describe. newDescribeTapeArchives :: DescribeTapeArchives newDescribeTapeArchives = DescribeTapeArchives' { limit = Prelude.Nothing, marker = Prelude.Nothing, tapeARNs = Prelude.Nothing } -- | Specifies that the number of virtual tapes described be limited to the -- specified number. describeTapeArchives_limit :: Lens.Lens' DescribeTapeArchives (Prelude.Maybe Prelude.Natural) describeTapeArchives_limit = Lens.lens (\DescribeTapeArchives' {limit} -> limit) (\s@DescribeTapeArchives' {} a -> s {limit = a} :: DescribeTapeArchives) -- | An opaque string that indicates the position at which to begin -- describing virtual tapes. describeTapeArchives_marker :: Lens.Lens' DescribeTapeArchives (Prelude.Maybe Prelude.Text) describeTapeArchives_marker = Lens.lens (\DescribeTapeArchives' {marker} -> marker) (\s@DescribeTapeArchives' {} a -> s {marker = a} :: DescribeTapeArchives) -- | Specifies one or more unique Amazon Resource Names (ARNs) that represent -- the virtual tapes you want to describe. describeTapeArchives_tapeARNs :: Lens.Lens' DescribeTapeArchives (Prelude.Maybe [Prelude.Text]) describeTapeArchives_tapeARNs = Lens.lens (\DescribeTapeArchives' {tapeARNs} -> tapeARNs) (\s@DescribeTapeArchives' {} a -> s {tapeARNs = a} :: DescribeTapeArchives) Prelude.. Lens.mapping Lens.coerced instance Core.AWSPager DescribeTapeArchives where page rq rs | Core.stop ( rs Lens.^? describeTapeArchivesResponse_marker Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? describeTapeArchivesResponse_tapeArchives Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& describeTapeArchives_marker Lens..~ rs Lens.^? describeTapeArchivesResponse_marker Prelude.. Lens._Just instance Core.AWSRequest DescribeTapeArchives where type AWSResponse DescribeTapeArchives = DescribeTapeArchivesResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> DescribeTapeArchivesResponse' Prelude.<$> (x Data..?> "Marker") Prelude.<*> (x Data..?> "TapeArchives" Core..!@ Prelude.mempty) Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DescribeTapeArchives where hashWithSalt _salt DescribeTapeArchives' {..} = _salt `Prelude.hashWithSalt` limit `Prelude.hashWithSalt` marker `Prelude.hashWithSalt` tapeARNs instance Prelude.NFData DescribeTapeArchives where rnf DescribeTapeArchives' {..} = Prelude.rnf limit `Prelude.seq` Prelude.rnf marker `Prelude.seq` Prelude.rnf tapeARNs instance Data.ToHeaders DescribeTapeArchives where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "StorageGateway_20130630.DescribeTapeArchives" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DescribeTapeArchives where toJSON DescribeTapeArchives' {..} = Data.object ( Prelude.catMaybes [ ("Limit" Data..=) Prelude.<$> limit, ("Marker" Data..=) Prelude.<$> marker, ("TapeARNs" Data..=) Prelude.<$> tapeARNs ] ) instance Data.ToPath DescribeTapeArchives where toPath = Prelude.const "/" instance Data.ToQuery DescribeTapeArchives where toQuery = Prelude.const Prelude.mempty -- | DescribeTapeArchivesOutput -- -- /See:/ 'newDescribeTapeArchivesResponse' smart constructor. data DescribeTapeArchivesResponse = DescribeTapeArchivesResponse' { -- | An opaque string that indicates the position at which the virtual tapes -- that were fetched for description ended. Use this marker in your next -- request to fetch the next set of virtual tapes in the virtual tape shelf -- (VTS). If there are no more virtual tapes to describe, this field does -- not appear in the response. marker :: Prelude.Maybe Prelude.Text, -- | An array of virtual tape objects in the virtual tape shelf (VTS). The -- description includes of the Amazon Resource Name (ARN) of the virtual -- tapes. The information returned includes the Amazon Resource Names -- (ARNs) of the tapes, size of the tapes, status of the tapes, progress of -- the description, and tape barcode. tapeArchives :: Prelude.Maybe [TapeArchive], -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeTapeArchivesResponse' 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: -- -- 'marker', 'describeTapeArchivesResponse_marker' - An opaque string that indicates the position at which the virtual tapes -- that were fetched for description ended. Use this marker in your next -- request to fetch the next set of virtual tapes in the virtual tape shelf -- (VTS). If there are no more virtual tapes to describe, this field does -- not appear in the response. -- -- 'tapeArchives', 'describeTapeArchivesResponse_tapeArchives' - An array of virtual tape objects in the virtual tape shelf (VTS). The -- description includes of the Amazon Resource Name (ARN) of the virtual -- tapes. The information returned includes the Amazon Resource Names -- (ARNs) of the tapes, size of the tapes, status of the tapes, progress of -- the description, and tape barcode. -- -- 'httpStatus', 'describeTapeArchivesResponse_httpStatus' - The response's http status code. newDescribeTapeArchivesResponse :: -- | 'httpStatus' Prelude.Int -> DescribeTapeArchivesResponse newDescribeTapeArchivesResponse pHttpStatus_ = DescribeTapeArchivesResponse' { marker = Prelude.Nothing, tapeArchives = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | An opaque string that indicates the position at which the virtual tapes -- that were fetched for description ended. Use this marker in your next -- request to fetch the next set of virtual tapes in the virtual tape shelf -- (VTS). If there are no more virtual tapes to describe, this field does -- not appear in the response. describeTapeArchivesResponse_marker :: Lens.Lens' DescribeTapeArchivesResponse (Prelude.Maybe Prelude.Text) describeTapeArchivesResponse_marker = Lens.lens (\DescribeTapeArchivesResponse' {marker} -> marker) (\s@DescribeTapeArchivesResponse' {} a -> s {marker = a} :: DescribeTapeArchivesResponse) -- | An array of virtual tape objects in the virtual tape shelf (VTS). The -- description includes of the Amazon Resource Name (ARN) of the virtual -- tapes. The information returned includes the Amazon Resource Names -- (ARNs) of the tapes, size of the tapes, status of the tapes, progress of -- the description, and tape barcode. describeTapeArchivesResponse_tapeArchives :: Lens.Lens' DescribeTapeArchivesResponse (Prelude.Maybe [TapeArchive]) describeTapeArchivesResponse_tapeArchives = Lens.lens (\DescribeTapeArchivesResponse' {tapeArchives} -> tapeArchives) (\s@DescribeTapeArchivesResponse' {} a -> s {tapeArchives = a} :: DescribeTapeArchivesResponse) Prelude.. Lens.mapping Lens.coerced -- | The response's http status code. describeTapeArchivesResponse_httpStatus :: Lens.Lens' DescribeTapeArchivesResponse Prelude.Int describeTapeArchivesResponse_httpStatus = Lens.lens (\DescribeTapeArchivesResponse' {httpStatus} -> httpStatus) (\s@DescribeTapeArchivesResponse' {} a -> s {httpStatus = a} :: DescribeTapeArchivesResponse) instance Prelude.NFData DescribeTapeArchivesResponse where rnf DescribeTapeArchivesResponse' {..} = Prelude.rnf marker `Prelude.seq` Prelude.rnf tapeArchives `Prelude.seq` Prelude.rnf httpStatus