2023-08-10 11:06:00 +02:00
|
|
|
// Copyright 2023 Woodpecker Authors
|
|
|
|
//
|
|
|
|
// 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.
|
|
|
|
|
2019-04-06 21:32:14 +02:00
|
|
|
package internal
|
|
|
|
|
|
|
|
import (
|
|
|
|
"crypto/tls"
|
2021-10-28 09:14:16 +02:00
|
|
|
"crypto/x509"
|
2019-04-06 21:32:14 +02:00
|
|
|
"fmt"
|
|
|
|
"net/http"
|
2023-06-13 01:07:52 +02:00
|
|
|
"strconv"
|
2019-04-06 21:32:14 +02:00
|
|
|
"strings"
|
|
|
|
|
2021-10-28 09:14:16 +02:00
|
|
|
"github.com/rs/zerolog/log"
|
2021-10-27 21:03:14 +02:00
|
|
|
"github.com/urfave/cli/v2"
|
2019-04-06 21:32:14 +02:00
|
|
|
"golang.org/x/net/proxy"
|
|
|
|
"golang.org/x/oauth2"
|
|
|
|
|
2023-12-08 09:15:08 +02:00
|
|
|
"go.woodpecker-ci.org/woodpecker/v2/woodpecker-go/woodpecker"
|
2019-04-06 21:32:14 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
// NewClient returns a new client from the CLI context.
|
2021-10-03 00:27:43 +02:00
|
|
|
func NewClient(c *cli.Context) (woodpecker.Client, error) {
|
2019-04-06 21:32:14 +02:00
|
|
|
var (
|
2021-10-27 21:03:14 +02:00
|
|
|
skip = c.Bool("skip-verify")
|
|
|
|
socks = c.String("socks-proxy")
|
2024-05-24 22:35:04 +02:00
|
|
|
socksOff = c.Bool("socks-proxy-off")
|
2021-10-27 21:03:14 +02:00
|
|
|
token = c.String("token")
|
|
|
|
server = c.String("server")
|
2019-04-06 21:32:14 +02:00
|
|
|
)
|
|
|
|
server = strings.TrimRight(server, "/")
|
|
|
|
|
|
|
|
// if no server url is provided we can default
|
2021-10-03 00:27:43 +02:00
|
|
|
// to the hosted Woodpecker service.
|
2019-04-06 21:32:14 +02:00
|
|
|
if len(server) == 0 {
|
2024-01-10 21:57:12 +02:00
|
|
|
return nil, fmt.Errorf("you must provide the Woodpecker server address")
|
2019-04-06 21:32:14 +02:00
|
|
|
}
|
|
|
|
if len(token) == 0 {
|
2024-01-10 21:57:12 +02:00
|
|
|
return nil, fmt.Errorf("you must provide your Woodpecker access token")
|
2019-04-06 21:32:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// attempt to find system CA certs
|
2021-10-28 09:14:16 +02:00
|
|
|
certs, err := x509.SystemCertPool()
|
2022-04-05 14:37:02 +02:00
|
|
|
if err != nil {
|
2024-01-10 21:57:12 +02:00
|
|
|
log.Error().Err(err).Msg("failed to find system CA certs")
|
2022-04-05 14:37:02 +02:00
|
|
|
}
|
2019-04-06 21:32:14 +02:00
|
|
|
tlsConfig := &tls.Config{
|
|
|
|
RootCAs: certs,
|
|
|
|
InsecureSkipVerify: skip,
|
|
|
|
}
|
|
|
|
|
|
|
|
config := new(oauth2.Config)
|
2021-10-08 18:35:56 +02:00
|
|
|
client := config.Client(
|
2021-10-28 09:14:16 +02:00
|
|
|
c.Context,
|
2019-04-06 21:32:14 +02:00
|
|
|
&oauth2.Token{
|
|
|
|
AccessToken: token,
|
|
|
|
},
|
|
|
|
)
|
|
|
|
|
2021-10-08 18:35:56 +02:00
|
|
|
trans, _ := client.Transport.(*oauth2.Transport)
|
2019-04-06 21:32:14 +02:00
|
|
|
|
2024-05-24 22:35:04 +02:00
|
|
|
if len(socks) != 0 && !socksOff {
|
2019-04-06 21:32:14 +02:00
|
|
|
dialer, err := proxy.SOCKS5("tcp", socks, nil, proxy.Direct)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
trans.Base = &http.Transport{
|
|
|
|
TLSClientConfig: tlsConfig,
|
|
|
|
Proxy: http.ProxyFromEnvironment,
|
|
|
|
Dial: dialer.Dial,
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
trans.Base = &http.Transport{
|
|
|
|
TLSClientConfig: tlsConfig,
|
|
|
|
Proxy: http.ProxyFromEnvironment,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-10-08 18:35:56 +02:00
|
|
|
return woodpecker.NewClient(server, client), nil
|
2019-04-06 21:32:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// ParseRepo parses the repository owner and name from a string.
|
2023-06-13 01:07:52 +02:00
|
|
|
func ParseRepo(client woodpecker.Client, str string) (repoID int64, err error) {
|
|
|
|
if strings.Contains(str, "/") {
|
|
|
|
repo, err := client.RepoLookup(str)
|
|
|
|
if err != nil {
|
|
|
|
return 0, err
|
|
|
|
}
|
|
|
|
return repo.ID, nil
|
2019-04-06 21:32:14 +02:00
|
|
|
}
|
2023-06-13 01:07:52 +02:00
|
|
|
|
|
|
|
return strconv.ParseInt(str, 10, 64)
|
2019-04-06 21:32:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// ParseKeyPair parses a key=value pair.
|
|
|
|
func ParseKeyPair(p []string) map[string]string {
|
|
|
|
params := map[string]string{}
|
|
|
|
for _, i := range p {
|
2024-03-15 19:00:25 +02:00
|
|
|
before, after, ok := strings.Cut(i, "=")
|
|
|
|
if !ok || before == "" {
|
2019-04-06 21:32:14 +02:00
|
|
|
continue
|
|
|
|
}
|
2024-03-15 19:00:25 +02:00
|
|
|
params[before] = after
|
2019-04-06 21:32:14 +02:00
|
|
|
}
|
|
|
|
return params
|
|
|
|
}
|