go-git:如何在远程服务器上进行身份验证?

go-git:如何在远程服务器上进行身份验证?

问题描述:

我使用go项目go-git作为git-client,并想从通过gitea托管的私有git存储库中获取。go-git:如何在远程服务器上进行身份验证?

执行此操作的相应功能是func (r *Remote) Fetch(o *FetchOptions) error,它需要transport.AuthMethod对象进行身份验证。

我试过如下:

repo, _ := git.PlainOpen("/path/to/project/folder") 
err := repo.Fetch(&git.FetchOptions{ 
    Auth: http.NewBasicAuth("someUser", "andThePassword"), 
}) 

...这只是返回:

无效的授权方法

如果我使用

authenticator, _ := ssh.NewSSHAgentAuth("git") 
同样的情况,

从包"gopkg.in/src-d/go-git.v4/plumbing/transport/ssh"

并且如果我使用证书:

authenticator, _:= ssh.NewPublicKeysFromFile("gitea name", "/home/name/.ssh/id_rsa", "passphrase") 

如何找出哪个身份验证方法的支持,并在那里的transport.AuthMethod,我可以用现有的实现?

+0

您的使用看起来正确的我,也许有一个bug?该项目最近有一个问题[#618](https://github.com/src-d/go-git/issues/618),可能表明有用的解决方法:'&git.CloneOptions {URL:“https: //user:[email protected]/repo.git“}' – orirawlings

+0

@orirawlings这样的url只能在克隆新存储库时应用。当我已经拥有本地版本库时,我用'PlainOpen'打开它,然后使用'Fetch',为此我无法再指定URL。 (URL是从'.git/config'文件中获得的,即使我在那里修改了url,它也会返回“invalid auth method” – maja

+0

你使用哪种协议?HTTP或者SSH?或者git? – mcuadros

这里的问题是,我使用了错误的http-package来获取authenticator。

我使用了包net/http中的BasicAuth() - 但是,要使用的正确http包是gopkg.in/src-d/go-git.v4/plumbing/transport/http

更改导入并从那里使用(兼容)BasicAuth-authenticator时,它可以完美地工作。

这个工作对我gopkg.in/src-d/go-git.v4

func cloneGit() (err error) { 
    username := "dude" 
    password := "super-secret-Personal-access-token" 
    repo := "github.build.company.com/org/repo-name.git" 
    url := fmt.Sprintf("https://%s:%[email protected]%s", username, password, repo) 
    options := git.CloneOptions{ 
     URL:  url, 
     Progress: os.Stdout, 
    } 
    r, err := git.PlainClone("./src", false, &options) 

    if err != nil { 
     return err 
    } 
    fmt.Println(r.Log) 
    return err 
}