diff options
author | Ash McKenzie <amckenzie@gitlab.com> | 2023-03-06 07:23:33 +0000 |
---|---|---|
committer | Ash McKenzie <amckenzie@gitlab.com> | 2023-03-06 07:23:33 +0000 |
commit | 23409f0eb98b0e8d3b0fcb57a31d75ddd6dc8262 (patch) | |
tree | 2f138cd934517f0280f0da148ede78720d9ab765 /internal/gitlabnet/git/client.go | |
parent | d893886d53c3038af84414589459d273609b2243 (diff) | |
parent | 83a4e8e542e9f929e1c22b235b883ee67187c4c6 (diff) | |
download | gitlab-shell-23409f0eb98b0e8d3b0fcb57a31d75ddd6dc8262.tar.gz |
Merge branch 'id-geo-http-push' into 'main'
Perform Git over HTTP request to primary repo
See merge request https://gitlab.com/gitlab-org/gitlab-shell/-/merge_requests/716
Merged-by: Ash McKenzie <amckenzie@gitlab.com>
Approved-by: Alejandro RodrÃguez <alejandro@gitlab.com>
Approved-by: Ash McKenzie <amckenzie@gitlab.com>
Reviewed-by: Valery Sizov <valery@gitlab.com>
Reviewed-by: Alejandro RodrÃguez <alejandro@gitlab.com>
Reviewed-by: Igor Drozdov <idrozdov@gitlab.com>
Reviewed-by: Ash McKenzie <amckenzie@gitlab.com>
Co-authored-by: Igor Drozdov <idrozdov@gitlab.com>
Diffstat (limited to 'internal/gitlabnet/git/client.go')
-rw-r--r-- | internal/gitlabnet/git/client.go | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/internal/gitlabnet/git/client.go b/internal/gitlabnet/git/client.go new file mode 100644 index 0000000..db71e3f --- /dev/null +++ b/internal/gitlabnet/git/client.go @@ -0,0 +1,56 @@ +package git + +import ( + "context" + "fmt" + "io" + "net/http" + + "gitlab.com/gitlab-org/gitlab-shell/v14/client" + "gitlab.com/gitlab-org/gitlab-shell/v14/internal/config" + "gitlab.com/gitlab-org/gitlab-shell/v14/internal/gitlabnet" +) + +type Client struct { + url string + headers map[string]string + client *client.GitlabNetClient +} + +func NewClient(cfg *config.Config, url string, headers map[string]string) (*Client, error) { + client, err := gitlabnet.GetClient(cfg) + if err != nil { + return nil, fmt.Errorf("Error creating http client: %v", err) + } + + return &Client{client: client, headers: headers, url: url}, nil +} + +func (c *Client) InfoRefs(ctx context.Context, service string) (*http.Response, error) { + request, err := http.NewRequestWithContext(ctx, http.MethodGet, c.url+"/info/refs?service="+service, nil) + if err != nil { + return nil, err + } + + return c.do(request) +} + +func (c *Client) ReceivePack(ctx context.Context, body io.Reader) (*http.Response, error) { + request, err := http.NewRequestWithContext(ctx, http.MethodPost, c.url+"/git-receive-pack", body) + if err != nil { + return nil, err + } + request.Header.Add("Content-Type", "application/x-git-receive-pack-request") + request.Header.Add("Accept", "application/x-git-receive-pack-result") + + return c.do(request) +} + +func (c *Client) do(request *http.Request) (*http.Response, error) { + + for k, v := range c.headers { + request.Header.Add(k, v) + } + + return c.client.Do(request) +} |