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:
Bo-Yi Wu
2026-03-12 04:22:28 +00:00
committed by Bo-Yi Wu (吳柏毅)
parent a531faa626
commit cb9824b451
3 changed files with 36 additions and 5 deletions

View File

@@ -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