{-# 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.UpdateCodeRepository -- 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 the specified Git repository with the specified values. module Amazonka.SageMaker.UpdateCodeRepository ( -- * Creating a Request UpdateCodeRepository (..), newUpdateCodeRepository, -- * Request Lenses updateCodeRepository_gitConfig, updateCodeRepository_codeRepositoryName, -- * Destructuring the Response UpdateCodeRepositoryResponse (..), newUpdateCodeRepositoryResponse, -- * Response Lenses updateCodeRepositoryResponse_httpStatus, updateCodeRepositoryResponse_codeRepositoryArn, ) 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:/ 'newUpdateCodeRepository' smart constructor. data UpdateCodeRepository = UpdateCodeRepository' { -- | The configuration of the git repository, including the URL and the -- Amazon Resource Name (ARN) of the Amazon Web Services Secrets Manager -- secret that contains the credentials used to access the repository. The -- secret must have a staging label of @AWSCURRENT@ and must be in the -- following format: -- -- @{\"username\": @/@UserName@/@, \"password\": @/@Password@/@}@ gitConfig :: Prelude.Maybe GitConfigForUpdate, -- | The name of the Git repository to update. codeRepositoryName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateCodeRepository' 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: -- -- 'gitConfig', 'updateCodeRepository_gitConfig' - The configuration of the git repository, including the URL and the -- Amazon Resource Name (ARN) of the Amazon Web Services Secrets Manager -- secret that contains the credentials used to access the repository. The -- secret must have a staging label of @AWSCURRENT@ and must be in the -- following format: -- -- @{\"username\": @/@UserName@/@, \"password\": @/@Password@/@}@ -- -- 'codeRepositoryName', 'updateCodeRepository_codeRepositoryName' - The name of the Git repository to update. newUpdateCodeRepository :: -- | 'codeRepositoryName' Prelude.Text -> UpdateCodeRepository newUpdateCodeRepository pCodeRepositoryName_ = UpdateCodeRepository' { gitConfig = Prelude.Nothing, codeRepositoryName = pCodeRepositoryName_ } -- | The configuration of the git repository, including the URL and the -- Amazon Resource Name (ARN) of the Amazon Web Services Secrets Manager -- secret that contains the credentials used to access the repository. The -- secret must have a staging label of @AWSCURRENT@ and must be in the -- following format: -- -- @{\"username\": @/@UserName@/@, \"password\": @/@Password@/@}@ updateCodeRepository_gitConfig :: Lens.Lens' UpdateCodeRepository (Prelude.Maybe GitConfigForUpdate) updateCodeRepository_gitConfig = Lens.lens (\UpdateCodeRepository' {gitConfig} -> gitConfig) (\s@UpdateCodeRepository' {} a -> s {gitConfig = a} :: UpdateCodeRepository) -- | The name of the Git repository to update. updateCodeRepository_codeRepositoryName :: Lens.Lens' UpdateCodeRepository Prelude.Text updateCodeRepository_codeRepositoryName = Lens.lens (\UpdateCodeRepository' {codeRepositoryName} -> codeRepositoryName) (\s@UpdateCodeRepository' {} a -> s {codeRepositoryName = a} :: UpdateCodeRepository) instance Core.AWSRequest UpdateCodeRepository where type AWSResponse UpdateCodeRepository = UpdateCodeRepositoryResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> UpdateCodeRepositoryResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) Prelude.<*> (x Data..:> "CodeRepositoryArn") ) instance Prelude.Hashable UpdateCodeRepository where hashWithSalt _salt UpdateCodeRepository' {..} = _salt `Prelude.hashWithSalt` gitConfig `Prelude.hashWithSalt` codeRepositoryName instance Prelude.NFData UpdateCodeRepository where rnf UpdateCodeRepository' {..} = Prelude.rnf gitConfig `Prelude.seq` Prelude.rnf codeRepositoryName instance Data.ToHeaders UpdateCodeRepository where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "SageMaker.UpdateCodeRepository" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON UpdateCodeRepository where toJSON UpdateCodeRepository' {..} = Data.object ( Prelude.catMaybes [ ("GitConfig" Data..=) Prelude.<$> gitConfig, Prelude.Just ("CodeRepositoryName" Data..= codeRepositoryName) ] ) instance Data.ToPath UpdateCodeRepository where toPath = Prelude.const "/" instance Data.ToQuery UpdateCodeRepository where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newUpdateCodeRepositoryResponse' smart constructor. data UpdateCodeRepositoryResponse = UpdateCodeRepositoryResponse' { -- | The response's http status code. httpStatus :: Prelude.Int, -- | The ARN of the Git repository. codeRepositoryArn :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateCodeRepositoryResponse' 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', 'updateCodeRepositoryResponse_httpStatus' - The response's http status code. -- -- 'codeRepositoryArn', 'updateCodeRepositoryResponse_codeRepositoryArn' - The ARN of the Git repository. newUpdateCodeRepositoryResponse :: -- | 'httpStatus' Prelude.Int -> -- | 'codeRepositoryArn' Prelude.Text -> UpdateCodeRepositoryResponse newUpdateCodeRepositoryResponse pHttpStatus_ pCodeRepositoryArn_ = UpdateCodeRepositoryResponse' { httpStatus = pHttpStatus_, codeRepositoryArn = pCodeRepositoryArn_ } -- | The response's http status code. updateCodeRepositoryResponse_httpStatus :: Lens.Lens' UpdateCodeRepositoryResponse Prelude.Int updateCodeRepositoryResponse_httpStatus = Lens.lens (\UpdateCodeRepositoryResponse' {httpStatus} -> httpStatus) (\s@UpdateCodeRepositoryResponse' {} a -> s {httpStatus = a} :: UpdateCodeRepositoryResponse) -- | The ARN of the Git repository. updateCodeRepositoryResponse_codeRepositoryArn :: Lens.Lens' UpdateCodeRepositoryResponse Prelude.Text updateCodeRepositoryResponse_codeRepositoryArn = Lens.lens (\UpdateCodeRepositoryResponse' {codeRepositoryArn} -> codeRepositoryArn) (\s@UpdateCodeRepositoryResponse' {} a -> s {codeRepositoryArn = a} :: UpdateCodeRepositoryResponse) instance Prelude.NFData UpdateCodeRepositoryResponse where rnf UpdateCodeRepositoryResponse' {..} = Prelude.rnf httpStatus `Prelude.seq` Prelude.rnf codeRepositoryArn