mirror of
https://gitea.com/gitea/tea.git
synced 2026-04-26 01:42:26 +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>
74 lines
1.7 KiB
Go
74 lines
1.7 KiB
Go
// Copyright 2020 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package releases
|
|
|
|
import (
|
|
stdctx "context"
|
|
"fmt"
|
|
|
|
"code.gitea.io/tea/cmd/flags"
|
|
"code.gitea.io/tea/modules/context"
|
|
|
|
"github.com/urfave/cli/v3"
|
|
)
|
|
|
|
// CmdReleaseDelete represents a sub command of Release to delete a release
|
|
var CmdReleaseDelete = cli.Command{
|
|
Name: "delete",
|
|
Aliases: []string{"rm"},
|
|
Usage: "Delete one or more releases",
|
|
Description: `Delete one or more releases`,
|
|
ArgsUsage: "<release tag> [<release tag>...]",
|
|
Action: runReleaseDelete,
|
|
Flags: append([]cli.Flag{
|
|
&cli.BoolFlag{
|
|
Name: "confirm",
|
|
Aliases: []string{"y"},
|
|
Usage: "Confirm deletion (required)",
|
|
},
|
|
&cli.BoolFlag{
|
|
Name: "delete-tag",
|
|
Usage: "Also delete the git tag for this release",
|
|
},
|
|
}, flags.AllDefaultFlags...),
|
|
}
|
|
|
|
func runReleaseDelete(_ stdctx.Context, cmd *cli.Command) error {
|
|
ctx, err := context.InitCommand(cmd)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if err := ctx.Ensure(context.CtxRequirement{RemoteRepo: true}); err != nil {
|
|
return err
|
|
}
|
|
client := ctx.Login.Client()
|
|
|
|
if !ctx.Args().Present() {
|
|
fmt.Println("Release tag needed to edit")
|
|
return nil
|
|
}
|
|
|
|
if !ctx.Bool("confirm") {
|
|
fmt.Println("Are you sure? Please confirm with -y or --confirm.")
|
|
return nil
|
|
}
|
|
|
|
for _, tag := range ctx.Args().Slice() {
|
|
release, err := GetReleaseByTag(ctx.Owner, ctx.Repo, tag, client)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
_, err = client.DeleteRelease(ctx.Owner, ctx.Repo, release.ID)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if ctx.Bool("delete-tag") {
|
|
_, err = client.DeleteTag(ctx.Owner, ctx.Repo, tag)
|
|
return err
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|