{-# 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.IoT.ListTargetsForSecurityProfile -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Lists the targets (thing groups) associated with a given Device Defender -- security profile. -- -- Requires permission to access the -- -- action. -- -- This operation returns paginated results. module Amazonka.IoT.ListTargetsForSecurityProfile ( -- * Creating a Request ListTargetsForSecurityProfile (..), newListTargetsForSecurityProfile, -- * Request Lenses listTargetsForSecurityProfile_maxResults, listTargetsForSecurityProfile_nextToken, listTargetsForSecurityProfile_securityProfileName, -- * Destructuring the Response ListTargetsForSecurityProfileResponse (..), newListTargetsForSecurityProfileResponse, -- * Response Lenses listTargetsForSecurityProfileResponse_nextToken, listTargetsForSecurityProfileResponse_securityProfileTargets, listTargetsForSecurityProfileResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.IoT.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newListTargetsForSecurityProfile' smart constructor. data ListTargetsForSecurityProfile = ListTargetsForSecurityProfile' { -- | The maximum number of results to return at one time. maxResults :: Prelude.Maybe Prelude.Natural, -- | The token for the next set of results. nextToken :: Prelude.Maybe Prelude.Text, -- | The security profile. securityProfileName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListTargetsForSecurityProfile' 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', 'listTargetsForSecurityProfile_maxResults' - The maximum number of results to return at one time. -- -- 'nextToken', 'listTargetsForSecurityProfile_nextToken' - The token for the next set of results. -- -- 'securityProfileName', 'listTargetsForSecurityProfile_securityProfileName' - The security profile. newListTargetsForSecurityProfile :: -- | 'securityProfileName' Prelude.Text -> ListTargetsForSecurityProfile newListTargetsForSecurityProfile pSecurityProfileName_ = ListTargetsForSecurityProfile' { maxResults = Prelude.Nothing, nextToken = Prelude.Nothing, securityProfileName = pSecurityProfileName_ } -- | The maximum number of results to return at one time. listTargetsForSecurityProfile_maxResults :: Lens.Lens' ListTargetsForSecurityProfile (Prelude.Maybe Prelude.Natural) listTargetsForSecurityProfile_maxResults = Lens.lens (\ListTargetsForSecurityProfile' {maxResults} -> maxResults) (\s@ListTargetsForSecurityProfile' {} a -> s {maxResults = a} :: ListTargetsForSecurityProfile) -- | The token for the next set of results. listTargetsForSecurityProfile_nextToken :: Lens.Lens' ListTargetsForSecurityProfile (Prelude.Maybe Prelude.Text) listTargetsForSecurityProfile_nextToken = Lens.lens (\ListTargetsForSecurityProfile' {nextToken} -> nextToken) (\s@ListTargetsForSecurityProfile' {} a -> s {nextToken = a} :: ListTargetsForSecurityProfile) -- | The security profile. listTargetsForSecurityProfile_securityProfileName :: Lens.Lens' ListTargetsForSecurityProfile Prelude.Text listTargetsForSecurityProfile_securityProfileName = Lens.lens (\ListTargetsForSecurityProfile' {securityProfileName} -> securityProfileName) (\s@ListTargetsForSecurityProfile' {} a -> s {securityProfileName = a} :: ListTargetsForSecurityProfile) instance Core.AWSPager ListTargetsForSecurityProfile where page rq rs | Core.stop ( rs Lens.^? listTargetsForSecurityProfileResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? listTargetsForSecurityProfileResponse_securityProfileTargets Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& listTargetsForSecurityProfile_nextToken Lens..~ rs Lens.^? listTargetsForSecurityProfileResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest ListTargetsForSecurityProfile where type AWSResponse ListTargetsForSecurityProfile = ListTargetsForSecurityProfileResponse request overrides = Request.get (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListTargetsForSecurityProfileResponse' Prelude.<$> (x Data..?> "nextToken") Prelude.<*> ( x Data..?> "securityProfileTargets" Core..!@ Prelude.mempty ) Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ListTargetsForSecurityProfile where hashWithSalt _salt ListTargetsForSecurityProfile' {..} = _salt `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken `Prelude.hashWithSalt` securityProfileName instance Prelude.NFData ListTargetsForSecurityProfile where rnf ListTargetsForSecurityProfile' {..} = Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf securityProfileName instance Data.ToHeaders ListTargetsForSecurityProfile where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath ListTargetsForSecurityProfile where toPath ListTargetsForSecurityProfile' {..} = Prelude.mconcat [ "/security-profiles/", Data.toBS securityProfileName, "/targets" ] instance Data.ToQuery ListTargetsForSecurityProfile where toQuery ListTargetsForSecurityProfile' {..} = Prelude.mconcat [ "maxResults" Data.=: maxResults, "nextToken" Data.=: nextToken ] -- | /See:/ 'newListTargetsForSecurityProfileResponse' smart constructor. data ListTargetsForSecurityProfileResponse = ListTargetsForSecurityProfileResponse' { -- | A token that can be used to retrieve the next set of results, or @null@ -- if there are no additional results. nextToken :: Prelude.Maybe Prelude.Text, -- | The thing groups to which the security profile is attached. securityProfileTargets :: Prelude.Maybe [SecurityProfileTarget], -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListTargetsForSecurityProfileResponse' 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: -- -- 'nextToken', 'listTargetsForSecurityProfileResponse_nextToken' - A token that can be used to retrieve the next set of results, or @null@ -- if there are no additional results. -- -- 'securityProfileTargets', 'listTargetsForSecurityProfileResponse_securityProfileTargets' - The thing groups to which the security profile is attached. -- -- 'httpStatus', 'listTargetsForSecurityProfileResponse_httpStatus' - The response's http status code. newListTargetsForSecurityProfileResponse :: -- | 'httpStatus' Prelude.Int -> ListTargetsForSecurityProfileResponse newListTargetsForSecurityProfileResponse pHttpStatus_ = ListTargetsForSecurityProfileResponse' { nextToken = Prelude.Nothing, securityProfileTargets = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | A token that can be used to retrieve the next set of results, or @null@ -- if there are no additional results. listTargetsForSecurityProfileResponse_nextToken :: Lens.Lens' ListTargetsForSecurityProfileResponse (Prelude.Maybe Prelude.Text) listTargetsForSecurityProfileResponse_nextToken = Lens.lens (\ListTargetsForSecurityProfileResponse' {nextToken} -> nextToken) (\s@ListTargetsForSecurityProfileResponse' {} a -> s {nextToken = a} :: ListTargetsForSecurityProfileResponse) -- | The thing groups to which the security profile is attached. listTargetsForSecurityProfileResponse_securityProfileTargets :: Lens.Lens' ListTargetsForSecurityProfileResponse (Prelude.Maybe [SecurityProfileTarget]) listTargetsForSecurityProfileResponse_securityProfileTargets = Lens.lens (\ListTargetsForSecurityProfileResponse' {securityProfileTargets} -> securityProfileTargets) (\s@ListTargetsForSecurityProfileResponse' {} a -> s {securityProfileTargets = a} :: ListTargetsForSecurityProfileResponse) Prelude.. Lens.mapping Lens.coerced -- | The response's http status code. listTargetsForSecurityProfileResponse_httpStatus :: Lens.Lens' ListTargetsForSecurityProfileResponse Prelude.Int listTargetsForSecurityProfileResponse_httpStatus = Lens.lens (\ListTargetsForSecurityProfileResponse' {httpStatus} -> httpStatus) (\s@ListTargetsForSecurityProfileResponse' {} a -> s {httpStatus = a} :: ListTargetsForSecurityProfileResponse) instance Prelude.NFData ListTargetsForSecurityProfileResponse where rnf ListTargetsForSecurityProfileResponse' {..} = Prelude.rnf nextToken `Prelude.seq` Prelude.rnf securityProfileTargets `Prelude.seq` Prelude.rnf httpStatus