git: includeIf 不使用 git clone

Dr.*_*cky 6 git github ssh-keys git-config

.gitconfig

[user]
    name = Dr.jacky
    email = personal.email@gmail.com
    signingKey = ""
[includeIf "gitdir:/Users/drjacky/Projects/CompanyName/"]
    path = /Users/drjacky/gitconfigcompanyname/.gitconfig
[core]
    excludesfile = /Users/drjacky/.gitignore_global
    autocrlf = input
[difftool "sourcetree"]
    cmd = opendiff \"$LOCAL\" \"$REMOTE\"
    path = 
[mergetool "sourcetree"]
    cmd = /Applications/Sourcetree.app/Contents/Resources/opendiff-w.sh \"$LOCAL\" \"$REMOTE\" -ancestor \"$BASE\" -merge \"$MERGED\"
    trustExitCode = true
[commit]
    template = /Users/drjacky/.stCommitMsg
    gpgSign = false
[gpg]
    program = gpg
[tag]
    forceSignAnnotated = false

Run Code Online (Sandbox Code Playgroud)

gitconfigcompanyname/.gitconfig

[user]
    name = My Name
    email = my.company.email@company.com

Run Code Online (Sandbox Code Playgroud)

.ssh/配置


# --- Sourcetree Generated ---
Host Personal-GitHub
    HostName github.com
    User Drjacky
    PreferredAuthentications publickey
# IdentityFile /Users/drjacky/.ssh/Personal-GitHub
    IdentityFile ~/.ssh/id_rsa
    UseKeychain yes
    AddKeysToAgent yes
# ----------------------------
# Company Work GitHub
Host github.com/Company
    HostName github.com
    PreferredAuthentications publickey
    IdentityFile ~/.ssh/id_rsa_companyname
    UseKeychain yes
    AddKeysToAgent yes

Run Code Online (Sandbox Code Playgroud)

我已经通过添加了第二个 ssh pub ssh-add

现在,在终端/iTerm2 上,我重定向到/Users/drjacky/Projects/CompanyName/HERE,然后运行以下命令: git clone httpUrlOfMyCompanyRepogit clone sshOfMyCompanyRepo; 没关系,它没有访问权限:

远程:未找到存储库。致命:找不到存储库“https://github.com/CompanyName/reponame.git/”

当我git config user.email在 CompanyName 文件夹路径下运行时,它会显示我的个人电子邮件。

当我跑步时git config --list

credential.helper=osxkeychain
user.name=Dr.jacky
user.email=personal.email@gmail.com
user.signingkey=
includeif.gitdir:/Users/drjacky/Projectz/CompanyName/.path=/Users/drjacky/gitconfigcompanyname/.gitconfig
core.excludesfile=/Users/drjacky/.gitignore_global
core.autocrlf=input
difftool.sourcetree.cmd=opendiff "$LOCAL" "$REMOTE"
difftool.sourcetree.path=
mergetool.sourcetree.cmd=/Applications/Sourcetree.app/Contents/Resources/opendiff-w.sh "$LOCAL" "$REMOTE" -ancestor "$BASE" -merge "$MERGED"
mergetool.sourcetree.trustexitcode=true
commit.template=/Users/drjacky/.stCommitMsg
commit.gpgsign=false
gpg.program=gpg
tag.forcesignannotated=false
(END)
Run Code Online (Sandbox Code Playgroud)

git bugreport:

[System Info]
git version:
git version 2.28.0
cpu: x86_64
no commit associated with this build
sizeof-long: 8
sizeof-size_t: 8
shell-path: /bin/sh
uname: Darwin 19.6.0 Darwin Kernel Version 19.6.0: Sun Jul  5 00:43:10 PDT 2020; root:xnu-6153.141.1~9/RELEASE_X86_64 x86_64
compiler info: clang: 11.0.3 (clang-1103.0.32.62)
libc info: no libc information available
$SHELL (typically, interactive shell): /bin/zsh
Run Code Online (Sandbox Code Playgroud)

注意事项

  • 我已经卸载了 SourceTree 但没有帮助。
  • git 版本 2.28.0
  • 使用工具成功克隆存储库后,它可以正常工作,没有问题。

更新: 我检查了 Github 仪表板上的 SSH 部分,它显示 SSH 密钥根本没有被使用!

在此输入图像描述

Dr.*_*cky 7

我不得不Host github.com/Company改为Host github.com-Companyin ssh/config。然后,像这样克隆: git clone git@github.com-Company:Company/repoName.git

但是,仍然希望有更好的解决方案,而不是更改 ssh 地址/HTTP URL。

资料来源:

更新:

根据此评论
个人.gitconfig的个人/其他项目:

[user]
    name = Dr.jacky
    email = email@personal.com
[core]
    sshCommand = ssh -i ~/.ssh/id_rsa -F /dev/null
Run Code Online (Sandbox Code Playgroud)

.gitconfig为公司项目工作:

[user]
    name = Work Name
    email = work@company.com
[core]
    sshCommand = ssh -i ~/.ssh/id_rsa_companyname -F /dev/null
Run Code Online (Sandbox Code Playgroud)

并将全局更改.gitconfig为:

[user]
    name = Dr.jacky
    email = email@personal.com
    signingKey = ""
[includeIf "gitdir:/Users/drjacky/*"]
    path = /Users/drjacky/gitconfigpersonal/.gitconfig
[includeIf "gitdir:/Users/drjacky/Projectz/CompanyName/"]
    path = /Users/drjacky/gitconfigcompanyname/.gitconfig
Run Code Online (Sandbox Code Playgroud)

感谢leddzip