mirror of
				https://github.com/go-gitea/gitea
				synced 2025-09-28 03:28:13 +00:00 
			
		
		
		
	* update github.com/alecthomas/chroma v0.8.0 -> v0.8.1 * github.com/blevesearch/bleve v1.0.10 -> v1.0.12 * editorconfig-core-go v2.1.1 -> v2.3.7 * github.com/gliderlabs/ssh v0.2.2 -> v0.3.1 * migrate editorconfig.ParseBytes to Parse * github.com/shurcooL/vfsgen to 0d455de96546 * github.com/go-git/go-git/v5 v5.1.0 -> v5.2.0 * github.com/google/uuid v1.1.1 -> v1.1.2 * github.com/huandu/xstrings v1.3.0 -> v1.3.2 * github.com/klauspost/compress v1.10.11 -> v1.11.1 * github.com/markbates/goth v1.61.2 -> v1.65.0 * github.com/mattn/go-sqlite3 v1.14.0 -> v1.14.4 * github.com/mholt/archiver v3.3.0 -> v3.3.2 * github.com/microcosm-cc/bluemonday 4f7140c49acb -> v1.0.4 * github.com/minio/minio-go v7.0.4 -> v7.0.5 * github.com/olivere/elastic v7.0.9 -> v7.0.20 * github.com/urfave/cli v1.20.0 -> v1.22.4 * github.com/prometheus/client_golang v1.1.0 -> v1.8.0 * github.com/xanzy/go-gitlab v0.37.0 -> v0.38.1 * mvdan.cc/xurls v2.1.0 -> v2.2.0 Co-authored-by: Lauris BH <lauris@nix.lv>
		
			
				
	
	
		
			224 lines
		
	
	
		
			6.8 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
			
		
		
	
	
			224 lines
		
	
	
		
			6.8 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
| package gitlab
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"time"
 | |
| )
 | |
| 
 | |
| // ContainerRegistryService handles communication with the container registry
 | |
| // related methods of the GitLab API.
 | |
| //
 | |
| // GitLab API docs: https://docs.gitlab.com/ee/api/container_registry.html
 | |
| type ContainerRegistryService struct {
 | |
| 	client *Client
 | |
| }
 | |
| 
 | |
| // RegistryRepository represents a GitLab content registry repository.
 | |
| //
 | |
| // GitLab API docs: https://docs.gitlab.com/ee/api/container_registry.html
 | |
| type RegistryRepository struct {
 | |
| 	ID        int        `json:"id"`
 | |
| 	Name      string     `json:"name"`
 | |
| 	Path      string     `json:"path"`
 | |
| 	Location  string     `json:"location"`
 | |
| 	CreatedAt *time.Time `json:"created_at"`
 | |
| }
 | |
| 
 | |
| func (s RegistryRepository) String() string {
 | |
| 	return Stringify(s)
 | |
| }
 | |
| 
 | |
| // RegistryRepositoryTag represents a GitLab registry image tag.
 | |
| //
 | |
| // GitLab API docs: https://docs.gitlab.com/ee/api/container_registry.html
 | |
| type RegistryRepositoryTag struct {
 | |
| 	Name          string     `json:"name"`
 | |
| 	Path          string     `json:"path"`
 | |
| 	Location      string     `json:"location"`
 | |
| 	Revision      string     `json:"revision"`
 | |
| 	ShortRevision string     `json:"short_revision"`
 | |
| 	Digest        string     `json:"digest"`
 | |
| 	CreatedAt     *time.Time `json:"created_at"`
 | |
| 	TotalSize     int        `json:"total_size"`
 | |
| }
 | |
| 
 | |
| func (s RegistryRepositoryTag) String() string {
 | |
| 	return Stringify(s)
 | |
| }
 | |
| 
 | |
| // ListRegistryRepositoriesOptions represents the available
 | |
| // ListRegistryRepositories() options.
 | |
| //
 | |
| // GitLab API docs:
 | |
| // https://docs.gitlab.com/ee/api/container_registry.html#list-registry-repositories
 | |
| type ListRegistryRepositoriesOptions ListOptions
 | |
| 
 | |
| // ListRegistryRepositories gets a list of registry repositories in a project.
 | |
| //
 | |
| // GitLab API docs:
 | |
| // https://docs.gitlab.com/ee/api/container_registry.html#list-registry-repositories
 | |
| func (s *ContainerRegistryService) ListRegistryRepositories(pid interface{}, opt *ListRegistryRepositoriesOptions, options ...RequestOptionFunc) ([]*RegistryRepository, *Response, error) {
 | |
| 	project, err := parseID(pid)
 | |
| 	if err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 	u := fmt.Sprintf("projects/%s/registry/repositories", pathEscape(project))
 | |
| 
 | |
| 	req, err := s.client.NewRequest("GET", u, opt, options)
 | |
| 	if err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 
 | |
| 	var repos []*RegistryRepository
 | |
| 	resp, err := s.client.Do(req, &repos)
 | |
| 	if err != nil {
 | |
| 		return nil, resp, err
 | |
| 	}
 | |
| 
 | |
| 	return repos, resp, err
 | |
| }
 | |
| 
 | |
| // DeleteRegistryRepository deletes a repository in a registry.
 | |
| //
 | |
| // GitLab API docs:
 | |
| // https://docs.gitlab.com/ee/api/container_registry.html#delete-registry-repository
 | |
| func (s *ContainerRegistryService) DeleteRegistryRepository(pid interface{}, repository int, options ...RequestOptionFunc) (*Response, error) {
 | |
| 	project, err := parseID(pid)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	u := fmt.Sprintf("projects/%s/registry/repositories/%d", pathEscape(project), repository)
 | |
| 
 | |
| 	req, err := s.client.NewRequest("DELETE", u, nil, options)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 
 | |
| 	return s.client.Do(req, nil)
 | |
| }
 | |
| 
 | |
| // ListRegistryRepositoryTagsOptions represents the available
 | |
| // ListRegistryRepositoryTags() options.
 | |
| //
 | |
| // GitLab API docs:
 | |
| // https://docs.gitlab.com/ee/api/container_registry.html#list-repository-tags
 | |
| type ListRegistryRepositoryTagsOptions ListOptions
 | |
| 
 | |
| // ListRegistryRepositoryTags gets a list of tags for given registry repository.
 | |
| //
 | |
| // GitLab API docs:
 | |
| // https://docs.gitlab.com/ee/api/container_registry.html#list-repository-tags
 | |
| func (s *ContainerRegistryService) ListRegistryRepositoryTags(pid interface{}, repository int, opt *ListRegistryRepositoryTagsOptions, options ...RequestOptionFunc) ([]*RegistryRepositoryTag, *Response, error) {
 | |
| 	project, err := parseID(pid)
 | |
| 	if err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 	u := fmt.Sprintf("projects/%s/registry/repositories/%d/tags",
 | |
| 		pathEscape(project),
 | |
| 		repository,
 | |
| 	)
 | |
| 
 | |
| 	req, err := s.client.NewRequest("GET", u, opt, options)
 | |
| 	if err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 
 | |
| 	var tags []*RegistryRepositoryTag
 | |
| 	resp, err := s.client.Do(req, &tags)
 | |
| 	if err != nil {
 | |
| 		return nil, resp, err
 | |
| 	}
 | |
| 
 | |
| 	return tags, resp, err
 | |
| }
 | |
| 
 | |
| // GetRegistryRepositoryTagDetail get details of a registry repository tag
 | |
| //
 | |
| // GitLab API docs:
 | |
| // https://docs.gitlab.com/ee/api/container_registry.html#get-details-of-a-repository-tag
 | |
| func (s *ContainerRegistryService) GetRegistryRepositoryTagDetail(pid interface{}, repository int, tagName string, options ...RequestOptionFunc) (*RegistryRepositoryTag, *Response, error) {
 | |
| 	project, err := parseID(pid)
 | |
| 	if err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 	u := fmt.Sprintf("projects/%s/registry/repositories/%d/tags/%s",
 | |
| 		pathEscape(project),
 | |
| 		repository,
 | |
| 		tagName,
 | |
| 	)
 | |
| 
 | |
| 	req, err := s.client.NewRequest("GET", u, nil, options)
 | |
| 	if err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 
 | |
| 	tag := new(RegistryRepositoryTag)
 | |
| 	resp, err := s.client.Do(req, &tag)
 | |
| 	if err != nil {
 | |
| 		return nil, resp, err
 | |
| 	}
 | |
| 
 | |
| 	return tag, resp, err
 | |
| }
 | |
| 
 | |
| // DeleteRegistryRepositoryTag deletes a registry repository tag.
 | |
| //
 | |
| // GitLab API docs:
 | |
| // https://docs.gitlab.com/ee/api/container_registry.html#delete-a-repository-tag
 | |
| func (s *ContainerRegistryService) DeleteRegistryRepositoryTag(pid interface{}, repository int, tagName string, options ...RequestOptionFunc) (*Response, error) {
 | |
| 	project, err := parseID(pid)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	u := fmt.Sprintf("projects/%s/registry/repositories/%d/tags/%s",
 | |
| 		pathEscape(project),
 | |
| 		repository,
 | |
| 		tagName,
 | |
| 	)
 | |
| 
 | |
| 	req, err := s.client.NewRequest("DELETE", u, nil, options)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 
 | |
| 	return s.client.Do(req, nil)
 | |
| }
 | |
| 
 | |
| // DeleteRegistryRepositoryTagsOptions represents the available
 | |
| // DeleteRegistryRepositoryTags() options.
 | |
| //
 | |
| // GitLab API docs:
 | |
| // https://docs.gitlab.com/ee/api/container_registry.html#delete-repository-tags-in-bulk
 | |
| type DeleteRegistryRepositoryTagsOptions struct {
 | |
| 	NameRegexpDelete *string `url:"name_regex_delete,omitempty" json:"name_regex_delete,omitempty"`
 | |
| 	NameRegexpKeep   *string `url:"name_regex_keep,omitempty" json:"name_regex_keep,omitempty"`
 | |
| 	KeepN            *int    `url:"keep_n,omitempty" json:"keep_n,omitempty"`
 | |
| 	OlderThan        *string `url:"older_than,omitempty" json:"older_than,omitempty"`
 | |
| 
 | |
| 	// Deprecated members
 | |
| 	NameRegexp *string `url:"name_regex,omitempty" json:"name_regex,omitempty"`
 | |
| }
 | |
| 
 | |
| // DeleteRegistryRepositoryTags deletes repository tags in bulk based on
 | |
| // given criteria.
 | |
| //
 | |
| // GitLab API docs:
 | |
| // https://docs.gitlab.com/ee/api/container_registry.html#delete-repository-tags-in-bulk
 | |
| func (s *ContainerRegistryService) DeleteRegistryRepositoryTags(pid interface{}, repository int, opt *DeleteRegistryRepositoryTagsOptions, options ...RequestOptionFunc) (*Response, error) {
 | |
| 	project, err := parseID(pid)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	u := fmt.Sprintf("projects/%s/registry/repositories/%d/tags",
 | |
| 		pathEscape(project),
 | |
| 		repository,
 | |
| 	)
 | |
| 
 | |
| 	req, err := s.client.NewRequest("DELETE", u, opt, options)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 
 | |
| 	return s.client.Do(req, nil)
 | |
| }
 |