mirror of
https://gitea.com/gitea/tea.git
synced 2024-12-04 14:46:40 -05:00
dc67630b64
introduce TeaContext clean up InitCommand move GetListOptions to TeaContext ensure context for each command so we fail early with a good error message instead of "Error: 404" etc make linter happy Merge branch 'master' into refactor-global-flags move TeaContext & InitCommand to modules/context Merge branch 'master' into refactor-global-flags CI.restart() Merge branch 'master' into refactor-global-flags Merge branch 'master' into refactor-global-flags Co-authored-by: Norwin Roosen <git@nroo.de> Co-authored-by: 6543 <6543@obermui.de> Reviewed-on: https://gitea.com/gitea/tea/pulls/291 Reviewed-by: Lunny Xiao <xiaolunwen@gmail.com> Reviewed-by: khmarbaise <khmarbaise@noreply.gitea.io> Reviewed-by: 6543 <6543@obermui.de> Co-Authored-By: Norwin <noerw@noreply.gitea.io> Co-Committed-By: Norwin <noerw@noreply.gitea.io>
175 lines
4.4 KiB
Go
175 lines
4.4 KiB
Go
// Copyright 2020 The Gitea Authors. All rights reserved.
|
|
// Use of this source code is governed by a MIT-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package milestones
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"code.gitea.io/tea/cmd/flags"
|
|
"code.gitea.io/tea/modules/context"
|
|
"code.gitea.io/tea/modules/print"
|
|
"code.gitea.io/tea/modules/utils"
|
|
|
|
"code.gitea.io/sdk/gitea"
|
|
"github.com/urfave/cli/v2"
|
|
)
|
|
|
|
// CmdMilestonesIssues represents a sub command of milestones to manage issue/pull of an milestone
|
|
var CmdMilestonesIssues = cli.Command{
|
|
Name: "issues",
|
|
Aliases: []string{"i"},
|
|
Usage: "manage issue/pull of an milestone",
|
|
Description: "manage issue/pull of an milestone",
|
|
ArgsUsage: "<milestone name>",
|
|
Action: runMilestoneIssueList,
|
|
Subcommands: []*cli.Command{
|
|
&CmdMilestoneAddIssue,
|
|
&CmdMilestoneRemoveIssue,
|
|
},
|
|
Flags: append([]cli.Flag{
|
|
&cli.StringFlag{
|
|
Name: "state",
|
|
Usage: "Filter by issue state (all|open|closed)",
|
|
DefaultText: "open",
|
|
},
|
|
&cli.StringFlag{
|
|
Name: "kind",
|
|
Usage: "Filter by kind (issue|pull)",
|
|
},
|
|
&flags.PaginationPageFlag,
|
|
&flags.PaginationLimitFlag,
|
|
}, flags.AllDefaultFlags...),
|
|
}
|
|
|
|
// CmdMilestoneAddIssue represents a sub command of milestone issues to add an issue/pull to an milestone
|
|
var CmdMilestoneAddIssue = cli.Command{
|
|
Name: "add",
|
|
Aliases: []string{"a"},
|
|
Usage: "Add an issue/pull to an milestone",
|
|
Description: "Add an issue/pull to an milestone",
|
|
ArgsUsage: "<milestone name> <issue/pull index>",
|
|
Action: runMilestoneIssueAdd,
|
|
Flags: flags.AllDefaultFlags,
|
|
}
|
|
|
|
// CmdMilestoneRemoveIssue represents a sub command of milestones to remove an issue/pull from an milestone
|
|
var CmdMilestoneRemoveIssue = cli.Command{
|
|
Name: "remove",
|
|
Aliases: []string{"r"},
|
|
Usage: "Remove an issue/pull to an milestone",
|
|
Description: "Remove an issue/pull to an milestone",
|
|
ArgsUsage: "<milestone name> <issue/pull index>",
|
|
Action: runMilestoneIssueRemove,
|
|
Flags: flags.AllDefaultFlags,
|
|
}
|
|
|
|
func runMilestoneIssueList(cmd *cli.Context) error {
|
|
ctx := context.InitCommand(cmd)
|
|
ctx.Ensure(context.CtxRequirement{RemoteRepo: true})
|
|
client := ctx.Login.Client()
|
|
|
|
state := gitea.StateOpen
|
|
switch ctx.String("state") {
|
|
case "all":
|
|
state = gitea.StateAll
|
|
case "closed":
|
|
state = gitea.StateClosed
|
|
}
|
|
|
|
kind := gitea.IssueTypeAll
|
|
switch ctx.String("kind") {
|
|
case "issue":
|
|
kind = gitea.IssueTypeIssue
|
|
case "pull":
|
|
kind = gitea.IssueTypePull
|
|
}
|
|
|
|
if ctx.Args().Len() != 1 {
|
|
return fmt.Errorf("Must specify milestone name")
|
|
}
|
|
|
|
milestone := ctx.Args().First()
|
|
// make sure milestone exist
|
|
_, _, err := client.GetMilestoneByName(ctx.Owner, ctx.Repo, milestone)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
issues, _, err := client.ListRepoIssues(ctx.Owner, ctx.Repo, gitea.ListIssueOption{
|
|
ListOptions: ctx.GetListOptions(),
|
|
Milestones: []string{milestone},
|
|
Type: kind,
|
|
State: state,
|
|
})
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
print.IssuesPullsList(issues, ctx.Output)
|
|
return nil
|
|
}
|
|
|
|
func runMilestoneIssueAdd(cmd *cli.Context) error {
|
|
ctx := context.InitCommand(cmd)
|
|
ctx.Ensure(context.CtxRequirement{RemoteRepo: true})
|
|
client := ctx.Login.Client()
|
|
if ctx.Args().Len() != 2 {
|
|
return fmt.Errorf("need two arguments")
|
|
}
|
|
|
|
mileName := ctx.Args().Get(0)
|
|
issueIndex := ctx.Args().Get(1)
|
|
idx, err := utils.ArgToIndex(issueIndex)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
// make sure milestone exist
|
|
mile, _, err := client.GetMilestoneByName(ctx.Owner, ctx.Repo, mileName)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
_, _, err = client.EditIssue(ctx.Owner, ctx.Repo, idx, gitea.EditIssueOption{
|
|
Milestone: &mile.ID,
|
|
})
|
|
return err
|
|
}
|
|
|
|
func runMilestoneIssueRemove(cmd *cli.Context) error {
|
|
ctx := context.InitCommand(cmd)
|
|
ctx.Ensure(context.CtxRequirement{RemoteRepo: true})
|
|
client := ctx.Login.Client()
|
|
if ctx.Args().Len() != 2 {
|
|
return fmt.Errorf("need two arguments")
|
|
}
|
|
|
|
mileName := ctx.Args().Get(0)
|
|
issueIndex := ctx.Args().Get(1)
|
|
idx, err := utils.ArgToIndex(issueIndex)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
issue, _, err := client.GetIssue(ctx.Owner, ctx.Repo, idx)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if issue.Milestone == nil {
|
|
return fmt.Errorf("issue is not assigned to a milestone")
|
|
}
|
|
|
|
if issue.Milestone.Title != mileName {
|
|
return fmt.Errorf("issue is not assigned to this milestone")
|
|
}
|
|
|
|
zero := int64(0)
|
|
_, _, err = client.EditIssue(ctx.Owner, ctx.Repo, idx, gitea.EditIssueOption{
|
|
Milestone: &zero,
|
|
})
|
|
return err
|
|
}
|