mattermost-community-enterp.../cluster/init.go
Claude fad2fe9d3c Initial commit: Mattermost Community Enterprise
Open source implementation of Mattermost Enterprise features:

Authentication & SSO:
- LDAP authentication and sync
- LDAP diagnostics
- SAML 2.0 SSO
- OAuth providers (Google, Office365, OpenID Connect)

Infrastructure:
- Redis-based cluster implementation
- Prometheus metrics
- IP filtering
- Push proxy authentication

Search:
- Bleve search engine (lightweight Elasticsearch alternative)

Compliance & Security:
- Compliance reporting
- Data retention policies
- Message export (Actiance, GlobalRelay, CSV)
- Access control (PAP/PDP)

User Management:
- Account migration (LDAP/SAML)
- ID-loaded push notifications
- Outgoing OAuth connections

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2025-12-17 23:49:14 +09:00

52 lines
1.3 KiB
Go

// Copyright (c) 2024 Mattermost Community Enterprise
// Registration of Redis cluster implementation
package cluster
import (
"os"
"github.com/mattermost/mattermost/server/public/model"
"github.com/mattermost/mattermost/server/public/shared/mlog"
"github.com/mattermost/mattermost/server/v8/channels/app/platform"
"github.com/mattermost/mattermost/server/v8/einterfaces"
)
func init() {
platform.RegisterClusterInterface(NewRedisClusterInterface)
}
func NewRedisClusterInterface(ps *platform.PlatformService) einterfaces.ClusterInterface {
// Check if Redis cluster is enabled via environment variables
redisAddr := os.Getenv("MM_CLUSTER_REDIS_ADDR")
if redisAddr == "" {
// Cluster not enabled
return nil
}
redisPassword := os.Getenv("MM_CLUSTER_REDIS_PASSWORD")
clusterID := os.Getenv("MM_CLUSTER_ID")
if clusterID == "" {
clusterID = "default"
}
cfg := &RedisClusterConfig{
RedisAddr: redisAddr,
RedisPassword: redisPassword,
RedisDB: 0,
ClusterID: clusterID,
Logger: ps.Log(),
Version: model.CurrentVersion,
SchemaVersion: "",
ConfigHash: "",
}
cluster, err := NewRedisCluster(cfg)
if err != nil {
mlog.Error("Failed to initialize Redis cluster", mlog.Err(err))
return nil
}
return cluster
}