Full Mattermost server source with integrated Community Enterprise features. Includes vendor directory for offline/air-gapped builds. Structure: - enterprise-impl/: Enterprise feature implementations - enterprise-community/: Init files that register implementations - enterprise/: Bridge imports (community_imports.go) - vendor/: All dependencies for offline builds Build (online): go build ./cmd/mattermost Build (offline/air-gapped): go build -mod=vendor ./cmd/mattermost 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
136 lines
3.8 KiB
Go
136 lines
3.8 KiB
Go
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
|
|
package localcachelayer
|
|
|
|
import (
|
|
"bytes"
|
|
"fmt"
|
|
|
|
"github.com/mattermost/mattermost/server/public/model"
|
|
"github.com/mattermost/mattermost/server/v8/channels/store"
|
|
)
|
|
|
|
type LocalCacheFileInfoStore struct {
|
|
store.FileInfoStore
|
|
rootStore *LocalCacheStore
|
|
}
|
|
|
|
func (s *LocalCacheFileInfoStore) handleClusterInvalidateFileInfo(msg *model.ClusterMessage) {
|
|
if bytes.Equal(msg.Data, clearCacheMessageData) {
|
|
s.rootStore.fileInfoCache.Purge()
|
|
return
|
|
}
|
|
s.rootStore.fileInfoCache.Remove(string(msg.Data))
|
|
}
|
|
|
|
func (s LocalCacheFileInfoStore) GetForPost(postId string, readFromMaster, includeDeleted, allowFromCache bool) ([]*model.FileInfo, error) {
|
|
if !allowFromCache {
|
|
return s.FileInfoStore.GetForPost(postId, readFromMaster, includeDeleted, allowFromCache)
|
|
}
|
|
|
|
cacheKey := postId
|
|
if includeDeleted {
|
|
cacheKey += "_deleted"
|
|
}
|
|
|
|
var fileInfo []*model.FileInfo
|
|
if err := s.rootStore.doStandardReadCache(s.rootStore.fileInfoCache, cacheKey, &fileInfo); err == nil {
|
|
return fileInfo, nil
|
|
}
|
|
|
|
fileInfos, err := s.FileInfoStore.GetForPost(postId, readFromMaster, includeDeleted, allowFromCache)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
if len(fileInfos) > 0 {
|
|
s.rootStore.doStandardAddToCache(s.rootStore.fileInfoCache, cacheKey, fileInfos)
|
|
}
|
|
|
|
return fileInfos, nil
|
|
}
|
|
|
|
func (s LocalCacheFileInfoStore) GetByIds(ids []string, includeDeleted, allowFromCache bool) ([]*model.FileInfo, error) {
|
|
if !allowFromCache {
|
|
return s.FileInfoStore.GetByIds(ids, includeDeleted, allowFromCache)
|
|
}
|
|
|
|
var fileIdsToFetch []string
|
|
var fileInfos []*model.FileInfo
|
|
|
|
for _, fileId := range ids {
|
|
cacheKey := fmt.Sprintf("%s_%t", fileId, includeDeleted)
|
|
|
|
var fileInfo *model.FileInfo
|
|
if err := s.rootStore.doStandardReadCache(s.rootStore.fileInfoCache, cacheKey, &fileInfo); err == nil {
|
|
fileInfos = append(fileInfos, fileInfo)
|
|
} else {
|
|
fileIdsToFetch = append(fileIdsToFetch, fileId)
|
|
}
|
|
}
|
|
|
|
if len(fileIdsToFetch) > 0 {
|
|
fetchedFileInfos, err := s.FileInfoStore.GetByIds(fileIdsToFetch, includeDeleted, false)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
for _, fileInfo := range fetchedFileInfos {
|
|
cacheKey := fmt.Sprintf("%s_%t", fileInfo.Id, includeDeleted)
|
|
s.rootStore.doStandardAddToCache(s.rootStore.fileInfoCache, cacheKey, fileInfo)
|
|
fileInfos = append(fileInfos, fileInfo)
|
|
}
|
|
}
|
|
|
|
return fileInfos, nil
|
|
}
|
|
|
|
func (s LocalCacheFileInfoStore) ClearCaches() {
|
|
s.rootStore.fileInfoCache.Purge()
|
|
if s.rootStore.metrics != nil {
|
|
s.rootStore.metrics.IncrementMemCacheInvalidationCounter(s.rootStore.fileInfoCache.Name())
|
|
}
|
|
}
|
|
|
|
func (s LocalCacheFileInfoStore) InvalidateFileInfosForPostCache(postId string, deleted bool) {
|
|
cacheKey := postId
|
|
if deleted {
|
|
cacheKey += "_deleted"
|
|
}
|
|
s.rootStore.doInvalidateCacheCluster(s.rootStore.fileInfoCache, cacheKey, nil)
|
|
if s.rootStore.metrics != nil {
|
|
s.rootStore.metrics.IncrementMemCacheInvalidationCounter(s.rootStore.fileInfoCache.Name())
|
|
}
|
|
}
|
|
|
|
func (s LocalCacheFileInfoStore) GetStorageUsage(allowFromCache, includeDeleted bool) (int64, error) {
|
|
storageUsageKey := "storage_usage"
|
|
if includeDeleted {
|
|
storageUsageKey += "_deleted"
|
|
}
|
|
|
|
if !allowFromCache {
|
|
usage, err := s.FileInfoStore.GetStorageUsage(allowFromCache, includeDeleted)
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
|
|
s.rootStore.doStandardAddToCache(s.rootStore.fileInfoCache, storageUsageKey, usage)
|
|
return usage, nil
|
|
}
|
|
|
|
var usage int64
|
|
if err := s.rootStore.doStandardReadCache(s.rootStore.fileInfoCache, storageUsageKey, &usage); err == nil {
|
|
return usage, nil
|
|
}
|
|
|
|
usage, err := s.FileInfoStore.GetStorageUsage(allowFromCache, includeDeleted)
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
|
|
s.rootStore.doStandardAddToCache(s.rootStore.fileInfoCache, storageUsageKey, usage)
|
|
return usage, nil
|
|
}
|