我正在尝试导入位于 AWS codecommit 中的模块。为了克隆存储库,我使用 HTTPS GRC(Git 远程代码提交)方法,该方法使用 Google Suite 凭证来访问 AWS 控制台。
我用来克隆存储库的命令是:
git clone codecommit::us-west-2://my-module
远程模块的go.mod
文件包含以下内容:
module git-codecommit.us-west-2.amazonaws.com/my-module.git
我尝试这样配置 Git 来实现我的目标:
git config --global url."codecommit::us-west-2://".insteadOf "https://git-codecommit.us-west-2.amazonaws.com/"
设置为私有:
go env -w GOPRIVATE=git-codecommit.us-west-2.amazonaws.com/my-module.git
然后获取存储库:
go get -x git-codecommit.us-west-2.amazonaws.com/my-module.git
但我得到这个输出(并且执行被卡住):
cd.
git ls-remote https://git-codecommit.us-west-2.amazonaws.com/my-module
我想提一下,当我执行git ls-remote https://git-codecommit.us-west-2.amazonaws.com/my-module
手动命令我毫无问题地获取分支和标签的信息。
我检查了这个话题 https://stackoverflow.com/questions/53299355/go-get-a-private-repo-from-codecommit/但在这种情况下,使用 SSH 协议而不是 HTTP GRC。也许从私有存储库导入模块的唯一方法是通过 SSH?
终于找到了解决办法:
设置 Git 凭证助手:
git config --global credential.helper '!aws codecommit credential-helper $@'
git config --global credential.UseHttpPath true
设置 GOPRIVATE 环境变量:
go env -w GOPRIVATE=git-codecommit.us-west-2.amazonaws.com
在 MacOS 中,禁用 Git 的钥匙串:
Comment helper = osxkeychain
在包含该值的文件中(运行git config -l --show-origin | grep credential
找到目标文件)
运行获取:
go get git-codecommit.us-west-2.amazonaws.com/v1/repos/my-module.git
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)