{-# 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.SSO.Logout -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Removes the locally stored SSO tokens from the client-side cache and -- sends an API call to the IAM Identity Center service to invalidate the -- corresponding server-side IAM Identity Center sign in session. -- -- If a user uses IAM Identity Center to access the AWS CLI, the user’s IAM -- Identity Center sign in session is used to obtain an IAM session, as -- specified in the corresponding IAM Identity Center permission set. More -- specifically, IAM Identity Center assumes an IAM role in the target -- account on behalf of the user, and the corresponding temporary AWS -- credentials are returned to the client. -- -- After user logout, any existing IAM role sessions that were created by -- using IAM Identity Center permission sets continue based on the duration -- configured in the permission set. For more information, see -- -- in the /IAM Identity Center User Guide/. module Amazonka.SSO.Logout ( -- * Creating a Request Logout (..), newLogout, -- * Request Lenses logout_accessToken, -- * Destructuring the Response LogoutResponse (..), newLogoutResponse, ) 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.SSO.Types -- | /See:/ 'newLogout' smart constructor. data Logout = Logout' { -- | The token issued by the @CreateToken@ API call. For more information, -- see -- -- in the /IAM Identity Center OIDC API Reference Guide/. accessToken :: Data.Sensitive Prelude.Text } deriving (Prelude.Eq, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'Logout' 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: -- -- 'accessToken', 'logout_accessToken' - The token issued by the @CreateToken@ API call. For more information, -- see -- -- in the /IAM Identity Center OIDC API Reference Guide/. newLogout :: -- | 'accessToken' Prelude.Text -> Logout newLogout pAccessToken_ = Logout' { accessToken = Data._Sensitive Lens.# pAccessToken_ } -- | The token issued by the @CreateToken@ API call. For more information, -- see -- -- in the /IAM Identity Center OIDC API Reference Guide/. logout_accessToken :: Lens.Lens' Logout Prelude.Text logout_accessToken = Lens.lens (\Logout' {accessToken} -> accessToken) (\s@Logout' {} a -> s {accessToken = a} :: Logout) Prelude.. Data._Sensitive instance Core.AWSRequest Logout where type AWSResponse Logout = LogoutResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveNull LogoutResponse' instance Prelude.Hashable Logout where hashWithSalt _salt Logout' {..} = _salt `Prelude.hashWithSalt` accessToken instance Prelude.NFData Logout where rnf Logout' {..} = Prelude.rnf accessToken instance Data.ToHeaders Logout where toHeaders Logout' {..} = Prelude.mconcat [ "x-amz-sso_bearer_token" Data.=# accessToken, "Content-Type" Data.=# ("application/x-amz-json-1.1" :: Prelude.ByteString) ] instance Data.ToJSON Logout where toJSON = Prelude.const (Data.Object Prelude.mempty) instance Data.ToPath Logout where toPath = Prelude.const "/logout" instance Data.ToQuery Logout where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newLogoutResponse' smart constructor. data LogoutResponse = LogoutResponse' { } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'LogoutResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. newLogoutResponse :: LogoutResponse newLogoutResponse = LogoutResponse' instance Prelude.NFData LogoutResponse where rnf _ = ()