mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-26 00:48:29 +00:00 
			
		
		
		
	Refactor cache and disable go-chi cache (#30417)
use built-in cache package to wrap external go-chi cache package
This commit is contained in:
		| @@ -7,18 +7,11 @@ import ( | ||||
| 	"crypto/sha256" | ||||
| 	"fmt" | ||||
|  | ||||
| 	"code.gitea.io/gitea/modules/cache" | ||||
| 	"code.gitea.io/gitea/modules/log" | ||||
| 	"code.gitea.io/gitea/modules/setting" | ||||
| ) | ||||
|  | ||||
| // Cache represents a caching interface | ||||
| type Cache interface { | ||||
| 	// Put puts value into cache with key and expire time. | ||||
| 	Put(key string, val any, timeout int64) error | ||||
| 	// Get gets cached value by given key. | ||||
| 	Get(key string) any | ||||
| } | ||||
|  | ||||
| func getCacheKey(repoPath, commitID, entryPath string) string { | ||||
| 	hashBytes := sha256.Sum256([]byte(fmt.Sprintf("%s:%s:%s", repoPath, commitID, entryPath))) | ||||
| 	return fmt.Sprintf("last_commit:%x", hashBytes) | ||||
| @@ -30,11 +23,11 @@ type LastCommitCache struct { | ||||
| 	ttl         func() int64 | ||||
| 	repo        *Repository | ||||
| 	commitCache map[string]*Commit | ||||
| 	cache       Cache | ||||
| 	cache       cache.StringCache | ||||
| } | ||||
|  | ||||
| // NewLastCommitCache creates a new last commit cache for repo | ||||
| func NewLastCommitCache(count int64, repoPath string, gitRepo *Repository, cache Cache) *LastCommitCache { | ||||
| func NewLastCommitCache(count int64, repoPath string, gitRepo *Repository, cache cache.StringCache) *LastCommitCache { | ||||
| 	if cache == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| @@ -65,7 +58,7 @@ func (c *LastCommitCache) Get(ref, entryPath string) (*Commit, error) { | ||||
| 		return nil, nil | ||||
| 	} | ||||
|  | ||||
| 	commitID, ok := c.cache.Get(getCacheKey(c.repoPath, ref, entryPath)).(string) | ||||
| 	commitID, ok := c.cache.Get(getCacheKey(c.repoPath, ref, entryPath)) | ||||
| 	if !ok || commitID == "" { | ||||
| 		return nil, nil | ||||
| 	} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user