mass renaming of gitlab to gitea
This commit is contained in:
305
gitea.go
Normal file
305
gitea.go
Normal file
@@ -0,0 +1,305 @@
|
||||
package resource
|
||||
|
||||
import (
|
||||
"crypto/tls"
|
||||
"errors"
|
||||
"fmt"
|
||||
"io"
|
||||
"net/http"
|
||||
"net/url"
|
||||
"os"
|
||||
"path/filepath"
|
||||
"strings"
|
||||
|
||||
"golang.org/x/oauth2"
|
||||
|
||||
"context"
|
||||
|
||||
"code.gitea.io/sdk/gitea"
|
||||
)
|
||||
|
||||
//go:generate counterfeiter . Gitea
|
||||
|
||||
type Gitea interface {
|
||||
ListTags() ([]*gitea.Tag, error)
|
||||
ListTagsUntil(tag_name string) ([]*gitea.Tag, error)
|
||||
GetTag(tag_name string) (*gitea.Tag, error)
|
||||
CreateTag(tag_name string, ref string) (*gitea.Tag, error)
|
||||
CreateRelease(tag_name string, description string) (*gitea.Release, error)
|
||||
UpdateRelease(tag_name string, description string) (*gitea.Release, error)
|
||||
UploadProjectFile(file string) (*gitea.ProjectFile, error)
|
||||
DownloadProjectFile(url, file string) error
|
||||
}
|
||||
|
||||
type GiteaClient struct {
|
||||
client *gitea.Client
|
||||
|
||||
accessToken string
|
||||
repository string
|
||||
}
|
||||
|
||||
func NewGiteaClient(source Source) (*GiteaClient, error) {
|
||||
var httpClient = &http.Client{}
|
||||
var ctx = context.TODO()
|
||||
|
||||
if source.Insecure {
|
||||
httpClient.Transport = &http.Transport{
|
||||
TLSClientConfig: &tls.Config{InsecureSkipVerify: true},
|
||||
}
|
||||
ctx = context.WithValue(ctx, oauth2.HTTPClient, httpClient)
|
||||
}
|
||||
|
||||
client := gitea.NewClient(httpClient, source.AccessToken)
|
||||
|
||||
if source.GiteaAPIURL != "" {
|
||||
var err error
|
||||
baseUrl, err := url.Parse(source.GiteaAPIURL)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
client.SetBaseURL(baseUrl.String())
|
||||
}
|
||||
|
||||
return &GiteaClient{
|
||||
client: client,
|
||||
repository: source.Repository,
|
||||
accessToken: source.AccessToken,
|
||||
}, nil
|
||||
}
|
||||
|
||||
func (g *GiteaClient) ListTags() ([]*gitea.Tag, error) {
|
||||
var allTags []*gitea.Tag
|
||||
|
||||
opt := &gitea.ListTagsOptions{
|
||||
ListOptions: gitea.ListOptions{
|
||||
PerPage: 100,
|
||||
Page: 1,
|
||||
},
|
||||
OrderBy: gitea.String("updated"),
|
||||
Sort: gitea.String("desc"),
|
||||
}
|
||||
|
||||
for {
|
||||
tags, res, err := g.client.Tags.ListTags(g.repository, opt)
|
||||
if err != nil {
|
||||
return []*gitea.Tag{}, err
|
||||
}
|
||||
|
||||
allTags = append(allTags, tags...)
|
||||
|
||||
if opt.Page >= res.TotalPages {
|
||||
break
|
||||
}
|
||||
|
||||
opt.Page = res.NextPage
|
||||
}
|
||||
|
||||
return allTags, nil
|
||||
}
|
||||
|
||||
func (g *GiteaClient) ListTagsUntil(tag_name string) ([]*gitea.Tag, error) {
|
||||
var allTags []*gitea.Tag
|
||||
|
||||
pageSize := 100
|
||||
|
||||
opt := &gitea.ListTagsOptions{
|
||||
ListOptions: gitea.ListOptions{
|
||||
PerPage: pageSize,
|
||||
Page: 1,
|
||||
},
|
||||
OrderBy: gitea.String("updated"),
|
||||
Sort: gitea.String("desc"),
|
||||
}
|
||||
|
||||
var foundTag *gitea.Tag
|
||||
for {
|
||||
tags, res, err := g.client.Tags.ListTags(g.repository, opt)
|
||||
if err != nil {
|
||||
return []*gitea.Tag{}, err
|
||||
}
|
||||
|
||||
skipToNextPage := false
|
||||
for i, tag := range tags {
|
||||
// Some tags might have the same date - if they all have the same date, take
|
||||
// all of them
|
||||
if foundTag != nil {
|
||||
if foundTag.Commit.CommittedDate.Equal(*tag.Commit.CommittedDate) {
|
||||
allTags = append(allTags, tag)
|
||||
if i == (pageSize - 1) {
|
||||
skipToNextPage = true
|
||||
break
|
||||
} else {
|
||||
continue
|
||||
}
|
||||
} else {
|
||||
break
|
||||
}
|
||||
}
|
||||
|
||||
if tag.Name == tag_name {
|
||||
allTags = append(allTags, tags[:i+1]...)
|
||||
foundTag = tag
|
||||
continue
|
||||
}
|
||||
}
|
||||
if skipToNextPage {
|
||||
if opt.Page >= res.TotalPages {
|
||||
break
|
||||
}
|
||||
|
||||
opt.Page = res.NextPage
|
||||
continue
|
||||
}
|
||||
|
||||
if foundTag != nil {
|
||||
break
|
||||
}
|
||||
|
||||
allTags = append(allTags, tags...)
|
||||
|
||||
if opt.Page >= res.TotalPages {
|
||||
break
|
||||
}
|
||||
|
||||
opt.Page = res.NextPage
|
||||
}
|
||||
|
||||
return allTags, nil
|
||||
}
|
||||
|
||||
func (g *GiteaClient) GetTag(tag_name string) (*gitea.Tag, error) {
|
||||
tag, res, err := g.client.Tags.GetTag(g.repository, tag_name)
|
||||
if err != nil {
|
||||
return &gitea.Tag{}, err
|
||||
}
|
||||
|
||||
err = res.Body.Close()
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
return tag, nil
|
||||
}
|
||||
|
||||
func (g *GiteaClient) CreateTag(ref string, tag_name string) (*gitea.Tag, error) {
|
||||
opt := &gitea.CreateTagOptions{
|
||||
TagName: gitea.String(tag_name),
|
||||
Ref: gitea.String(ref),
|
||||
Message: gitea.String(tag_name),
|
||||
}
|
||||
|
||||
tag, res, err := g.client.Tags.CreateTag(g.repository, opt)
|
||||
if err != nil {
|
||||
return &gitea.Tag{}, err
|
||||
}
|
||||
|
||||
err = res.Body.Close()
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
return tag, nil
|
||||
}
|
||||
|
||||
func (g *GiteaClient) CreateRelease(tag_name string, description string) (*gitea.Release, error) {
|
||||
opt := &gitea.CreateReleaseOptions{
|
||||
Description: gitea.String(description),
|
||||
}
|
||||
|
||||
release, res, err := g.client.Tags.CreateRelease(g.repository, tag_name, opt)
|
||||
if err != nil {
|
||||
return &gitea.Release{}, err
|
||||
}
|
||||
|
||||
// https://docs.gitea.com/ce/api/tags.html#create-a-new-release
|
||||
// returns 409 if release already exists
|
||||
if res.StatusCode == http.StatusConflict {
|
||||
return nil, errors.New("release already exists")
|
||||
}
|
||||
|
||||
err = res.Body.Close()
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
return release, nil
|
||||
}
|
||||
|
||||
func (g *GiteaClient) UpdateRelease(tag_name string, description string) (*gitea.Release, error) {
|
||||
opt := &gitea.UpdateReleaseOptions{
|
||||
Description: gitea.String(description),
|
||||
}
|
||||
|
||||
release, res, err := g.client.Tags.UpdateRelease(g.repository, tag_name, opt)
|
||||
if err != nil {
|
||||
return &gitea.Release{}, err
|
||||
}
|
||||
|
||||
err = res.Body.Close()
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
return release, nil
|
||||
}
|
||||
|
||||
func (g *GiteaClient) UploadProjectFile(file string) (*gitea.ProjectFile, error) {
|
||||
projectFile, res, err := g.client.Projects.UploadFile(g.repository, file)
|
||||
if err != nil {
|
||||
return &gitea.ProjectFile{}, err
|
||||
}
|
||||
|
||||
err = res.Body.Close()
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
return projectFile, nil
|
||||
}
|
||||
|
||||
func (g *GiteaClient) DownloadProjectFile(filePath, destPath string) error {
|
||||
out, err := os.Create(destPath)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
defer out.Close()
|
||||
|
||||
// e.g. (group/project) + (/uploads/hash/filename)
|
||||
filePathRef, err := url.Parse(g.repository + filePath)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
// e.g. (https://gitea-instance/api/v4) + (/group/project/uploads/hash/filename)
|
||||
projectFileUrl := g.client.BaseURL().ResolveReference(filePathRef)
|
||||
|
||||
// https://gitea.com/gitea-org/gitea-ce/issues/51447
|
||||
nonApiUrl := strings.Replace(projectFileUrl.String(), "/api/v4", "", 1)
|
||||
projectFileUrl, err = url.Parse(nonApiUrl)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
client := &http.Client{}
|
||||
req, err := http.NewRequest("GET", projectFileUrl.String(), nil)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
req.Header.Add("Private-Token", g.accessToken)
|
||||
resp, err := client.Do(req)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
defer resp.Body.Close()
|
||||
|
||||
if resp.StatusCode != http.StatusOK {
|
||||
return fmt.Errorf("failed to download file `%s`: HTTP status %d", filepath.Base(destPath), resp.StatusCode)
|
||||
}
|
||||
|
||||
_, err = io.Copy(out, resp.Body)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
Reference in New Issue
Block a user