mirror of
				https://gitea.com/gitea/tea.git
				synced 2025-10-31 09:15:26 +01:00 
			
		
		
		
	Add tea repos search, improve repo listing (#215)
				
					
				
			Merge branch 'master' into add-repo-search-improve-listing-closes-#210 Merge branch 'master' into add-repo-search-improve-listing-closes-#210 fixup! repos list: client side filtering for repo type fix --private flag repos list: client side filtering for repo type repos list: listing of starred repos repos search: rename --mode to --type repo search: prioritize own user UX tradeoff between usefulness & response speed fix -O owner flag filter rework repo list, add repo search repo search is mostly the old behaviour of repo list Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com> Co-authored-by: Norwin Roosen <git@nroo.de> Reviewed-on: https://gitea.com/gitea/tea/pulls/215 Reviewed-by: 6543 <6543@noreply.gitea.io> Reviewed-by: Lunny Xiao <xiaolunwen@gmail.com>
This commit is contained in:
		| @@ -5,10 +5,6 @@ | ||||
| package repos | ||||
|  | ||||
| import ( | ||||
| 	"log" | ||||
| 	"net/http" | ||||
| 	"strings" | ||||
|  | ||||
| 	"code.gitea.io/tea/cmd/flags" | ||||
| 	"code.gitea.io/tea/modules/config" | ||||
| 	"code.gitea.io/tea/modules/print" | ||||
| @@ -17,39 +13,33 @@ import ( | ||||
| 	"github.com/urfave/cli/v2" | ||||
| ) | ||||
|  | ||||
| // CmdReposListFlags contains all flags needed for repo listing | ||||
| var CmdReposListFlags = append([]cli.Flag{ | ||||
| 	&cli.BoolFlag{ | ||||
| 		Name:     "watched", | ||||
| 		Aliases:  []string{"w"}, | ||||
| 		Required: false, | ||||
| 		Usage:    "List your watched repos instead", | ||||
| 	}, | ||||
| 	&cli.BoolFlag{ | ||||
| 		Name:     "starred", | ||||
| 		Aliases:  []string{"s"}, | ||||
| 		Required: false, | ||||
| 		Usage:    "List your starred repos instead", | ||||
| 	}, | ||||
| 	&typeFilterFlag, | ||||
| 	&flags.PaginationPageFlag, | ||||
| 	&flags.PaginationLimitFlag, | ||||
| }, flags.LoginOutputFlags...) | ||||
|  | ||||
| // CmdReposList represents a sub command of repos to list them | ||||
| var CmdReposList = cli.Command{ | ||||
| 	Name:        "ls", | ||||
| 	Aliases:     []string{"list"}, | ||||
| 	Usage:       "List available repositories", | ||||
| 	Description: `List available repositories`, | ||||
| 	Usage:       "List repositories you have access to", | ||||
| 	Description: "List repositories you have access to", | ||||
| 	Action:      RunReposList, | ||||
| 	Flags: append([]cli.Flag{ | ||||
| 		&cli.StringFlag{ | ||||
| 			Name:     "mode", | ||||
| 			Aliases:  []string{"m"}, | ||||
| 			Required: false, | ||||
| 			Usage:    "Filter by mode: fork, mirror, source", | ||||
| 		}, | ||||
| 		&cli.StringFlag{ | ||||
| 			Name:     "owner", | ||||
| 			Aliases:  []string{"O"}, | ||||
| 			Required: false, | ||||
| 			Usage:    "Filter by owner", | ||||
| 		}, | ||||
| 		&cli.StringFlag{ | ||||
| 			Name:     "private", | ||||
| 			Required: false, | ||||
| 			Usage:    "Filter private repos (true|false)", | ||||
| 		}, | ||||
| 		&cli.StringFlag{ | ||||
| 			Name:     "archived", | ||||
| 			Required: false, | ||||
| 			Usage:    "Filter archived repos (true|false)", | ||||
| 		}, | ||||
| 		&flags.PaginationPageFlag, | ||||
| 		&flags.PaginationLimitFlag, | ||||
| 	}, flags.LoginOutputFlags...), | ||||
| 	Flags:       CmdReposListFlags, | ||||
| } | ||||
|  | ||||
| // RunReposList list repositories | ||||
| @@ -57,97 +47,61 @@ func RunReposList(ctx *cli.Context) error { | ||||
| 	login := config.InitCommandLoginOnly(flags.GlobalLoginValue) | ||||
| 	client := login.Client() | ||||
|  | ||||
| 	var ownerID int64 | ||||
| 	if ctx.IsSet("owner") { | ||||
| 		// test if owner is a organisation | ||||
| 		org, resp, err := client.GetOrg(ctx.String("owner")) | ||||
| 		if err != nil { | ||||
| 			if resp == nil || resp.StatusCode != http.StatusNotFound { | ||||
| 				return err | ||||
| 			} | ||||
| 			// if owner is no org, its a user | ||||
| 			user, _, err := client.GetUserInfo(ctx.String("owner")) | ||||
| 			if err != nil { | ||||
| 				return err | ||||
| 			} | ||||
| 			ownerID = user.ID | ||||
| 		} else { | ||||
| 			ownerID = org.ID | ||||
| 		} | ||||
| 	} else { | ||||
| 		me, _, err := client.GetMyUserInfo() | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 		ownerID = me.ID | ||||
| 	} | ||||
|  | ||||
| 	var isArchived *bool | ||||
| 	if ctx.IsSet("archived") { | ||||
| 		archived := strings.ToLower(ctx.String("archived"))[:1] == "t" | ||||
| 		isArchived = &archived | ||||
| 	} | ||||
|  | ||||
| 	var isPrivate *bool | ||||
| 	if ctx.IsSet("private") { | ||||
| 		private := strings.ToLower(ctx.String("private"))[:1] == "t" | ||||
| 		isArchived = &private | ||||
| 	} | ||||
|  | ||||
| 	mode := gitea.RepoTypeNone | ||||
| 	switch ctx.String("mode") { | ||||
| 	case "fork": | ||||
| 		mode = gitea.RepoTypeFork | ||||
| 	case "mirror": | ||||
| 		mode = gitea.RepoTypeMirror | ||||
| 	case "source": | ||||
| 		mode = gitea.RepoTypeSource | ||||
| 	} | ||||
|  | ||||
| 	rps, _, err := client.SearchRepos(gitea.SearchRepoOptions{ | ||||
| 		ListOptions: flags.GetListOptions(ctx), | ||||
| 		OwnerID:     ownerID, | ||||
| 		IsPrivate:   isPrivate, | ||||
| 		IsArchived:  isArchived, | ||||
| 		Type:        mode, | ||||
| 	}) | ||||
| 	typeFilter, err := getTypeFilter(ctx) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	if len(rps) == 0 { | ||||
| 		log.Fatal("No repositories found", rps) | ||||
| 		return nil | ||||
| 	} | ||||
|  | ||||
| 	headers := []string{ | ||||
| 		"Name", | ||||
| 		"Type", | ||||
| 		"SSH", | ||||
| 		"Owner", | ||||
| 	} | ||||
| 	var values [][]string | ||||
|  | ||||
| 	for _, rp := range rps { | ||||
| 		var mode = "source" | ||||
| 		if rp.Fork { | ||||
| 			mode = "fork" | ||||
| 	var rps []*gitea.Repository | ||||
| 	if ctx.Bool("starred") { | ||||
| 		user, _, err := client.GetMyUserInfo() | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 		if rp.Mirror { | ||||
| 			mode = "mirror" | ||||
| 		} | ||||
|  | ||||
| 		values = append( | ||||
| 			values, | ||||
| 			[]string{ | ||||
| 				rp.FullName, | ||||
| 				mode, | ||||
| 				rp.SSHURL, | ||||
| 				rp.Owner.UserName, | ||||
| 			}, | ||||
| 		) | ||||
| 		rps, _, err = client.SearchRepos(gitea.SearchRepoOptions{ | ||||
| 			ListOptions:     flags.GetListOptions(ctx), | ||||
| 			StarredByUserID: user.ID, | ||||
| 		}) | ||||
| 	} else if ctx.Bool("watched") { | ||||
| 		rps, _, err = client.GetMyWatchedRepos() // TODO: this does not expose pagination.. | ||||
| 	} else { | ||||
| 		rps, _, err = client.ListMyRepos(gitea.ListReposOptions{ | ||||
| 			ListOptions: flags.GetListOptions(ctx), | ||||
| 		}) | ||||
| 	} | ||||
| 	print.OutputList(flags.GlobalOutputValue, headers, values) | ||||
|  | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	reposFiltered := rps | ||||
| 	if typeFilter != gitea.RepoTypeNone { | ||||
| 		reposFiltered = filterReposByType(rps, typeFilter) | ||||
| 	} | ||||
|  | ||||
| 	print.ReposList(reposFiltered) | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func filterReposByType(repos []*gitea.Repository, t gitea.RepoType) []*gitea.Repository { | ||||
| 	var filtered []*gitea.Repository | ||||
| 	for _, r := range repos { | ||||
| 		switch t { | ||||
| 		case gitea.RepoTypeFork: | ||||
| 			if !r.Fork { | ||||
| 				continue | ||||
| 			} | ||||
| 		case gitea.RepoTypeMirror: | ||||
| 			if !r.Mirror { | ||||
| 				continue | ||||
| 			} | ||||
| 		case gitea.RepoTypeSource: | ||||
| 			if r.Fork || r.Mirror { | ||||
| 				continue | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		filtered = append(filtered, r) | ||||
| 	} | ||||
| 	return filtered | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Norwin
					Norwin