2021-10-27 21:03:14 +02:00
|
|
|
// Copyright 2021 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.
|
|
|
|
|
|
|
|
package common
|
|
|
|
|
2023-08-07 20:47:30 +02:00
|
|
|
import (
|
|
|
|
"github.com/urfave/cli/v2"
|
2021-10-27 21:03:14 +02:00
|
|
|
|
2024-01-01 00:29:56 +02:00
|
|
|
"go.woodpecker-ci.org/woodpecker/v2/shared/logger"
|
2023-08-07 20:47:30 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
var GlobalFlags = append([]cli.Flag{
|
2024-03-13 12:08:22 +02:00
|
|
|
&cli.StringFlag{
|
|
|
|
EnvVars: []string{"WOODPECKER_CONFIG"},
|
|
|
|
Name: "config",
|
|
|
|
Aliases: []string{"c"},
|
|
|
|
Usage: "path to config file",
|
|
|
|
},
|
2021-10-27 21:03:14 +02:00
|
|
|
&cli.StringFlag{
|
|
|
|
EnvVars: []string{"WOODPECKER_SERVER"},
|
|
|
|
Name: "server",
|
|
|
|
Aliases: []string{"s"},
|
|
|
|
Usage: "server address",
|
|
|
|
},
|
2024-06-06 13:30:08 +02:00
|
|
|
&cli.StringFlag{
|
|
|
|
EnvVars: []string{"WOODPECKER_TOKEN"},
|
|
|
|
Name: "token",
|
|
|
|
Aliases: []string{"t"},
|
|
|
|
Usage: "server auth token",
|
|
|
|
},
|
2024-02-19 10:16:27 +02:00
|
|
|
&cli.BoolFlag{
|
2024-02-19 11:04:55 +02:00
|
|
|
EnvVars: []string{"WOODPECKER_DISABLE_UPDATE_CHECK"},
|
2024-02-19 10:16:27 +02:00
|
|
|
Name: "disable-update-check",
|
|
|
|
Usage: "disable update check",
|
|
|
|
},
|
2021-10-27 21:03:14 +02:00
|
|
|
&cli.BoolFlag{
|
|
|
|
EnvVars: []string{"WOODPECKER_SKIP_VERIFY"},
|
|
|
|
Name: "skip-verify",
|
|
|
|
Usage: "skip ssl verification",
|
|
|
|
Hidden: true,
|
|
|
|
},
|
|
|
|
&cli.StringFlag{
|
|
|
|
EnvVars: []string{"SOCKS_PROXY"},
|
|
|
|
Name: "socks-proxy",
|
|
|
|
Usage: "socks proxy address",
|
|
|
|
Hidden: true,
|
|
|
|
},
|
|
|
|
&cli.BoolFlag{
|
|
|
|
EnvVars: []string{"SOCKS_PROXY_OFF"},
|
|
|
|
Name: "socks-proxy-off",
|
|
|
|
Usage: "socks proxy ignored",
|
|
|
|
Hidden: true,
|
|
|
|
},
|
2024-01-01 00:29:56 +02:00
|
|
|
}, logger.GlobalLoggerFlags...)
|
2021-10-27 21:03:14 +02:00
|
|
|
|
|
|
|
// FormatFlag return format flag with value set based on template
|
2024-05-13 22:58:21 +02:00
|
|
|
// if hidden value is set, flag will be hidden.
|
2021-10-27 21:03:14 +02:00
|
|
|
func FormatFlag(tmpl string, hidden ...bool) *cli.StringFlag {
|
|
|
|
return &cli.StringFlag{
|
|
|
|
Name: "format",
|
|
|
|
Usage: "format output",
|
|
|
|
Value: tmpl,
|
|
|
|
Hidden: len(hidden) != 0,
|
|
|
|
}
|
|
|
|
}
|
2022-08-30 01:14:07 +02:00
|
|
|
|
2024-05-02 08:43:46 +02:00
|
|
|
// OutputFlags returns a slice of cli.Flag containing output format options.
|
|
|
|
func OutputFlags(def string) []cli.Flag {
|
|
|
|
return []cli.Flag{
|
|
|
|
&cli.StringFlag{
|
|
|
|
Name: "output",
|
|
|
|
Usage: "output format",
|
|
|
|
Value: def,
|
|
|
|
},
|
|
|
|
&cli.BoolFlag{
|
|
|
|
Name: "output-no-headers",
|
|
|
|
Usage: "don't print headers",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-08-30 01:14:07 +02:00
|
|
|
var RepoFlag = &cli.StringFlag{
|
|
|
|
Name: "repository",
|
|
|
|
Aliases: []string{"repo"},
|
2024-05-01 11:50:41 +02:00
|
|
|
Usage: "repository id or full name (e.g. 134 or octocat/hello-world)",
|
2022-08-30 01:14:07 +02:00
|
|
|
}
|
2023-07-21 19:45:32 +02:00
|
|
|
|
|
|
|
var OrgFlag = &cli.StringFlag{
|
|
|
|
Name: "organization",
|
|
|
|
Aliases: []string{"org"},
|
2024-05-01 11:50:41 +02:00
|
|
|
Usage: "organization id or full name (e.g. 123 or octocat)",
|
2023-07-21 19:45:32 +02:00
|
|
|
}
|