* update github.com/blevesearch/bleve v2.0.2 -> v2.0.3 * github.com/denisenkom/go-mssqldb v0.9.0 -> v0.10.0 * github.com/editorconfig/editorconfig-core-go v2.4.1 -> v2.4.2 * github.com/go-chi/cors v1.1.1 -> v1.2.0 * github.com/go-git/go-billy v5.0.0 -> v5.1.0 * github.com/go-git/go-git v5.2.0 -> v5.3.0 * github.com/go-ldap/ldap v3.2.4 -> v3.3.0 * github.com/go-redis/redis v8.6.0 -> v8.8.2 * github.com/go-sql-driver/mysql v1.5.0 -> v1.6.0 * github.com/go-swagger/go-swagger v0.26.1 -> v0.27.0 * github.com/lib/pq v1.9.0 -> v1.10.1 * github.com/mattn/go-sqlite3 v1.14.6 -> v1.14.7 * github.com/go-testfixtures/testfixtures v3.5.0 -> v3.6.0 * github.com/issue9/identicon v1.0.1 -> v1.2.0 * github.com/klauspost/compress v1.11.8 -> v1.12.1 * github.com/mgechev/revive v1.0.3 -> v1.0.6 * github.com/microcosm-cc/bluemonday v1.0.7 -> v1.0.8 * github.com/niklasfasching/go-org v1.4.0 -> v1.5.0 * github.com/olivere/elastic v7.0.22 -> v7.0.24 * github.com/pelletier/go-toml v1.8.1 -> v1.9.0 * github.com/prometheus/client_golang v1.9.0 -> v1.10.0 * github.com/xanzy/go-gitlab v0.44.0 -> v0.48.0 * github.com/yuin/goldmark v1.3.3 -> v1.3.5 * github.com/6543/go-version v1.2.4 -> v1.3.1 * do github.com/lib/pq v1.10.0 -> v1.10.1 again ...
		
			
				
	
	
		
			379 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
			
		
		
	
	
			379 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
| //
 | |
| // Copyright 2021, Sander van Harmelen
 | |
| //
 | |
| // Licensed under the Apache License, Version 2.0 (the "License");
 | |
| // you may not use this file except in compliance with the License.
 | |
| // You may obtain a copy of the License at
 | |
| //
 | |
| //     http://www.apache.org/licenses/LICENSE-2.0
 | |
| //
 | |
| // Unless required by applicable law or agreed to in writing, software
 | |
| // distributed under the License is distributed on an "AS IS" BASIS,
 | |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| // See the License for the specific language governing permissions and
 | |
| // limitations under the License.
 | |
| //
 | |
| 
 | |
| package gitlab
 | |
| 
 | |
| import (
 | |
| 	"bytes"
 | |
| 	"fmt"
 | |
| 	"net/http"
 | |
| 	"strconv"
 | |
| 	"time"
 | |
| )
 | |
| 
 | |
| // RepositoryFilesService handles communication with the repository files
 | |
| // related methods of the GitLab API.
 | |
| //
 | |
| // GitLab API docs: https://docs.gitlab.com/ce/api/repository_files.html
 | |
| type RepositoryFilesService struct {
 | |
| 	client *Client
 | |
| }
 | |
| 
 | |
| // File represents a GitLab repository file.
 | |
| //
 | |
| // GitLab API docs: https://docs.gitlab.com/ce/api/repository_files.html
 | |
| type File struct {
 | |
| 	FileName     string `json:"file_name"`
 | |
| 	FilePath     string `json:"file_path"`
 | |
| 	Size         int    `json:"size"`
 | |
| 	Encoding     string `json:"encoding"`
 | |
| 	Content      string `json:"content"`
 | |
| 	Ref          string `json:"ref"`
 | |
| 	BlobID       string `json:"blob_id"`
 | |
| 	CommitID     string `json:"commit_id"`
 | |
| 	SHA256       string `json:"content_sha256"`
 | |
| 	LastCommitID string `json:"last_commit_id"`
 | |
| }
 | |
| 
 | |
| func (r File) String() string {
 | |
| 	return Stringify(r)
 | |
| }
 | |
| 
 | |
| // GetFileOptions represents the available GetFile() options.
 | |
| //
 | |
| // GitLab API docs:
 | |
| // https://docs.gitlab.com/ce/api/repository_files.html#get-file-from-repository
 | |
| type GetFileOptions struct {
 | |
| 	Ref *string `url:"ref,omitempty" json:"ref,omitempty"`
 | |
| }
 | |
| 
 | |
| // GetFile allows you to receive information about a file in repository like
 | |
| // name, size, content. Note that file content is Base64 encoded.
 | |
| //
 | |
| // GitLab API docs:
 | |
| // https://docs.gitlab.com/ce/api/repository_files.html#get-file-from-repository
 | |
| func (s *RepositoryFilesService) GetFile(pid interface{}, fileName string, opt *GetFileOptions, options ...RequestOptionFunc) (*File, *Response, error) {
 | |
| 	project, err := parseID(pid)
 | |
| 	if err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 	u := fmt.Sprintf(
 | |
| 		"projects/%s/repository/files/%s",
 | |
| 		pathEscape(project),
 | |
| 		pathEscape(fileName),
 | |
| 	)
 | |
| 
 | |
| 	req, err := s.client.NewRequest(http.MethodGet, u, opt, options)
 | |
| 	if err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 
 | |
| 	f := new(File)
 | |
| 	resp, err := s.client.Do(req, f)
 | |
| 	if err != nil {
 | |
| 		return nil, resp, err
 | |
| 	}
 | |
| 
 | |
| 	return f, resp, err
 | |
| }
 | |
| 
 | |
| // GetFileMetaDataOptions represents the available GetFileMetaData() options.
 | |
| //
 | |
| // GitLab API docs:
 | |
| // https://docs.gitlab.com/ce/api/repository_files.html#get-file-from-repository
 | |
| type GetFileMetaDataOptions struct {
 | |
| 	Ref *string `url:"ref,omitempty" json:"ref,omitempty"`
 | |
| }
 | |
| 
 | |
| // GetFileMetaData allows you to receive meta information about a file in
 | |
| // repository like name, size.
 | |
| //
 | |
| // GitLab API docs:
 | |
| // https://docs.gitlab.com/ce/api/repository_files.html#get-file-from-repository
 | |
| func (s *RepositoryFilesService) GetFileMetaData(pid interface{}, fileName string, opt *GetFileMetaDataOptions, options ...RequestOptionFunc) (*File, *Response, error) {
 | |
| 	project, err := parseID(pid)
 | |
| 	if err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 	u := fmt.Sprintf(
 | |
| 		"projects/%s/repository/files/%s",
 | |
| 		pathEscape(project),
 | |
| 		pathEscape(fileName),
 | |
| 	)
 | |
| 
 | |
| 	req, err := s.client.NewRequest(http.MethodHead, u, opt, options)
 | |
| 	if err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 
 | |
| 	resp, err := s.client.Do(req, nil)
 | |
| 	if err != nil {
 | |
| 		return nil, resp, err
 | |
| 	}
 | |
| 
 | |
| 	f := &File{
 | |
| 		BlobID:       resp.Header.Get("X-Gitlab-Blob-Id"),
 | |
| 		CommitID:     resp.Header.Get("X-Gitlab-Last-Commit-Id"),
 | |
| 		Encoding:     resp.Header.Get("X-Gitlab-Encoding"),
 | |
| 		FileName:     resp.Header.Get("X-Gitlab-File-Name"),
 | |
| 		FilePath:     resp.Header.Get("X-Gitlab-File-Path"),
 | |
| 		Ref:          resp.Header.Get("X-Gitlab-Ref"),
 | |
| 		SHA256:       resp.Header.Get("X-Gitlab-Content-Sha256"),
 | |
| 		LastCommitID: resp.Header.Get("X-Gitlab-Last-Commit-Id"),
 | |
| 	}
 | |
| 
 | |
| 	if sizeString := resp.Header.Get("X-Gitlab-Size"); sizeString != "" {
 | |
| 		f.Size, err = strconv.Atoi(sizeString)
 | |
| 		if err != nil {
 | |
| 			return nil, resp, err
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	return f, resp, err
 | |
| }
 | |
| 
 | |
| // FileBlameRange represents one item of blame information.
 | |
| //
 | |
| // GitLab API docs: https://docs.gitlab.com/ce/api/repository_files.html
 | |
| type FileBlameRange struct {
 | |
| 	Commit struct {
 | |
| 		ID             string     `json:"id"`
 | |
| 		ParentIDs      []string   `json:"parent_ids"`
 | |
| 		Message        string     `json:"message"`
 | |
| 		AuthoredDate   *time.Time `json:"authored_date"`
 | |
| 		AuthorName     string     `json:"author_name"`
 | |
| 		AuthorEmail    string     `json:"author_email"`
 | |
| 		CommittedDate  *time.Time `json:"committed_date"`
 | |
| 		CommitterName  string     `json:"committer_name"`
 | |
| 		CommitterEmail string     `json:"committer_email"`
 | |
| 	} `json:"commit"`
 | |
| 	Lines []string `json:"lines"`
 | |
| }
 | |
| 
 | |
| func (b FileBlameRange) String() string {
 | |
| 	return Stringify(b)
 | |
| }
 | |
| 
 | |
| // GetFileBlameOptions represents the available GetFileBlame() options.
 | |
| //
 | |
| // GitLab API docs:
 | |
| // https://docs.gitlab.com/ce/api/repository_files.html#get-file-blame-from-repository
 | |
| type GetFileBlameOptions struct {
 | |
| 	Ref *string `url:"ref,omitempty" json:"ref,omitempty"`
 | |
| }
 | |
| 
 | |
| // GetFileBlame allows you to receive blame information. Each blame range
 | |
| // contains lines and corresponding commit info.
 | |
| //
 | |
| // GitLab API docs:
 | |
| // https://docs.gitlab.com/ce/api/repository_files.html#get-file-blame-from-repository
 | |
| func (s *RepositoryFilesService) GetFileBlame(pid interface{}, file string, opt *GetFileBlameOptions, options ...RequestOptionFunc) ([]*FileBlameRange, *Response, error) {
 | |
| 	project, err := parseID(pid)
 | |
| 	if err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 	u := fmt.Sprintf(
 | |
| 		"projects/%s/repository/files/%s/blame",
 | |
| 		pathEscape(project),
 | |
| 		pathEscape(file),
 | |
| 	)
 | |
| 
 | |
| 	req, err := s.client.NewRequest(http.MethodGet, u, opt, options)
 | |
| 	if err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 
 | |
| 	var br []*FileBlameRange
 | |
| 	resp, err := s.client.Do(req, &br)
 | |
| 	if err != nil {
 | |
| 		return nil, resp, err
 | |
| 	}
 | |
| 
 | |
| 	return br, resp, err
 | |
| }
 | |
| 
 | |
| // GetRawFileOptions represents the available GetRawFile() options.
 | |
| //
 | |
| // GitLab API docs:
 | |
| // https://docs.gitlab.com/ce/api/repository_files.html#get-raw-file-from-repository
 | |
| type GetRawFileOptions struct {
 | |
| 	Ref *string `url:"ref,omitempty" json:"ref,omitempty"`
 | |
| }
 | |
| 
 | |
| // GetRawFile allows you to receive the raw file in repository.
 | |
| //
 | |
| // GitLab API docs:
 | |
| // https://docs.gitlab.com/ce/api/repository_files.html#get-raw-file-from-repository
 | |
| func (s *RepositoryFilesService) GetRawFile(pid interface{}, fileName string, opt *GetRawFileOptions, options ...RequestOptionFunc) ([]byte, *Response, error) {
 | |
| 	project, err := parseID(pid)
 | |
| 	if err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 	u := fmt.Sprintf(
 | |
| 		"projects/%s/repository/files/%s/raw",
 | |
| 		pathEscape(project),
 | |
| 		pathEscape(fileName),
 | |
| 	)
 | |
| 
 | |
| 	req, err := s.client.NewRequest(http.MethodGet, u, opt, options)
 | |
| 	if err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 
 | |
| 	var f bytes.Buffer
 | |
| 	resp, err := s.client.Do(req, &f)
 | |
| 	if err != nil {
 | |
| 		return nil, resp, err
 | |
| 	}
 | |
| 
 | |
| 	return f.Bytes(), resp, err
 | |
| }
 | |
| 
 | |
| // FileInfo represents file details of a GitLab repository file.
 | |
| //
 | |
| // GitLab API docs: https://docs.gitlab.com/ce/api/repository_files.html
 | |
| type FileInfo struct {
 | |
| 	FilePath string `json:"file_path"`
 | |
| 	Branch   string `json:"branch"`
 | |
| }
 | |
| 
 | |
| func (r FileInfo) String() string {
 | |
| 	return Stringify(r)
 | |
| }
 | |
| 
 | |
| // CreateFileOptions represents the available CreateFile() options.
 | |
| //
 | |
| // GitLab API docs:
 | |
| // https://docs.gitlab.com/ce/api/repository_files.html#create-new-file-in-repository
 | |
| type CreateFileOptions struct {
 | |
| 	Branch        *string `url:"branch,omitempty" json:"branch,omitempty"`
 | |
| 	StartBranch   *string `url:"start_branch,omitempty" json:"start_branch,omitempty"`
 | |
| 	Encoding      *string `url:"encoding,omitempty" json:"encoding,omitempty"`
 | |
| 	AuthorEmail   *string `url:"author_email,omitempty" json:"author_email,omitempty"`
 | |
| 	AuthorName    *string `url:"author_name,omitempty" json:"author_name,omitempty"`
 | |
| 	Content       *string `url:"content,omitempty" json:"content,omitempty"`
 | |
| 	CommitMessage *string `url:"commit_message,omitempty" json:"commit_message,omitempty"`
 | |
| }
 | |
| 
 | |
| // CreateFile creates a new file in a repository.
 | |
| //
 | |
| // GitLab API docs:
 | |
| // https://docs.gitlab.com/ce/api/repository_files.html#create-new-file-in-repository
 | |
| func (s *RepositoryFilesService) CreateFile(pid interface{}, fileName string, opt *CreateFileOptions, options ...RequestOptionFunc) (*FileInfo, *Response, error) {
 | |
| 	project, err := parseID(pid)
 | |
| 	if err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 	u := fmt.Sprintf(
 | |
| 		"projects/%s/repository/files/%s",
 | |
| 		pathEscape(project),
 | |
| 		pathEscape(fileName),
 | |
| 	)
 | |
| 
 | |
| 	req, err := s.client.NewRequest(http.MethodPost, u, opt, options)
 | |
| 	if err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 
 | |
| 	f := new(FileInfo)
 | |
| 	resp, err := s.client.Do(req, f)
 | |
| 	if err != nil {
 | |
| 		return nil, resp, err
 | |
| 	}
 | |
| 
 | |
| 	return f, resp, err
 | |
| }
 | |
| 
 | |
| // UpdateFileOptions represents the available UpdateFile() options.
 | |
| //
 | |
| // GitLab API docs:
 | |
| // https://docs.gitlab.com/ce/api/repository_files.html#update-existing-file-in-repository
 | |
| type UpdateFileOptions struct {
 | |
| 	Branch        *string `url:"branch,omitempty" json:"branch,omitempty"`
 | |
| 	StartBranch   *string `url:"start_branch,omitempty" json:"start_branch,omitempty"`
 | |
| 	Encoding      *string `url:"encoding,omitempty" json:"encoding,omitempty"`
 | |
| 	AuthorEmail   *string `url:"author_email,omitempty" json:"author_email,omitempty"`
 | |
| 	AuthorName    *string `url:"author_name,omitempty" json:"author_name,omitempty"`
 | |
| 	Content       *string `url:"content,omitempty" json:"content,omitempty"`
 | |
| 	CommitMessage *string `url:"commit_message,omitempty" json:"commit_message,omitempty"`
 | |
| 	LastCommitID  *string `url:"last_commit_id,omitempty" json:"last_commit_id,omitempty"`
 | |
| }
 | |
| 
 | |
| // UpdateFile updates an existing file in a repository
 | |
| //
 | |
| // GitLab API docs:
 | |
| // https://docs.gitlab.com/ce/api/repository_files.html#update-existing-file-in-repository
 | |
| func (s *RepositoryFilesService) UpdateFile(pid interface{}, fileName string, opt *UpdateFileOptions, options ...RequestOptionFunc) (*FileInfo, *Response, error) {
 | |
| 	project, err := parseID(pid)
 | |
| 	if err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 	u := fmt.Sprintf(
 | |
| 		"projects/%s/repository/files/%s",
 | |
| 		pathEscape(project),
 | |
| 		pathEscape(fileName),
 | |
| 	)
 | |
| 
 | |
| 	req, err := s.client.NewRequest(http.MethodPut, u, opt, options)
 | |
| 	if err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 
 | |
| 	f := new(FileInfo)
 | |
| 	resp, err := s.client.Do(req, f)
 | |
| 	if err != nil {
 | |
| 		return nil, resp, err
 | |
| 	}
 | |
| 
 | |
| 	return f, resp, err
 | |
| }
 | |
| 
 | |
| // DeleteFileOptions represents the available DeleteFile() options.
 | |
| //
 | |
| // GitLab API docs:
 | |
| // https://docs.gitlab.com/ce/api/repository_files.html#delete-existing-file-in-repository
 | |
| type DeleteFileOptions struct {
 | |
| 	Branch        *string `url:"branch,omitempty" json:"branch,omitempty"`
 | |
| 	StartBranch   *string `url:"start_branch,omitempty" json:"start_branch,omitempty"`
 | |
| 	AuthorEmail   *string `url:"author_email,omitempty" json:"author_email,omitempty"`
 | |
| 	AuthorName    *string `url:"author_name,omitempty" json:"author_name,omitempty"`
 | |
| 	CommitMessage *string `url:"commit_message,omitempty" json:"commit_message,omitempty"`
 | |
| 	LastCommitID  *string `url:"last_commit_id,omitempty" json:"last_commit_id,omitempty"`
 | |
| }
 | |
| 
 | |
| // DeleteFile deletes an existing file in a repository
 | |
| //
 | |
| // GitLab API docs:
 | |
| // https://docs.gitlab.com/ce/api/repository_files.html#delete-existing-file-in-repository
 | |
| func (s *RepositoryFilesService) DeleteFile(pid interface{}, fileName string, opt *DeleteFileOptions, options ...RequestOptionFunc) (*Response, error) {
 | |
| 	project, err := parseID(pid)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	u := fmt.Sprintf(
 | |
| 		"projects/%s/repository/files/%s",
 | |
| 		pathEscape(project),
 | |
| 		pathEscape(fileName),
 | |
| 	)
 | |
| 
 | |
| 	req, err := s.client.NewRequest(http.MethodDelete, u, opt, options)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 
 | |
| 	return s.client.Do(req, nil)
 | |
| }
 |