c572fcfe04
Rename the Go module path from code.gitea.io/gitea to git.mokoconsulting.tech/MokoConsulting/MokoGitea across the entire codebase. Scope: - go.mod module declaration - 2,235 Go source files (import paths) - Dockerfile WORKDIR and COPY paths - Swagger API templates - golangci.yml linter config External dependencies (code.gitea.io/gitea-vet, code.gitea.io/sdk/gitea, gitea.com/gitea/act, etc.) are intentionally NOT renamed — they are separate upstream modules. Closes #132 Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
50 lines
1.4 KiB
Go
50 lines
1.4 KiB
Go
// Copyright 2020 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package stats
|
|
|
|
import (
|
|
"errors"
|
|
|
|
repo_model "git.mokoconsulting.tech/MokoConsulting/MokoGitea/models/repo"
|
|
"git.mokoconsulting.tech/MokoConsulting/MokoGitea/modules/graceful"
|
|
"git.mokoconsulting.tech/MokoConsulting/MokoGitea/modules/log"
|
|
"git.mokoconsulting.tech/MokoConsulting/MokoGitea/modules/queue"
|
|
"git.mokoconsulting.tech/MokoConsulting/MokoGitea/modules/setting"
|
|
)
|
|
|
|
// statsQueue represents a queue to handle repository stats updates
|
|
var statsQueue *queue.WorkerPoolQueue[int64]
|
|
|
|
// handle passed PR IDs and test the PRs
|
|
func handler(items ...int64) []int64 {
|
|
for _, opts := range items {
|
|
if err := indexer.Index(opts); err != nil {
|
|
if !setting.IsInTesting {
|
|
log.Error("stats queue indexer.Index(%d) failed: %v", opts, err)
|
|
}
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func initStatsQueue() error {
|
|
statsQueue = queue.CreateUniqueQueue(graceful.GetManager().ShutdownContext(), "repo_stats_update", handler)
|
|
if statsQueue == nil {
|
|
return errors.New("unable to create repo_stats_update queue")
|
|
}
|
|
go graceful.GetManager().RunWithCancel(statsQueue)
|
|
return nil
|
|
}
|
|
|
|
// UpdateRepoIndexer update a repository's entries in the indexer
|
|
func UpdateRepoIndexer(repo *repo_model.Repository) error {
|
|
if err := statsQueue.Push(repo.ID); err != nil {
|
|
if err != queue.ErrAlreadyInQueue {
|
|
return err
|
|
}
|
|
log.Debug("Repo ID: %d already queued", repo.ID)
|
|
}
|
|
return nil
|
|
}
|