mirror of
https://github.com/woodpecker-ci/woodpecker.git
synced 2024-12-12 08:23:48 +02:00
ff01a9ff1d
closes #1295 closes #648 # TODO - [x] add new routes with `:repoID` - [x] load repo in middleware using `:repoID` if present - [x] update UI routes `:owner/:name` to `:repoID` - [x] load repos using id in UI - [x] add lookup endpoint `:owner/:name` to `:repoID` - [x] redirect `:owner/:name` to `:repoID` in UI - [x] use badge with `:repoID` route in UI - [x] update `woodpecker-go` - [x] check cli - [x] add migrations / deprecation notes - [x] check if #648 got solved directly - [x] Test - [x] create repo - [x] repo pages - [x] ui redirects - [x] forge status links
53 lines
1.1 KiB
Go
53 lines
1.1 KiB
Go
package secret
|
|
|
|
import (
|
|
"strings"
|
|
|
|
"github.com/urfave/cli/v2"
|
|
|
|
"github.com/woodpecker-ci/woodpecker/cli/common"
|
|
"github.com/woodpecker-ci/woodpecker/cli/internal"
|
|
"github.com/woodpecker-ci/woodpecker/woodpecker-go/woodpecker"
|
|
)
|
|
|
|
// Command exports the secret command.
|
|
var Command = &cli.Command{
|
|
Name: "secret",
|
|
Usage: "manage secrets",
|
|
Flags: common.GlobalFlags,
|
|
Subcommands: []*cli.Command{
|
|
secretCreateCmd,
|
|
secretDeleteCmd,
|
|
secretUpdateCmd,
|
|
secretInfoCmd,
|
|
secretListCmd,
|
|
},
|
|
}
|
|
|
|
func parseTargetArgs(client woodpecker.Client, c *cli.Context) (global bool, owner string, repoID int64, err error) {
|
|
if c.Bool("global") {
|
|
return true, "", -1, nil
|
|
}
|
|
|
|
repoIDOrFullName := c.String("repository")
|
|
if repoIDOrFullName == "" {
|
|
repoIDOrFullName = c.Args().First()
|
|
}
|
|
|
|
orgName := c.String("organization")
|
|
if orgName != "" && repoIDOrFullName == "" {
|
|
return false, orgName, -1, err
|
|
}
|
|
|
|
if orgName != "" && !strings.Contains(repoIDOrFullName, "/") {
|
|
repoIDOrFullName = orgName + "/" + repoIDOrFullName
|
|
}
|
|
|
|
repoID, err = internal.ParseRepo(client, repoIDOrFullName)
|
|
if err != nil {
|
|
return false, "", -1, err
|
|
}
|
|
|
|
return false, "", repoID, nil
|
|
}
|