mirror of
https://gitea.com/gitea/tea.git
synced 2026-03-13 09:13:30 +01:00
feat(repos): support owner-based repository listing with robust lookup (#931)
- Add an owner flag to the repos list command to list repositories for a specific user or organization - Implement owner-based repository listing by detecting whether the owner is an organization or a user and calling the appropriate API - Improve error handling for owner lookup by checking HTTP status codes instead of relying on error string matching - Align repository search logic with the updated owner lookup behavior using HTTP response validation Signed-off-by: Bo-Yi Wu <appleboy.tw@gmail.com> Reviewed-on: https://gitea.com/gitea/tea/pulls/931 Co-authored-by: Bo-Yi Wu <appleboy.tw@gmail.com> Co-committed-by: Bo-Yi Wu <appleboy.tw@gmail.com>
This commit is contained in:
@@ -6,6 +6,7 @@ package repos
|
||||
import (
|
||||
stdctx "context"
|
||||
"fmt"
|
||||
"net/http"
|
||||
"strings"
|
||||
|
||||
"code.gitea.io/tea/cmd/flags"
|
||||
@@ -63,11 +64,10 @@ func runReposSearch(_ stdctx.Context, cmd *cli.Command) error {
|
||||
var ownerID int64
|
||||
if teaCmd.IsSet("owner") {
|
||||
// test if owner is an organization
|
||||
org, _, err := client.GetOrg(teaCmd.String("owner"))
|
||||
org, resp, err := client.GetOrg(teaCmd.String("owner"))
|
||||
if err != nil {
|
||||
// HACK: the client does not return a response on 404, so we can't check res.StatusCode
|
||||
if err.Error() != "404 Not Found" {
|
||||
return fmt.Errorf("Could not find owner: %s", err)
|
||||
if resp == nil || resp.StatusCode != http.StatusNotFound {
|
||||
return fmt.Errorf("Could not find owner: %w", err)
|
||||
}
|
||||
|
||||
// if owner is no org, its a user
|
||||
|
||||
Reference in New Issue
Block a user