Skip to content
Snippets Groups Projects
Select Git revision
  • 022ff1229c9804650d323d72d9edef240ade1367
  • master default protected
  • 1.31
  • 4.38.7
  • 4.38.6
  • 4.38.5
  • 4.38.4
  • 4.38.3
  • 4.38.2
  • 4.38.1
  • 4.38.0
  • 4.37.2
  • 4.37.1
  • 4.37.0
  • 4.36.0
  • 4.35.0
  • 4.34.1
  • 4.34.0
  • 4.33.1
  • 4.33.0
  • 4.32.2
  • 4.32.1
  • 4.32.0
23 results

change-button.pcss

Blame
  • releases.go 8.99 KiB
    //
    // 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 (
    	"fmt"
    	"net/http"
    	"time"
    )
    
    // ReleasesService handles communication with the releases methods
    // of the GitLab API.
    //
    // GitLab API docs: https://docs.gitlab.com/ee/api/releases/index.html
    type ReleasesService struct {
    	client *Client
    }
    
    // Release represents a project release.
    //
    // GitLab API docs:
    // https://docs.gitlab.com/ee/api/releases/index.html#list-releases
    type Release struct {
    	TagName         string     `json:"tag_name"`
    	Name            string     `json:"name"`
    	Description     string     `json:"description"`
    	DescriptionHTML string     `json:"description_html"`
    	CreatedAt       *time.Time `json:"created_at"`
    	ReleasedAt      *time.Time `json:"released_at"`
    	Author          struct {
    		ID        int    `json:"id"`
    		Name      string `json:"name"`
    		Username  string `json:"username"`
    		State     string `json:"state"`
    		AvatarURL string `json:"avatar_url"`
    		WebURL    string `json:"web_url"`
    	} `json:"author"`
    	Commit          Commit `json:"commit"`
    	UpcomingRelease bool   `json:"upcoming_release"`
    	CommitPath      string `json:"commit_path"`
    	TagPath         string `json:"tag_path"`
    	Assets          struct {
    		Count   int `json:"count"`
    		Sources []struct {
    			Format string `json:"format"`
    			URL    string `json:"url"`
    		} `json:"sources"`
    		Links []*ReleaseLink `json:"links"`
    	} `json:"assets"`
    	Links struct {
    		ClosedIssueURL     string `json:"closed_issues_url"`
    		ClosedMergeRequest string `json:"closed_merge_requests_url"`
    		EditURL            string `json:"edit_url"`
    		MergedMergeRequest string `json:"merged_merge_requests_url"`
    		OpenedIssues       string `json:"opened_issues_url"`
    		OpenedMergeRequest string `json:"opened_merge_requests_url"`
    		Self               string `json:"self"`
    	} `json:"_links"`
    }
    
    // ListReleasesOptions represents ListReleases() options.
    //
    // GitLab API docs:
    // https://docs.gitlab.com/ee/api/releases/index.html#list-releases
    type ListReleasesOptions struct {
    	ListOptions
    	OrderBy                *string `url:"order_by,omitempty" json:"order_by,omitempty"`
    	Sort                   *string `url:"sort,omitempty" json:"sort,omitempty"`
    	IncludeHTMLDescription *bool   `url:"include_html_description,omitempty" json:"include_html_description,omitempty"`
    }
    
    // ListReleases gets a pagenated of releases accessible by the authenticated user.
    //
    // GitLab API docs:
    // https://docs.gitlab.com/ee/api/releases/index.html#list-releases
    func (s *ReleasesService) ListReleases(pid interface{}, opt *ListReleasesOptions, options ...RequestOptionFunc) ([]*Release, *Response, error) {
    	project, err := parseID(pid)
    	if err != nil {
    		return nil, nil, err
    	}
    	u := fmt.Sprintf("projects/%s/releases", PathEscape(project))
    
    	req, err := s.client.NewRequest(http.MethodGet, u, opt, options)
    	if err != nil {
    		return nil, nil, err
    	}
    
    	var rs []*Release
    	resp, err := s.client.Do(req, &rs)
    	if err != nil {
    		return nil, resp, err
    	}
    
    	return rs, resp, nil
    }
    
    // GetRelease returns a single release, identified by a tag name.
    //
    // GitLab API docs:
    // https://docs.gitlab.com/ee/api/releases/index.html#get-a-release-by-a-tag-name
    func (s *ReleasesService) GetRelease(pid interface{}, tagName string, options ...RequestOptionFunc) (*Release, *Response, error) {
    	project, err := parseID(pid)
    	if err != nil {
    		return nil, nil, err
    	}
    	u := fmt.Sprintf("projects/%s/releases/%s", PathEscape(project), PathEscape(tagName))
    
    	req, err := s.client.NewRequest(http.MethodGet, u, nil, options)
    	if err != nil {
    		return nil, nil, err
    	}
    
    	r := new(Release)
    	resp, err := s.client.Do(req, r)
    	if err != nil {
    		return nil, resp, err
    	}
    
    	return r, resp, nil
    }
    
    // GetLatestRelease returns the latest release for the project.
    //
    // GitLab API docs:
    // https://docs.gitlab.com/ee/api/releases/#get-the-latest-release
    func (s *ReleasesService) GetLatestRelease(pid interface{}, options ...RequestOptionFunc) (*Release, *Response, error) {
    	project, err := parseID(pid)
    	if err != nil {
    		return nil, nil, err
    	}
    	u := fmt.Sprintf("projects/%s/releases/permalink/latest", PathEscape(project))
    
    	req, err := s.client.NewRequest(http.MethodGet, u, nil, options)
    	if err != nil {
    		return nil, nil, err
    	}
    
    	r := new(Release)
    	resp, err := s.client.Do(req, r)
    	if err != nil {
    		return nil, resp, err
    	}
    
    	return r, resp, err
    }
    
    // CreateReleaseOptions represents CreateRelease() options.
    //
    // GitLab API docs:
    // https://docs.gitlab.com/ee/api/releases/index.html#create-a-release
    type CreateReleaseOptions struct {
    	Name        *string               `url:"name,omitempty" json:"name,omitempty"`
    	TagName     *string               `url:"tag_name,omitempty" json:"tag_name,omitempty"`
    	TagMessage  *string               `url:"tag_message,omitempty" json:"tag_message,omitempty"`
    	Description *string               `url:"description,omitempty" json:"description,omitempty"`
    	Ref         *string               `url:"ref,omitempty" json:"ref,omitempty"`
    	Milestones  *[]string             `url:"milestones,omitempty" json:"milestones,omitempty"`
    	Assets      *ReleaseAssetsOptions `url:"assets,omitempty" json:"assets,omitempty"`
    	ReleasedAt  *time.Time            `url:"released_at,omitempty" json:"released_at,omitempty"`
    }
    
    // ReleaseAssetsOptions represents release assets in CreateRelease() options.
    //
    // GitLab API docs:
    // https://docs.gitlab.com/ee/api/releases/index.html#create-a-release
    type ReleaseAssetsOptions struct {
    	Links []*ReleaseAssetLinkOptions `url:"links,omitempty" json:"links,omitempty"`
    }
    
    // ReleaseAssetLinkOptions represents release asset link in CreateRelease()
    // options.
    //
    // GitLab API docs:
    // https://docs.gitlab.com/ee/api/releases/index.html#create-a-release
    type ReleaseAssetLinkOptions struct {
    	Name            *string        `url:"name,omitempty" json:"name,omitempty"`
    	URL             *string        `url:"url,omitempty" json:"url,omitempty"`
    	FilePath        *string        `url:"filepath,omitempty" json:"filepath,omitempty"`
    	DirectAssetPath *string        `url:"direct_asset_path,omitempty" json:"direct_asset_path,omitempty"`
    	LinkType        *LinkTypeValue `url:"link_type,omitempty" json:"link_type,omitempty"`
    }
    
    // CreateRelease creates a release.
    //
    // GitLab API docs:
    // https://docs.gitlab.com/ee/api/releases/index.html#create-a-release
    func (s *ReleasesService) CreateRelease(pid interface{}, opts *CreateReleaseOptions, options ...RequestOptionFunc) (*Release, *Response, error) {
    	project, err := parseID(pid)
    	if err != nil {
    		return nil, nil, err
    	}
    	u := fmt.Sprintf("projects/%s/releases", PathEscape(project))
    
    	req, err := s.client.NewRequest(http.MethodPost, u, opts, options)
    	if err != nil {
    		return nil, nil, err
    	}
    
    	r := new(Release)
    	resp, err := s.client.Do(req, r)
    	if err != nil {
    		return nil, resp, err
    	}
    
    	return r, resp, nil
    }
    
    // UpdateReleaseOptions represents UpdateRelease() options.
    //
    // GitLab API docs:
    // https://docs.gitlab.com/ee/api/releases/index.html#update-a-release
    type UpdateReleaseOptions struct {
    	Name        *string    `url:"name" json:"name"`
    	Description *string    `url:"description" json:"description"`
    	Milestones  *[]string  `url:"milestones,omitempty" json:"milestones,omitempty"`
    	ReleasedAt  *time.Time `url:"released_at,omitempty" json:"released_at,omitempty"`
    }
    
    // UpdateRelease updates a release.
    //
    // GitLab API docs:
    // https://docs.gitlab.com/ee/api/releases/index.html#update-a-release
    func (s *ReleasesService) UpdateRelease(pid interface{}, tagName string, opts *UpdateReleaseOptions, options ...RequestOptionFunc) (*Release, *Response, error) {
    	project, err := parseID(pid)
    	if err != nil {
    		return nil, nil, err
    	}
    	u := fmt.Sprintf("projects/%s/releases/%s", PathEscape(project), PathEscape(tagName))
    
    	req, err := s.client.NewRequest(http.MethodPut, u, opts, options)
    	if err != nil {
    		return nil, nil, err
    	}
    
    	r := new(Release)
    	resp, err := s.client.Do(req, &r)
    	if err != nil {
    		return nil, resp, err
    	}
    
    	return r, resp, nil
    }
    
    // DeleteRelease deletes a release.
    //
    // GitLab API docs:
    // https://docs.gitlab.com/ee/api/releases/index.html#delete-a-release
    func (s *ReleasesService) DeleteRelease(pid interface{}, tagName string, options ...RequestOptionFunc) (*Release, *Response, error) {
    	project, err := parseID(pid)
    	if err != nil {
    		return nil, nil, err
    	}
    	u := fmt.Sprintf("projects/%s/releases/%s", PathEscape(project), PathEscape(tagName))
    
    	req, err := s.client.NewRequest(http.MethodDelete, u, nil, options)
    	if err != nil {
    		return nil, nil, err
    	}
    
    	r := new(Release)
    	resp, err := s.client.Do(req, r)
    	if err != nil {
    		return nil, resp, err
    	}
    
    	return r, resp, nil
    }