Compare commits

..

No commits in common. "bc99681992115b7603c35be4bed4b8a9790c0037" and "0dd91c5ce717d818fedb6472db504b9682890fc3" have entirely different histories.

3 changed files with 6 additions and 41 deletions

View File

@ -30,7 +30,7 @@ steps:
from_secret: docker_username
password:
from_secret: docker_password
- image: gitea.dikurium.ch/innopeak/drone-gitea-release:0.7
- image: gitea.dikurium.ch/innopeak/drone-gitea-release:0.6
name: create release
settings:
gitea_password:

View File

@ -26,8 +26,6 @@ type Args struct {
GiteaUrl string `envconfig:"PLUGIN_GITEA_URL"`
GiteaUsername string `envconfig:"PLUGIN_GITEA_USERNAME"`
GiteaPassword string `envconfig:"PLUGIN_GITEA_PASSWORD"`
GitUsername string `envconfig:"PLUGIN_GIT_USERNAME"`
GitPassword string `envconfig:"PLUGIN_GIT_PASSWORD"`
Owner string `envconfig:"PLUGIN_OWNER"`
Repo string `envconfig:"PLUGIN_REPO"`
TitleFormat string `envconfig:"PLUGIN_TITLE_FORMAT"`
@ -78,11 +76,8 @@ func Exec(ctx context.Context, args Args) error {
if args.UseLatestGitTag {
var options = make([]GetLatestGitTagOption, 0)
if args.GitUsername != "" && args.GitPassword != "" {
options = append(options, SetBasicAuth(args.GitUsername, args.GitPassword))
}
if args.FetchGitTags {
options = append(options, FetchTags())
options = append(options, FetchTags)
}
tag, err = getLatestGitTag(options...)

View File

@ -9,52 +9,22 @@ import (
"encoding/json"
"fmt"
"io"
"net/http"
"os"
"strings"
"github.com/go-git/go-git/v5"
"github.com/go-git/go-git/v5/plumbing/transport/client"
githttp "github.com/go-git/go-git/v5/plumbing/transport/http"
)
type GetLatestGitTagOption func(repo *git.Repository) error
type BasicAuthTransport struct {
Username string
Password string
RoundTriper http.RoundTripper
}
func (bat BasicAuthTransport) RoundTrip(req *http.Request) (resp *http.Response, err error) {
creds := base64.StdEncoding.EncodeToString([]byte(fmt.Sprintf("%s:%s", bat.Username, bat.Password)))
req.Header.Set("Authorization", fmt.Sprintf("Basic %s", creds))
return bat.RoundTriper.RoundTrip(req)
}
func SetBasicAuth(username, password string) func(repo *git.Repository) error {
return func(repo *git.Repository) error {
customClient := &http.Client{
Transport: BasicAuthTransport{username, password, http.DefaultTransport},
}
// Override http(s) default protocol to use our custom client
client.InstallProtocol("https", githttp.NewClient(customClient))
var FetchTags = func(repo *git.Repository) error {
err := repo.Fetch(&git.FetchOptions{Tags: git.AllTags})
if err == git.NoErrAlreadyUpToDate {
return nil
}
}
func FetchTags() func(repo *git.Repository) error {
return func(repo *git.Repository) error {
err := repo.Fetch(&git.FetchOptions{Tags: git.AllTags})
if err == git.NoErrAlreadyUpToDate {
return nil
}
return err
}
return err
}
func getLatestGitTag(options ...GetLatestGitTagOption) (tag string, err error) {