mirror of
https://github.com/mattermost/focalboard.git
synced 2024-12-24 13:43:12 +02:00
f1b8d88d6b
* Improving mattermost auth implementation * Making mattermost-auth based on shared database access * Reverting unneeded changes in the config.json file * Fixing tiny problems * Removing the need of using the mattermost session token * Fixing some bugs and allowing to not-bind the server to any port * Small fix to correctly get the templates * Adding the mattermost-plugin code inside focalboard repo * Adding a not working code part of the cluster websocket communication * Updating the mattermost version * Adding the cluster messages for the websockets * Updating to the new node version * Making it compatible with S3 * Addressing some tiny problems * Fixing server tests * Adds support for MySQL migrations and initialization Co-authored-by: Miguel de la Cruz <miguel@mcrx.me>
101 lines
4.0 KiB
Go
101 lines
4.0 KiB
Go
package config
|
|
|
|
import (
|
|
"log"
|
|
|
|
"github.com/spf13/viper"
|
|
)
|
|
|
|
const (
|
|
DefaultServerRoot = "http://localhost:8000"
|
|
DefaultPort = 8000
|
|
)
|
|
|
|
type AmazonS3Config struct {
|
|
AccessKeyId string
|
|
SecretAccessKey string
|
|
Bucket string
|
|
PathPrefix string
|
|
Region string
|
|
Endpoint string
|
|
SSL bool
|
|
SignV2 bool
|
|
SSE bool
|
|
Trace bool
|
|
}
|
|
|
|
// Configuration is the app configuration stored in a json file.
|
|
type Configuration struct {
|
|
ServerRoot string `json:"serverRoot" mapstructure:"serverRoot"`
|
|
Port int `json:"port" mapstructure:"port"`
|
|
DBType string `json:"dbtype" mapstructure:"dbtype"`
|
|
DBConfigString string `json:"dbconfig" mapstructure:"dbconfig"`
|
|
DBTablePrefix string `json:"dbtableprefix" mapstructure:"dbtableprefix"`
|
|
UseSSL bool `json:"useSSL" mapstructure:"useSSL"`
|
|
SecureCookie bool `json:"secureCookie" mapstructure:"secureCookie"`
|
|
WebPath string `json:"webpath" mapstructure:"webpath"`
|
|
FilesDriver string `json:"filesdriver" mapstructure:"filesdriver"`
|
|
FilesS3Config AmazonS3Config `json:"filess3config" mapstructure:"filess3config"`
|
|
FilesPath string `json:"filespath" mapstructure:"filespath"`
|
|
Telemetry bool `json:"telemetry" mapstructure:"telemetry"`
|
|
PrometheusAddress string `json:"prometheus_address" mapstructure:"prometheus_address"`
|
|
WebhookUpdate []string `json:"webhook_update" mapstructure:"webhook_update"`
|
|
Secret string `json:"secret" mapstructure:"secret"`
|
|
SessionExpireTime int64 `json:"session_expire_time" mapstructure:"session_expire_time"`
|
|
SessionRefreshTime int64 `json:"session_refresh_time" mapstructure:"session_refresh_time"`
|
|
LocalOnly bool `json:"localonly" mapstructure:"localonly"`
|
|
EnableLocalMode bool `json:"enableLocalMode" mapstructure:"enableLocalMode"`
|
|
LocalModeSocketLocation string `json:"localModeSocketLocation" mapstructure:"localModeSocketLocation"`
|
|
|
|
AuthMode string `json:"authMode" mapstructure:"authMode"`
|
|
}
|
|
|
|
// ReadConfigFile read the configuration from the filesystem.
|
|
func ReadConfigFile() (*Configuration, error) {
|
|
viper.SetConfigName("config") // name of config file (without extension)
|
|
viper.SetConfigType("json") // REQUIRED if the config file does not have the extension in the name
|
|
viper.AddConfigPath(".") // optionally look for config in the working directory
|
|
viper.SetEnvPrefix("focalboard")
|
|
viper.AutomaticEnv() // read config values from env like FOCALBOARD_SERVERROOT=...
|
|
viper.SetDefault("ServerRoot", DefaultServerRoot)
|
|
viper.SetDefault("Port", DefaultPort)
|
|
viper.SetDefault("DBType", "sqlite3")
|
|
viper.SetDefault("DBConfigString", "./focalboard.db")
|
|
viper.SetDefault("DBTablePrefix", "")
|
|
viper.SetDefault("SecureCookie", false)
|
|
viper.SetDefault("WebPath", "./pack")
|
|
viper.SetDefault("FilesPath", "./files")
|
|
viper.SetDefault("FilesDriver", "local")
|
|
viper.SetDefault("Telemetry", true)
|
|
viper.SetDefault("WebhookUpdate", nil)
|
|
viper.SetDefault("SessionExpireTime", 60*60*24*30) // 30 days session lifetime
|
|
viper.SetDefault("SessionRefreshTime", 60*60*5) // 5 minutes session refresh
|
|
viper.SetDefault("LocalOnly", false)
|
|
viper.SetDefault("EnableLocalMode", false)
|
|
viper.SetDefault("LocalModeSocketLocation", "/var/tmp/focalboard_local.socket")
|
|
|
|
viper.SetDefault("AuthMode", "native")
|
|
|
|
err := viper.ReadInConfig() // Find and read the config file
|
|
if err != nil { // Handle errors reading the config file
|
|
return nil, err
|
|
}
|
|
|
|
configuration := Configuration{}
|
|
|
|
err = viper.Unmarshal(&configuration)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
log.Println("readConfigFile")
|
|
log.Printf("%+v", removeSecurityData(configuration))
|
|
|
|
return &configuration, nil
|
|
}
|
|
|
|
func removeSecurityData(config Configuration) Configuration {
|
|
clean := config
|
|
return clean
|
|
}
|