{-# 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.SageMaker.UpdateWorkteam -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Updates an existing work team with new member definitions or -- description. module Amazonka.SageMaker.UpdateWorkteam ( -- * Creating a Request UpdateWorkteam (..), newUpdateWorkteam, -- * Request Lenses updateWorkteam_description, updateWorkteam_memberDefinitions, updateWorkteam_notificationConfiguration, updateWorkteam_workteamName, -- * Destructuring the Response UpdateWorkteamResponse (..), newUpdateWorkteamResponse, -- * Response Lenses updateWorkteamResponse_httpStatus, updateWorkteamResponse_workteam, ) 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.SageMaker.Types -- | /See:/ 'newUpdateWorkteam' smart constructor. data UpdateWorkteam = UpdateWorkteam' { -- | An updated description for the work team. description :: Prelude.Maybe Prelude.Text, -- | A list of @MemberDefinition@ objects that contains objects that identify -- the workers that make up the work team. -- -- Workforces can be created using Amazon Cognito or your own OIDC Identity -- Provider (IdP). For private workforces created using Amazon Cognito use -- @CognitoMemberDefinition@. For workforces created using your own OIDC -- identity provider (IdP) use @OidcMemberDefinition@. You should not -- provide input for both of these parameters in a single request. -- -- For workforces created using Amazon Cognito, private work teams -- correspond to Amazon Cognito /user groups/ within the user pool used to -- create a workforce. All of the @CognitoMemberDefinition@ objects that -- make up the member definition must have the same @ClientId@ and -- @UserPool@ values. To add a Amazon Cognito user group to an existing -- worker pool, see < Adding groups to a User Pool>. For more information -- about user pools, see -- . -- -- For workforces created using your own OIDC IdP, specify the user groups -- that you want to include in your private work team in -- @OidcMemberDefinition@ by listing those groups in @Groups@. Be aware -- that user groups that are already in the work team must also be listed -- in @Groups@ when you make this request to remain on the work team. If -- you do not include these user groups, they will no longer be associated -- with the work team you update. memberDefinitions :: Prelude.Maybe (Prelude.NonEmpty MemberDefinition), -- | Configures SNS topic notifications for available or expiring work items notificationConfiguration :: Prelude.Maybe NotificationConfiguration, -- | The name of the work team to update. workteamName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateWorkteam' 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: -- -- 'description', 'updateWorkteam_description' - An updated description for the work team. -- -- 'memberDefinitions', 'updateWorkteam_memberDefinitions' - A list of @MemberDefinition@ objects that contains objects that identify -- the workers that make up the work team. -- -- Workforces can be created using Amazon Cognito or your own OIDC Identity -- Provider (IdP). For private workforces created using Amazon Cognito use -- @CognitoMemberDefinition@. For workforces created using your own OIDC -- identity provider (IdP) use @OidcMemberDefinition@. You should not -- provide input for both of these parameters in a single request. -- -- For workforces created using Amazon Cognito, private work teams -- correspond to Amazon Cognito /user groups/ within the user pool used to -- create a workforce. All of the @CognitoMemberDefinition@ objects that -- make up the member definition must have the same @ClientId@ and -- @UserPool@ values. To add a Amazon Cognito user group to an existing -- worker pool, see < Adding groups to a User Pool>. For more information -- about user pools, see -- . -- -- For workforces created using your own OIDC IdP, specify the user groups -- that you want to include in your private work team in -- @OidcMemberDefinition@ by listing those groups in @Groups@. Be aware -- that user groups that are already in the work team must also be listed -- in @Groups@ when you make this request to remain on the work team. If -- you do not include these user groups, they will no longer be associated -- with the work team you update. -- -- 'notificationConfiguration', 'updateWorkteam_notificationConfiguration' - Configures SNS topic notifications for available or expiring work items -- -- 'workteamName', 'updateWorkteam_workteamName' - The name of the work team to update. newUpdateWorkteam :: -- | 'workteamName' Prelude.Text -> UpdateWorkteam newUpdateWorkteam pWorkteamName_ = UpdateWorkteam' { description = Prelude.Nothing, memberDefinitions = Prelude.Nothing, notificationConfiguration = Prelude.Nothing, workteamName = pWorkteamName_ } -- | An updated description for the work team. updateWorkteam_description :: Lens.Lens' UpdateWorkteam (Prelude.Maybe Prelude.Text) updateWorkteam_description = Lens.lens (\UpdateWorkteam' {description} -> description) (\s@UpdateWorkteam' {} a -> s {description = a} :: UpdateWorkteam) -- | A list of @MemberDefinition@ objects that contains objects that identify -- the workers that make up the work team. -- -- Workforces can be created using Amazon Cognito or your own OIDC Identity -- Provider (IdP). For private workforces created using Amazon Cognito use -- @CognitoMemberDefinition@. For workforces created using your own OIDC -- identity provider (IdP) use @OidcMemberDefinition@. You should not -- provide input for both of these parameters in a single request. -- -- For workforces created using Amazon Cognito, private work teams -- correspond to Amazon Cognito /user groups/ within the user pool used to -- create a workforce. All of the @CognitoMemberDefinition@ objects that -- make up the member definition must have the same @ClientId@ and -- @UserPool@ values. To add a Amazon Cognito user group to an existing -- worker pool, see < Adding groups to a User Pool>. For more information -- about user pools, see -- . -- -- For workforces created using your own OIDC IdP, specify the user groups -- that you want to include in your private work team in -- @OidcMemberDefinition@ by listing those groups in @Groups@. Be aware -- that user groups that are already in the work team must also be listed -- in @Groups@ when you make this request to remain on the work team. If -- you do not include these user groups, they will no longer be associated -- with the work team you update. updateWorkteam_memberDefinitions :: Lens.Lens' UpdateWorkteam (Prelude.Maybe (Prelude.NonEmpty MemberDefinition)) updateWorkteam_memberDefinitions = Lens.lens (\UpdateWorkteam' {memberDefinitions} -> memberDefinitions) (\s@UpdateWorkteam' {} a -> s {memberDefinitions = a} :: UpdateWorkteam) Prelude.. Lens.mapping Lens.coerced -- | Configures SNS topic notifications for available or expiring work items updateWorkteam_notificationConfiguration :: Lens.Lens' UpdateWorkteam (Prelude.Maybe NotificationConfiguration) updateWorkteam_notificationConfiguration = Lens.lens (\UpdateWorkteam' {notificationConfiguration} -> notificationConfiguration) (\s@UpdateWorkteam' {} a -> s {notificationConfiguration = a} :: UpdateWorkteam) -- | The name of the work team to update. updateWorkteam_workteamName :: Lens.Lens' UpdateWorkteam Prelude.Text updateWorkteam_workteamName = Lens.lens (\UpdateWorkteam' {workteamName} -> workteamName) (\s@UpdateWorkteam' {} a -> s {workteamName = a} :: UpdateWorkteam) instance Core.AWSRequest UpdateWorkteam where type AWSResponse UpdateWorkteam = UpdateWorkteamResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> UpdateWorkteamResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) Prelude.<*> (x Data..:> "Workteam") ) instance Prelude.Hashable UpdateWorkteam where hashWithSalt _salt UpdateWorkteam' {..} = _salt `Prelude.hashWithSalt` description `Prelude.hashWithSalt` memberDefinitions `Prelude.hashWithSalt` notificationConfiguration `Prelude.hashWithSalt` workteamName instance Prelude.NFData UpdateWorkteam where rnf UpdateWorkteam' {..} = Prelude.rnf description `Prelude.seq` Prelude.rnf memberDefinitions `Prelude.seq` Prelude.rnf notificationConfiguration `Prelude.seq` Prelude.rnf workteamName instance Data.ToHeaders UpdateWorkteam where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ("SageMaker.UpdateWorkteam" :: Prelude.ByteString), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON UpdateWorkteam where toJSON UpdateWorkteam' {..} = Data.object ( Prelude.catMaybes [ ("Description" Data..=) Prelude.<$> description, ("MemberDefinitions" Data..=) Prelude.<$> memberDefinitions, ("NotificationConfiguration" Data..=) Prelude.<$> notificationConfiguration, Prelude.Just ("WorkteamName" Data..= workteamName) ] ) instance Data.ToPath UpdateWorkteam where toPath = Prelude.const "/" instance Data.ToQuery UpdateWorkteam where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newUpdateWorkteamResponse' smart constructor. data UpdateWorkteamResponse = UpdateWorkteamResponse' { -- | The response's http status code. httpStatus :: Prelude.Int, -- | A @Workteam@ object that describes the updated work team. workteam :: Workteam } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateWorkteamResponse' 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: -- -- 'httpStatus', 'updateWorkteamResponse_httpStatus' - The response's http status code. -- -- 'workteam', 'updateWorkteamResponse_workteam' - A @Workteam@ object that describes the updated work team. newUpdateWorkteamResponse :: -- | 'httpStatus' Prelude.Int -> -- | 'workteam' Workteam -> UpdateWorkteamResponse newUpdateWorkteamResponse pHttpStatus_ pWorkteam_ = UpdateWorkteamResponse' { httpStatus = pHttpStatus_, workteam = pWorkteam_ } -- | The response's http status code. updateWorkteamResponse_httpStatus :: Lens.Lens' UpdateWorkteamResponse Prelude.Int updateWorkteamResponse_httpStatus = Lens.lens (\UpdateWorkteamResponse' {httpStatus} -> httpStatus) (\s@UpdateWorkteamResponse' {} a -> s {httpStatus = a} :: UpdateWorkteamResponse) -- | A @Workteam@ object that describes the updated work team. updateWorkteamResponse_workteam :: Lens.Lens' UpdateWorkteamResponse Workteam updateWorkteamResponse_workteam = Lens.lens (\UpdateWorkteamResponse' {workteam} -> workteam) (\s@UpdateWorkteamResponse' {} a -> s {workteam = a} :: UpdateWorkteamResponse) instance Prelude.NFData UpdateWorkteamResponse where rnf UpdateWorkteamResponse' {..} = Prelude.rnf httpStatus `Prelude.seq` Prelude.rnf workteam