{-# 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.IoTAnalytics.SampleChannelData -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Retrieves a sample of messages from the specified channel ingested -- during the specified timeframe. Up to 10 messages can be retrieved. module Amazonka.IoTAnalytics.SampleChannelData ( -- * Creating a Request SampleChannelData (..), newSampleChannelData, -- * Request Lenses sampleChannelData_endTime, sampleChannelData_maxMessages, sampleChannelData_startTime, sampleChannelData_channelName, -- * Destructuring the Response SampleChannelDataResponse (..), newSampleChannelDataResponse, -- * Response Lenses sampleChannelDataResponse_payloads, sampleChannelDataResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.IoTAnalytics.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newSampleChannelData' smart constructor. data SampleChannelData = SampleChannelData' { -- | The end of the time window from which sample messages are retrieved. endTime :: Prelude.Maybe Data.POSIX, -- | The number of sample messages to be retrieved. The limit is 10. The -- default is also 10. maxMessages :: Prelude.Maybe Prelude.Natural, -- | The start of the time window from which sample messages are retrieved. startTime :: Prelude.Maybe Data.POSIX, -- | The name of the channel whose message samples are retrieved. channelName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'SampleChannelData' 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: -- -- 'endTime', 'sampleChannelData_endTime' - The end of the time window from which sample messages are retrieved. -- -- 'maxMessages', 'sampleChannelData_maxMessages' - The number of sample messages to be retrieved. The limit is 10. The -- default is also 10. -- -- 'startTime', 'sampleChannelData_startTime' - The start of the time window from which sample messages are retrieved. -- -- 'channelName', 'sampleChannelData_channelName' - The name of the channel whose message samples are retrieved. newSampleChannelData :: -- | 'channelName' Prelude.Text -> SampleChannelData newSampleChannelData pChannelName_ = SampleChannelData' { endTime = Prelude.Nothing, maxMessages = Prelude.Nothing, startTime = Prelude.Nothing, channelName = pChannelName_ } -- | The end of the time window from which sample messages are retrieved. sampleChannelData_endTime :: Lens.Lens' SampleChannelData (Prelude.Maybe Prelude.UTCTime) sampleChannelData_endTime = Lens.lens (\SampleChannelData' {endTime} -> endTime) (\s@SampleChannelData' {} a -> s {endTime = a} :: SampleChannelData) Prelude.. Lens.mapping Data._Time -- | The number of sample messages to be retrieved. The limit is 10. The -- default is also 10. sampleChannelData_maxMessages :: Lens.Lens' SampleChannelData (Prelude.Maybe Prelude.Natural) sampleChannelData_maxMessages = Lens.lens (\SampleChannelData' {maxMessages} -> maxMessages) (\s@SampleChannelData' {} a -> s {maxMessages = a} :: SampleChannelData) -- | The start of the time window from which sample messages are retrieved. sampleChannelData_startTime :: Lens.Lens' SampleChannelData (Prelude.Maybe Prelude.UTCTime) sampleChannelData_startTime = Lens.lens (\SampleChannelData' {startTime} -> startTime) (\s@SampleChannelData' {} a -> s {startTime = a} :: SampleChannelData) Prelude.. Lens.mapping Data._Time -- | The name of the channel whose message samples are retrieved. sampleChannelData_channelName :: Lens.Lens' SampleChannelData Prelude.Text sampleChannelData_channelName = Lens.lens (\SampleChannelData' {channelName} -> channelName) (\s@SampleChannelData' {} a -> s {channelName = a} :: SampleChannelData) instance Core.AWSRequest SampleChannelData where type AWSResponse SampleChannelData = SampleChannelDataResponse request overrides = Request.get (overrides defaultService) response = Response.receiveJSON ( \s h x -> SampleChannelDataResponse' Prelude.<$> (x Data..?> "payloads") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable SampleChannelData where hashWithSalt _salt SampleChannelData' {..} = _salt `Prelude.hashWithSalt` endTime `Prelude.hashWithSalt` maxMessages `Prelude.hashWithSalt` startTime `Prelude.hashWithSalt` channelName instance Prelude.NFData SampleChannelData where rnf SampleChannelData' {..} = Prelude.rnf endTime `Prelude.seq` Prelude.rnf maxMessages `Prelude.seq` Prelude.rnf startTime `Prelude.seq` Prelude.rnf channelName instance Data.ToHeaders SampleChannelData where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath SampleChannelData where toPath SampleChannelData' {..} = Prelude.mconcat ["/channels/", Data.toBS channelName, "/sample"] instance Data.ToQuery SampleChannelData where toQuery SampleChannelData' {..} = Prelude.mconcat [ "endTime" Data.=: endTime, "maxMessages" Data.=: maxMessages, "startTime" Data.=: startTime ] -- | /See:/ 'newSampleChannelDataResponse' smart constructor. data SampleChannelDataResponse = SampleChannelDataResponse' { -- | The list of message samples. Each sample message is returned as a -- base64-encoded string. payloads :: Prelude.Maybe (Prelude.NonEmpty Data.Base64), -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'SampleChannelDataResponse' 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: -- -- 'payloads', 'sampleChannelDataResponse_payloads' - The list of message samples. Each sample message is returned as a -- base64-encoded string. -- -- 'httpStatus', 'sampleChannelDataResponse_httpStatus' - The response's http status code. newSampleChannelDataResponse :: -- | 'httpStatus' Prelude.Int -> SampleChannelDataResponse newSampleChannelDataResponse pHttpStatus_ = SampleChannelDataResponse' { payloads = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The list of message samples. Each sample message is returned as a -- base64-encoded string. sampleChannelDataResponse_payloads :: Lens.Lens' SampleChannelDataResponse (Prelude.Maybe (Prelude.NonEmpty Prelude.ByteString)) sampleChannelDataResponse_payloads = Lens.lens (\SampleChannelDataResponse' {payloads} -> payloads) (\s@SampleChannelDataResponse' {} a -> s {payloads = a} :: SampleChannelDataResponse) Prelude.. Lens.mapping Lens.coerced -- | The response's http status code. sampleChannelDataResponse_httpStatus :: Lens.Lens' SampleChannelDataResponse Prelude.Int sampleChannelDataResponse_httpStatus = Lens.lens (\SampleChannelDataResponse' {httpStatus} -> httpStatus) (\s@SampleChannelDataResponse' {} a -> s {httpStatus = a} :: SampleChannelDataResponse) instance Prelude.NFData SampleChannelDataResponse where rnf SampleChannelDataResponse' {..} = Prelude.rnf payloads `Prelude.seq` Prelude.rnf httpStatus