mirror of
https://gitea.com/gitea/tea.git
synced 2026-04-25 17:07:49 +02:00
## Summary - Extract duplicate \`getReleaseByTag\` into shared \`cmd/releases/utils.go\` - Replace \`log.Fatal\` calls with proper error returns in config and login commands; \`GetLoginByToken\`/\`GetLoginsByHost\`/\`GetLoginByHost\` now return errors - Remove dead \`portChan\` channel in \`modules/auth/oauth.go\` - Fix YAML integer detection to use \`strconv.ParseInt\` (correctly handles negatives and large ints) - Fix \`path.go\` error handling to use \`errors.As\` + \`syscall.ENOTDIR\` instead of string comparison - Extract repeated credential helper key into local variable in \`SetupHelper\` - Use existing \`isRemoteDeleted()\` in \`pull_clean.go\` instead of duplicating the logic - Fix ~30 error message casing violations to follow Go conventions - Use \`fmt.Errorf\` consistently instead of string concatenation in \`generic.go\` Reviewed-on: https://gitea.com/gitea/tea/pulls/947 Reviewed-by: Lunny Xiao <xiaolunwen@gmail.com> Reviewed-by: Bo-Yi Wu (吳柏毅) <appleboy.tw@gmail.com> Co-authored-by: Nicolas <bircni@icloud.com> Co-committed-by: Nicolas <bircni@icloud.com>
190 lines
5 KiB
Go
190 lines
5 KiB
Go
// Copyright 2025 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package flags
|
|
|
|
import (
|
|
"errors"
|
|
"fmt"
|
|
|
|
"code.gitea.io/sdk/gitea"
|
|
"github.com/urfave/cli/v3"
|
|
)
|
|
|
|
// LoginFlag provides flag to specify tea login profile
|
|
var LoginFlag = cli.StringFlag{
|
|
Name: "login",
|
|
Aliases: []string{"l"},
|
|
Usage: "Use a different Gitea Login. Optional",
|
|
}
|
|
|
|
// RepoFlag provides flag to specify repository
|
|
var RepoFlag = cli.StringFlag{
|
|
Name: "repo",
|
|
Aliases: []string{"r"},
|
|
Usage: "Override local repository path or gitea repository slug to interact with. Optional",
|
|
}
|
|
|
|
// RemoteFlag provides flag to specify remote repository
|
|
var RemoteFlag = cli.StringFlag{
|
|
Name: "remote",
|
|
Aliases: []string{"R"},
|
|
Usage: "Discover Gitea login from remote. Optional",
|
|
}
|
|
|
|
// OutputFlag provides flag to specify output type
|
|
var OutputFlag = cli.StringFlag{
|
|
Name: "output",
|
|
Aliases: []string{"o"},
|
|
Usage: "Output format. (simple, table, csv, tsv, yaml, json)",
|
|
}
|
|
|
|
var (
|
|
// ErrPage indicates that the provided page value is invalid (less than -1 or equal to 0).
|
|
ErrPage = errors.New("page cannot be smaller than 1")
|
|
// ErrLimit indicates that the provided limit value is invalid (negative).
|
|
ErrLimit = errors.New("limit cannot be negative")
|
|
)
|
|
|
|
const (
|
|
defaultPageValue = 1
|
|
defaultLimitValue = 30
|
|
)
|
|
|
|
// GetListOptions returns list options derived from the active command.
|
|
func GetListOptions(cmd *cli.Command) gitea.ListOptions {
|
|
page := cmd.Int("page")
|
|
if page == 0 {
|
|
page = defaultPageValue
|
|
}
|
|
|
|
pageSize := cmd.Int("limit")
|
|
if pageSize == 0 {
|
|
pageSize = defaultLimitValue
|
|
}
|
|
|
|
return gitea.ListOptions{
|
|
Page: page,
|
|
PageSize: pageSize,
|
|
}
|
|
}
|
|
|
|
// PaginationFlags provides all pagination related flags
|
|
var PaginationFlags = []cli.Flag{
|
|
&PaginationPageFlag,
|
|
&PaginationLimitFlag,
|
|
}
|
|
|
|
// PaginationPageFlag provides flag for pagination options
|
|
var PaginationPageFlag = cli.IntFlag{
|
|
Name: "page",
|
|
Aliases: []string{"p"},
|
|
Usage: "specify page",
|
|
Value: defaultPageValue,
|
|
Validator: func(i int) error {
|
|
if i < 1 && i != -1 {
|
|
return ErrPage
|
|
}
|
|
return nil
|
|
},
|
|
}
|
|
|
|
// PaginationLimitFlag provides flag for pagination options
|
|
var PaginationLimitFlag = cli.IntFlag{
|
|
Name: "limit",
|
|
Aliases: []string{"lm"},
|
|
Usage: "specify limit of items per page",
|
|
Value: defaultLimitValue,
|
|
Validator: func(i int) error {
|
|
if i < 0 {
|
|
return ErrLimit
|
|
}
|
|
return nil
|
|
},
|
|
}
|
|
|
|
// LoginOutputFlags defines login and output flags that should
|
|
// added to all subcommands and appended to the flags of the
|
|
// subcommand to work around issue and provide --login and --output:
|
|
// https://github.com/urfave/cli/issues/585
|
|
var LoginOutputFlags = []cli.Flag{
|
|
&LoginFlag,
|
|
&OutputFlag,
|
|
}
|
|
|
|
// LoginRepoFlags defines login and repo flags that should
|
|
// be used for all subcommands and appended to the flags of
|
|
// the subcommand to work around issue and provide --login and --repo:
|
|
// https://github.com/urfave/cli/issues/585
|
|
var LoginRepoFlags = []cli.Flag{
|
|
&LoginFlag,
|
|
&RepoFlag,
|
|
&RemoteFlag,
|
|
}
|
|
|
|
// AllDefaultFlags defines flags that should be available
|
|
// for all subcommands working with dedicated repositories
|
|
// to work around issue and provide --login, --repo and --output:
|
|
// https://github.com/urfave/cli/issues/585
|
|
var AllDefaultFlags = append([]cli.Flag{
|
|
&RepoFlag,
|
|
&RemoteFlag,
|
|
}, LoginOutputFlags...)
|
|
|
|
// NotificationFlags defines flags that should be available on notifications.
|
|
var NotificationFlags = append([]cli.Flag{
|
|
NotificationStateFlag,
|
|
&cli.BoolFlag{
|
|
Name: "mine",
|
|
Aliases: []string{"m"},
|
|
Usage: "Show notifications across all your repositories instead of the current repository only",
|
|
},
|
|
&PaginationPageFlag,
|
|
&PaginationLimitFlag,
|
|
}, AllDefaultFlags...)
|
|
|
|
// NotificationStateFlag is a csv flag applied to all notification subcommands as filter
|
|
var NotificationStateFlag = NewCsvFlag(
|
|
"states",
|
|
"notification states to filter by",
|
|
[]string{"s"},
|
|
[]string{"pinned", "unread", "read"},
|
|
[]string{"unread", "pinned"},
|
|
)
|
|
|
|
// FieldsFlag generates a flag selecting printable fields.
|
|
// To retrieve the value, use f.GetValues()
|
|
func FieldsFlag(availableFields, defaultFields []string) *CsvFlag {
|
|
return NewCsvFlag("fields", "fields to print", []string{"f"}, availableFields, defaultFields)
|
|
}
|
|
|
|
// ParseState parses a state string and returns the corresponding gitea.StateType
|
|
func ParseState(stateStr string) (gitea.StateType, error) {
|
|
switch stateStr {
|
|
case "all":
|
|
return gitea.StateAll, nil
|
|
case "", "open":
|
|
return gitea.StateOpen, nil
|
|
case "closed":
|
|
return gitea.StateClosed, nil
|
|
default:
|
|
return "", fmt.Errorf("unknown state '%s'", stateStr)
|
|
}
|
|
}
|
|
|
|
// ParseIssueKind parses a kind string and returns the corresponding gitea.IssueType.
|
|
// If kindStr is empty, returns the provided defaultKind.
|
|
func ParseIssueKind(kindStr string, defaultKind gitea.IssueType) (gitea.IssueType, error) {
|
|
switch kindStr {
|
|
case "":
|
|
return defaultKind, nil
|
|
case "all":
|
|
return gitea.IssueTypeAll, nil
|
|
case "issue", "issues":
|
|
return gitea.IssueTypeIssue, nil
|
|
case "pull", "pulls", "pr":
|
|
return gitea.IssueTypePull, nil
|
|
default:
|
|
return "", fmt.Errorf("unknown kind '%s'", kindStr)
|
|
}
|
|
}
|