{-# 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.WorkSpacesWeb.GetUserSettings -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Gets user settings. module Amazonka.WorkSpacesWeb.GetUserSettings ( -- * Creating a Request GetUserSettings (..), newGetUserSettings, -- * Request Lenses getUserSettings_userSettingsArn, -- * Destructuring the Response GetUserSettingsResponse (..), newGetUserSettingsResponse, -- * Response Lenses getUserSettingsResponse_userSettings, getUserSettingsResponse_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.WorkSpacesWeb.Types -- | /See:/ 'newGetUserSettings' smart constructor. data GetUserSettings = GetUserSettings' { -- | The ARN of the user settings. userSettingsArn :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'GetUserSettings' 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: -- -- 'userSettingsArn', 'getUserSettings_userSettingsArn' - The ARN of the user settings. newGetUserSettings :: -- | 'userSettingsArn' Prelude.Text -> GetUserSettings newGetUserSettings pUserSettingsArn_ = GetUserSettings' { userSettingsArn = pUserSettingsArn_ } -- | The ARN of the user settings. getUserSettings_userSettingsArn :: Lens.Lens' GetUserSettings Prelude.Text getUserSettings_userSettingsArn = Lens.lens (\GetUserSettings' {userSettingsArn} -> userSettingsArn) (\s@GetUserSettings' {} a -> s {userSettingsArn = a} :: GetUserSettings) instance Core.AWSRequest GetUserSettings where type AWSResponse GetUserSettings = GetUserSettingsResponse request overrides = Request.get (overrides defaultService) response = Response.receiveJSON ( \s h x -> GetUserSettingsResponse' Prelude.<$> (x Data..?> "userSettings") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable GetUserSettings where hashWithSalt _salt GetUserSettings' {..} = _salt `Prelude.hashWithSalt` userSettingsArn instance Prelude.NFData GetUserSettings where rnf GetUserSettings' {..} = Prelude.rnf userSettingsArn instance Data.ToHeaders GetUserSettings where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToPath GetUserSettings where toPath GetUserSettings' {..} = Prelude.mconcat ["/userSettings/", Data.toBS userSettingsArn] instance Data.ToQuery GetUserSettings where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newGetUserSettingsResponse' smart constructor. data GetUserSettingsResponse = GetUserSettingsResponse' { -- | The user settings. userSettings :: Prelude.Maybe UserSettings, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'GetUserSettingsResponse' 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: -- -- 'userSettings', 'getUserSettingsResponse_userSettings' - The user settings. -- -- 'httpStatus', 'getUserSettingsResponse_httpStatus' - The response's http status code. newGetUserSettingsResponse :: -- | 'httpStatus' Prelude.Int -> GetUserSettingsResponse newGetUserSettingsResponse pHttpStatus_ = GetUserSettingsResponse' { userSettings = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The user settings. getUserSettingsResponse_userSettings :: Lens.Lens' GetUserSettingsResponse (Prelude.Maybe UserSettings) getUserSettingsResponse_userSettings = Lens.lens (\GetUserSettingsResponse' {userSettings} -> userSettings) (\s@GetUserSettingsResponse' {} a -> s {userSettings = a} :: GetUserSettingsResponse) -- | The response's http status code. getUserSettingsResponse_httpStatus :: Lens.Lens' GetUserSettingsResponse Prelude.Int getUserSettingsResponse_httpStatus = Lens.lens (\GetUserSettingsResponse' {httpStatus} -> httpStatus) (\s@GetUserSettingsResponse' {} a -> s {httpStatus = a} :: GetUserSettingsResponse) instance Prelude.NFData GetUserSettingsResponse where rnf GetUserSettingsResponse' {..} = Prelude.rnf userSettings `Prelude.seq` Prelude.rnf httpStatus