{-# 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.IoTFleetWise.GetVehicleStatus -- 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 information about the status of a vehicle with any associated -- campaigns. -- -- This operation returns paginated results. module Amazonka.IoTFleetWise.GetVehicleStatus ( -- * Creating a Request GetVehicleStatus (..), newGetVehicleStatus, -- * Request Lenses getVehicleStatus_maxResults, getVehicleStatus_nextToken, getVehicleStatus_vehicleName, -- * Destructuring the Response GetVehicleStatusResponse (..), newGetVehicleStatusResponse, -- * Response Lenses getVehicleStatusResponse_campaigns, getVehicleStatusResponse_nextToken, getVehicleStatusResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.IoTFleetWise.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newGetVehicleStatus' smart constructor. data GetVehicleStatus = GetVehicleStatus' { -- | The maximum number of items to return, between 1 and 100, inclusive. maxResults :: Prelude.Maybe Prelude.Natural, -- | A pagination token for the next set of results. -- -- If the results of a search are large, only a portion of the results are -- returned, and a @nextToken@ pagination token is returned in the -- response. To retrieve the next set of results, reissue the search -- request and include the returned token. When all results have been -- returned, the response does not contain a pagination token value. nextToken :: Prelude.Maybe Prelude.Text, -- | The ID of the vehicle to retrieve information about. vehicleName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'GetVehicleStatus' 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: -- -- 'maxResults', 'getVehicleStatus_maxResults' - The maximum number of items to return, between 1 and 100, inclusive. -- -- 'nextToken', 'getVehicleStatus_nextToken' - A pagination token for the next set of results. -- -- If the results of a search are large, only a portion of the results are -- returned, and a @nextToken@ pagination token is returned in the -- response. To retrieve the next set of results, reissue the search -- request and include the returned token. When all results have been -- returned, the response does not contain a pagination token value. -- -- 'vehicleName', 'getVehicleStatus_vehicleName' - The ID of the vehicle to retrieve information about. newGetVehicleStatus :: -- | 'vehicleName' Prelude.Text -> GetVehicleStatus newGetVehicleStatus pVehicleName_ = GetVehicleStatus' { maxResults = Prelude.Nothing, nextToken = Prelude.Nothing, vehicleName = pVehicleName_ } -- | The maximum number of items to return, between 1 and 100, inclusive. getVehicleStatus_maxResults :: Lens.Lens' GetVehicleStatus (Prelude.Maybe Prelude.Natural) getVehicleStatus_maxResults = Lens.lens (\GetVehicleStatus' {maxResults} -> maxResults) (\s@GetVehicleStatus' {} a -> s {maxResults = a} :: GetVehicleStatus) -- | A pagination token for the next set of results. -- -- If the results of a search are large, only a portion of the results are -- returned, and a @nextToken@ pagination token is returned in the -- response. To retrieve the next set of results, reissue the search -- request and include the returned token. When all results have been -- returned, the response does not contain a pagination token value. getVehicleStatus_nextToken :: Lens.Lens' GetVehicleStatus (Prelude.Maybe Prelude.Text) getVehicleStatus_nextToken = Lens.lens (\GetVehicleStatus' {nextToken} -> nextToken) (\s@GetVehicleStatus' {} a -> s {nextToken = a} :: GetVehicleStatus) -- | The ID of the vehicle to retrieve information about. getVehicleStatus_vehicleName :: Lens.Lens' GetVehicleStatus Prelude.Text getVehicleStatus_vehicleName = Lens.lens (\GetVehicleStatus' {vehicleName} -> vehicleName) (\s@GetVehicleStatus' {} a -> s {vehicleName = a} :: GetVehicleStatus) instance Core.AWSPager GetVehicleStatus where page rq rs | Core.stop ( rs Lens.^? getVehicleStatusResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? getVehicleStatusResponse_campaigns Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& getVehicleStatus_nextToken Lens..~ rs Lens.^? getVehicleStatusResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest GetVehicleStatus where type AWSResponse GetVehicleStatus = GetVehicleStatusResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> GetVehicleStatusResponse' Prelude.<$> (x Data..?> "campaigns" Core..!@ Prelude.mempty) Prelude.<*> (x Data..?> "nextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable GetVehicleStatus where hashWithSalt _salt GetVehicleStatus' {..} = _salt `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken `Prelude.hashWithSalt` vehicleName instance Prelude.NFData GetVehicleStatus where rnf GetVehicleStatus' {..} = Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf vehicleName instance Data.ToHeaders GetVehicleStatus where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "IoTAutobahnControlPlane.GetVehicleStatus" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.0" :: Prelude.ByteString ) ] ) instance Data.ToJSON GetVehicleStatus where toJSON GetVehicleStatus' {..} = Data.object ( Prelude.catMaybes [ ("maxResults" Data..=) Prelude.<$> maxResults, ("nextToken" Data..=) Prelude.<$> nextToken, Prelude.Just ("vehicleName" Data..= vehicleName) ] ) instance Data.ToPath GetVehicleStatus where toPath = Prelude.const "/" instance Data.ToQuery GetVehicleStatus where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newGetVehicleStatusResponse' smart constructor. data GetVehicleStatusResponse = GetVehicleStatusResponse' { -- | Lists information about the state of the vehicle with deployed -- campaigns. campaigns :: Prelude.Maybe [VehicleStatus], -- | The token to retrieve the next set of results, or @null@ if there are no -- more results. nextToken :: 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 'GetVehicleStatusResponse' 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: -- -- 'campaigns', 'getVehicleStatusResponse_campaigns' - Lists information about the state of the vehicle with deployed -- campaigns. -- -- 'nextToken', 'getVehicleStatusResponse_nextToken' - The token to retrieve the next set of results, or @null@ if there are no -- more results. -- -- 'httpStatus', 'getVehicleStatusResponse_httpStatus' - The response's http status code. newGetVehicleStatusResponse :: -- | 'httpStatus' Prelude.Int -> GetVehicleStatusResponse newGetVehicleStatusResponse pHttpStatus_ = GetVehicleStatusResponse' { campaigns = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Lists information about the state of the vehicle with deployed -- campaigns. getVehicleStatusResponse_campaigns :: Lens.Lens' GetVehicleStatusResponse (Prelude.Maybe [VehicleStatus]) getVehicleStatusResponse_campaigns = Lens.lens (\GetVehicleStatusResponse' {campaigns} -> campaigns) (\s@GetVehicleStatusResponse' {} a -> s {campaigns = a} :: GetVehicleStatusResponse) Prelude.. Lens.mapping Lens.coerced -- | The token to retrieve the next set of results, or @null@ if there are no -- more results. getVehicleStatusResponse_nextToken :: Lens.Lens' GetVehicleStatusResponse (Prelude.Maybe Prelude.Text) getVehicleStatusResponse_nextToken = Lens.lens (\GetVehicleStatusResponse' {nextToken} -> nextToken) (\s@GetVehicleStatusResponse' {} a -> s {nextToken = a} :: GetVehicleStatusResponse) -- | The response's http status code. getVehicleStatusResponse_httpStatus :: Lens.Lens' GetVehicleStatusResponse Prelude.Int getVehicleStatusResponse_httpStatus = Lens.lens (\GetVehicleStatusResponse' {httpStatus} -> httpStatus) (\s@GetVehicleStatusResponse' {} a -> s {httpStatus = a} :: GetVehicleStatusResponse) instance Prelude.NFData GetVehicleStatusResponse where rnf GetVehicleStatusResponse' {..} = Prelude.rnf campaigns `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus