mirror of
				https://gitea.com/gitea/tea.git
				synced 2025-10-31 01:05:26 +01:00 
			
		
		
		
	replace flag globals, require context for commands (#291)
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>
This commit is contained in:
		| @@ -11,7 +11,7 @@ import ( | ||||
| 	"time" | ||||
|  | ||||
| 	"code.gitea.io/tea/cmd/flags" | ||||
| 	"code.gitea.io/tea/modules/config" | ||||
| 	"code.gitea.io/tea/modules/context" | ||||
| 	"code.gitea.io/tea/modules/utils" | ||||
|  | ||||
| 	"code.gitea.io/sdk/gitea" | ||||
| @@ -31,8 +31,9 @@ var CmdTrackedTimesAdd = cli.Command{ | ||||
| 	Flags:  flags.LoginRepoFlags, | ||||
| } | ||||
|  | ||||
| func runTrackedTimesAdd(ctx *cli.Context) error { | ||||
| 	login, owner, repo := config.InitCommand(flags.GlobalRepoValue, flags.GlobalLoginValue, flags.GlobalRemoteValue) | ||||
| func runTrackedTimesAdd(cmd *cli.Context) error { | ||||
| 	ctx := context.InitCommand(cmd) | ||||
| 	ctx.Ensure(context.CtxRequirement{RemoteRepo: true}) | ||||
|  | ||||
| 	if ctx.Args().Len() < 2 { | ||||
| 		return fmt.Errorf("No issue or duration specified.\nUsage:\t%s", ctx.Command.UsageText) | ||||
| @@ -48,7 +49,7 @@ func runTrackedTimesAdd(ctx *cli.Context) error { | ||||
| 		log.Fatal(err) | ||||
| 	} | ||||
|  | ||||
| 	_, _, err = login.Client().AddTime(owner, repo, issue, gitea.AddTimeOption{ | ||||
| 	_, _, err = ctx.Login.Client().AddTime(ctx.Owner, ctx.Repo, issue, gitea.AddTimeOption{ | ||||
| 		Time: int64(duration.Seconds()), | ||||
| 	}) | ||||
| 	if err != nil { | ||||
|   | ||||
| @@ -10,7 +10,7 @@ import ( | ||||
| 	"strconv" | ||||
|  | ||||
| 	"code.gitea.io/tea/cmd/flags" | ||||
| 	"code.gitea.io/tea/modules/config" | ||||
| 	"code.gitea.io/tea/modules/context" | ||||
| 	"code.gitea.io/tea/modules/utils" | ||||
|  | ||||
| 	"github.com/urfave/cli/v2" | ||||
| @@ -26,9 +26,10 @@ var CmdTrackedTimesDelete = cli.Command{ | ||||
| 	Flags:     flags.LoginRepoFlags, | ||||
| } | ||||
|  | ||||
| func runTrackedTimesDelete(ctx *cli.Context) error { | ||||
| 	login, owner, repo := config.InitCommand(flags.GlobalRepoValue, flags.GlobalLoginValue, flags.GlobalRemoteValue) | ||||
| 	client := login.Client() | ||||
| func runTrackedTimesDelete(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("No issue or time ID specified.\nUsage:\t%s", ctx.Command.UsageText) | ||||
| @@ -44,7 +45,7 @@ func runTrackedTimesDelete(ctx *cli.Context) error { | ||||
| 		log.Fatal(err) | ||||
| 	} | ||||
|  | ||||
| 	_, err = client.DeleteTime(owner, repo, issue, timeID) | ||||
| 	_, err = client.DeleteTime(ctx.Owner, ctx.Repo, issue, timeID) | ||||
| 	if err != nil { | ||||
| 		log.Fatal(err) | ||||
| 	} | ||||
|   | ||||
| @@ -10,7 +10,7 @@ import ( | ||||
| 	"time" | ||||
|  | ||||
| 	"code.gitea.io/tea/cmd/flags" | ||||
| 	"code.gitea.io/tea/modules/config" | ||||
| 	"code.gitea.io/tea/modules/context" | ||||
| 	"code.gitea.io/tea/modules/print" | ||||
| 	"code.gitea.io/tea/modules/utils" | ||||
|  | ||||
| @@ -50,9 +50,10 @@ var CmdTrackedTimesList = cli.Command{ | ||||
| } | ||||
|  | ||||
| // RunTimesList list repositories | ||||
| func RunTimesList(ctx *cli.Context) error { | ||||
| 	login, owner, repo := config.InitCommand(flags.GlobalRepoValue, flags.GlobalLoginValue, flags.GlobalRemoteValue) | ||||
| 	client := login.Client() | ||||
| func RunTimesList(cmd *cli.Context) error { | ||||
| 	ctx := context.InitCommand(cmd) | ||||
| 	ctx.Ensure(context.CtxRequirement{RemoteRepo: true}) | ||||
| 	client := ctx.Login.Client() | ||||
|  | ||||
| 	var times []*gitea.TrackedTime | ||||
| 	var err error | ||||
| @@ -61,17 +62,17 @@ func RunTimesList(ctx *cli.Context) error { | ||||
| 	fmt.Println(ctx.Command.ArgsUsage) | ||||
| 	if user == "" { | ||||
| 		// get all tracked times on the repo | ||||
| 		times, _, err = client.GetRepoTrackedTimes(owner, repo) | ||||
| 		times, _, err = client.GetRepoTrackedTimes(ctx.Owner, ctx.Repo) | ||||
| 	} else if strings.HasPrefix(user, "#") { | ||||
| 		// get all tracked times on the specified issue | ||||
| 		issue, err := utils.ArgToIndex(user) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 		times, _, err = client.ListTrackedTimes(owner, repo, issue, gitea.ListTrackedTimesOptions{}) | ||||
| 		times, _, err = client.ListTrackedTimes(ctx.Owner, ctx.Repo, issue, gitea.ListTrackedTimesOptions{}) | ||||
| 	} else { | ||||
| 		// get all tracked times by the specified user | ||||
| 		times, _, err = client.GetUserTrackedTimes(owner, repo, user) | ||||
| 		times, _, err = client.GetUserTrackedTimes(ctx.Owner, ctx.Repo, user) | ||||
| 	} | ||||
|  | ||||
| 	if err != nil { | ||||
| @@ -92,6 +93,6 @@ func RunTimesList(ctx *cli.Context) error { | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	print.TrackedTimesList(times, flags.GlobalOutputValue, from, until, ctx.Bool("total")) | ||||
| 	print.TrackedTimesList(times, ctx.Output, from, until, ctx.Bool("total")) | ||||
| 	return nil | ||||
| } | ||||
|   | ||||
| @@ -9,7 +9,7 @@ import ( | ||||
| 	"log" | ||||
|  | ||||
| 	"code.gitea.io/tea/cmd/flags" | ||||
| 	"code.gitea.io/tea/modules/config" | ||||
| 	"code.gitea.io/tea/modules/context" | ||||
| 	"code.gitea.io/tea/modules/utils" | ||||
|  | ||||
| 	"github.com/urfave/cli/v2" | ||||
| @@ -25,9 +25,10 @@ var CmdTrackedTimesReset = cli.Command{ | ||||
| 	Flags:     flags.LoginRepoFlags, | ||||
| } | ||||
|  | ||||
| func runTrackedTimesReset(ctx *cli.Context) error { | ||||
| 	login, owner, repo := config.InitCommand(flags.GlobalRepoValue, flags.GlobalLoginValue, flags.GlobalRemoteValue) | ||||
| 	client := login.Client() | ||||
| func runTrackedTimesReset(cmd *cli.Context) error { | ||||
| 	ctx := context.InitCommand(cmd) | ||||
| 	ctx.Ensure(context.CtxRequirement{RemoteRepo: true}) | ||||
| 	client := ctx.Login.Client() | ||||
|  | ||||
| 	if ctx.Args().Len() != 1 { | ||||
| 		return fmt.Errorf("No issue specified.\nUsage:\t%s", ctx.Command.UsageText) | ||||
| @@ -38,7 +39,7 @@ func runTrackedTimesReset(ctx *cli.Context) error { | ||||
| 		log.Fatal(err) | ||||
| 	} | ||||
|  | ||||
| 	_, err = client.ResetIssueTime(owner, repo, issue) | ||||
| 	_, err = client.ResetIssueTime(ctx.Owner, ctx.Repo, issue) | ||||
| 	if err != nil { | ||||
| 		log.Fatal(err) | ||||
| 	} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Norwin
					Norwin