diff options
author | Matthew Walowski <mattwalowski@gmail.com> | 2023-05-08 18:06:05 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-05-09 09:06:05 +0800 |
commit | 1dd83dbb917d55bd253001646d6743f247a4d98b (patch) | |
tree | 8c0a0f9e6903e366a7ed8ee043f686ecd40f343a /routers/api/v1/repo/commits.go | |
parent | 707c7e60c94c5b0d27ade7462dda1e526d35f369 (diff) | |
download | gitea-1dd83dbb917d55bd253001646d6743f247a4d98b.tar.gz gitea-1dd83dbb917d55bd253001646d6743f247a4d98b.zip |
Filters for GetAllCommits (#24568)
The `GetAllCommits` endpoint can be pretty slow, especially in repos
with a lot of commits. The issue is that it spends a lot of time
calculating information that may not be useful/needed by the user.
The `stat` param was previously added in #21337 to address this, by
allowing the user to disable the calculating stats for each commit. But
this has two issues:
1. The name `stat` is rather misleading, because disabling `stat`
disables the Stat **and** Files. This should be separated out into two
different params, because getting a list of affected files is much less
expensive than calculating the stats
2. There's still other costly information provided that the user may not
need, such as `Verification`
This PR, adds two parameters to the endpoint, `files` and `verification`
to allow the user to explicitly disable this information when listing
commits. The default behavior is true.
Diffstat (limited to 'routers/api/v1/repo/commits.go')
-rw-r--r-- | routers/api/v1/repo/commits.go | 20 |
1 files changed, 18 insertions, 2 deletions
diff --git a/routers/api/v1/repo/commits.go b/routers/api/v1/repo/commits.go index a5e2e7baef..9b7de91a72 100644 --- a/routers/api/v1/repo/commits.go +++ b/routers/api/v1/repo/commits.go @@ -69,7 +69,7 @@ func getCommit(ctx *context.APIContext, identifier string) { return } - json, err := convert.ToCommit(ctx, ctx.Repo.Repository, ctx.Repo.GitRepo, commit, nil, true) + json, err := convert.ToCommit(ctx, ctx.Repo.Repository, ctx.Repo.GitRepo, commit, nil, convert.ToCommitOptions{Stat: true}) if err != nil { ctx.Error(http.StatusInternalServerError, "toCommit", err) return @@ -107,6 +107,14 @@ func GetAllCommits(ctx *context.APIContext) { // in: query // description: include diff stats for every commit (disable for speedup, default 'true') // type: boolean + // - name: verification + // in: query + // description: include verification for every commit (disable for speedup, default 'true') + // type: boolean + // - name: files + // in: query + // description: include a list of affected files for every commit (disable for speedup, default 'true') + // type: boolean // - name: page // in: query // description: page number of results to return (1-based) @@ -238,10 +246,18 @@ func GetAllCommits(ctx *context.APIContext) { apiCommits := make([]*api.Commit, len(commits)) stat := ctx.FormString("stat") == "" || ctx.FormBool("stat") + verification := ctx.FormString("verification") == "" || ctx.FormBool("verification") + files := ctx.FormString("files") == "" || ctx.FormBool("files") for i, commit := range commits { // Create json struct - apiCommits[i], err = convert.ToCommit(ctx, ctx.Repo.Repository, ctx.Repo.GitRepo, commit, userCache, stat) + apiCommits[i], err = convert.ToCommit(ctx, ctx.Repo.Repository, ctx.Repo.GitRepo, commit, userCache, + convert.ToCommitOptions{ + Stat: stat, + Verification: verification, + Files: files, + }) + if err != nil { ctx.Error(http.StatusInternalServerError, "toCommit", err) return |