近期遇到一个git提交的问题,由于公司增加了commit中邮箱校验,非本公司内部邮箱无法提交.
问题:
已提交的commit信息中存在通过私人邮箱提交的历史记录,导致新拉分支时触发校验逻辑新分支拉取失败.
解决思路:
将所有提交中非企业邮箱的commit节点替换成企业邮箱
解法:
1.对应git上要有owner权限(第四步push需要owner权限)
2.包含错误commit节点的所有分支拉本地分支
3.修改脚本中中文部分,并运行
脚本1为统一将非法邮箱全量修改成某一合法邮箱 张三@qq.com,李四@126.com 统一改成 normal@niuxcompany.com
#!/bin/sh
git filter-branch --env-filter '
EMAIL_SUFFIX="公司公司邮箱后缀"
CORRECT_NAME="提交者名字"
CORRECT_EMAIL="默认统一修改成新邮箱"
if [[ "$GIT_COMMITTER_EMAIL" != *$EMAIL_SUFFIX ]]
then
export GIT_COMMITTER_NAME="$CORRECT_NAME"
export GIT_COMMITTER_EMAIL="$CORRECT_EMAIL"
fi
if [[ "$GIT_AUTHOR_EMAIL" != *$EMAIL_SUFFIX ]]
then
export GIT_AUTHOR_NAME="$CORRECT_NAME"
export GIT_AUTHOR_EMAIL="$CORRECT_EMAIL"
fi
' --tag-name-filter cat -- --branches --tags
脚本1为将某一邮箱改成目标邮箱 张三@qq.com改成 张三@niuxcompany.com
#!/bin/sh
git filter-branch --env-filter '
OLD_EMAIL="旧邮箱"
CORRECT_NAME="提交者名字"
CORRECT_EMAIL="新邮箱"
if [ "$GIT_COMMITTER_EMAIL" = "$OLD_EMAIL" ]
then
export GIT_COMMITTER_NAME="$CORRECT_NAME"
export GIT_COMMITTER_EMAIL="$CORRECT_EMAIL"
fi
if [ "$GIT_AUTHOR_EMAIL" = "$OLD_EMAIL" ]
then
export GIT_AUTHOR_NAME="$CORRECT_NAME"
export GIT_AUTHOR_EMAIL="$CORRECT_EMAIL"
fi
' --tag-name-filter cat -- --branches --tags
4.强推git push --force --tags origin 'refs/heads/*'