mirror of
				https://github.com/go-gitea/gitea
				synced 2025-11-04 05:18:25 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			220 lines
		
	
	
		
			6.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			220 lines
		
	
	
		
			6.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
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 {
 | 
						|
	NameRegexp *string `url:"name_regex,omitempty" json:"name_regex,omitempty"`
 | 
						|
	KeepN      *int    `url:"keep_n,omitempty" json:"keep_n,omitempty"`
 | 
						|
	OlderThan  *string `url:"older_than,omitempty" json:"older_than,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)
 | 
						|
}
 |