mirror of
https://github.com/woodpecker-ci/woodpecker.git
synced 2024-11-23 18:31:00 +00:00
41af9c0720
Since we are not able to list the already set secrets I have added the required API andpoint and the required sub command to list them.
63 lines
1.3 KiB
Go
63 lines
1.3 KiB
Go
package main
|
|
|
|
import (
|
|
"crypto/tls"
|
|
"fmt"
|
|
"io/ioutil"
|
|
"os"
|
|
"strings"
|
|
|
|
"github.com/drone/drone/client"
|
|
|
|
"github.com/codegangsta/cli"
|
|
"github.com/jackspirou/syscerts"
|
|
)
|
|
|
|
func newClient(c *cli.Context) (client.Client, error) {
|
|
var token = c.GlobalString("token")
|
|
var server = c.GlobalString("server")
|
|
|
|
// if no server url is provided we can default
|
|
// to the hosted Drone service.
|
|
if len(server) == 0 {
|
|
return nil, fmt.Errorf("Error: you must provide the Drone server address.")
|
|
}
|
|
if len(token) == 0 {
|
|
return nil, fmt.Errorf("Error: you must provide your Drone access token.")
|
|
}
|
|
|
|
// attempt to find system CA certs
|
|
certs := syscerts.SystemRootsPool()
|
|
tlsConfig := &tls.Config{RootCAs: certs}
|
|
|
|
// create the drone client with TLS options
|
|
return client.NewClientTokenTLS(server, token, tlsConfig), nil
|
|
}
|
|
|
|
func parseRepo(str string) (user, repo string, err error) {
|
|
var parts = strings.Split(str, "/")
|
|
if len(parts) != 2 {
|
|
err = fmt.Errorf("Error: Invalid or missing repository. eg octocat/hello-world.")
|
|
return
|
|
}
|
|
user = parts[0]
|
|
repo = parts[1]
|
|
return
|
|
}
|
|
|
|
func readInput(in string) ([]byte, error) {
|
|
if in == "-" {
|
|
return ioutil.ReadAll(os.Stdin)
|
|
}
|
|
return ioutil.ReadFile(in)
|
|
}
|
|
|
|
func stringInSlice(a string, list []string) bool {
|
|
for _, b := range list {
|
|
if b == a {
|
|
return true
|
|
}
|
|
}
|
|
|
|
return false
|
|
}
|