mirror of
https://github.com/minio/minio.git
synced 2024-12-24 22:25:54 -05:00
Remove unused config migration (#18277)
None of the migration is called. Remove dead code.
This commit is contained in:
parent
7926df0b80
commit
b46a717425
File diff suppressed because it is too large
Load Diff
@ -1,336 +0,0 @@
|
|||||||
// Copyright (c) 2015-2021 MinIO, Inc.
|
|
||||||
//
|
|
||||||
// This file is part of MinIO Object Storage stack
|
|
||||||
//
|
|
||||||
// This program is free software: you can redistribute it and/or modify
|
|
||||||
// it under the terms of the GNU Affero General Public License as published by
|
|
||||||
// the Free Software Foundation, either version 3 of the License, or
|
|
||||||
// (at your option) any later version.
|
|
||||||
//
|
|
||||||
// This program is distributed in the hope that it will be useful
|
|
||||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
// GNU Affero General Public License for more details.
|
|
||||||
//
|
|
||||||
// You should have received a copy of the GNU Affero General Public License
|
|
||||||
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
package cmd
|
|
||||||
|
|
||||||
import (
|
|
||||||
"context"
|
|
||||||
"fmt"
|
|
||||||
"os"
|
|
||||||
"testing"
|
|
||||||
)
|
|
||||||
|
|
||||||
// Test if config v1 is purged
|
|
||||||
func TestServerConfigMigrateV1(t *testing.T) {
|
|
||||||
ctx, cancel := context.WithCancel(context.Background())
|
|
||||||
defer cancel()
|
|
||||||
|
|
||||||
objLayer, fsDir, err := prepareFS(ctx)
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal(err)
|
|
||||||
}
|
|
||||||
defer os.RemoveAll(fsDir)
|
|
||||||
err = newTestConfig(globalMinioDefaultRegion, objLayer)
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("Init Test config failed")
|
|
||||||
}
|
|
||||||
rootPath := t.TempDir()
|
|
||||||
globalConfigDir = &ConfigDir{path: rootPath}
|
|
||||||
|
|
||||||
globalObjLayerMutex.Lock()
|
|
||||||
globalObjectAPI = objLayer
|
|
||||||
globalObjLayerMutex.Unlock()
|
|
||||||
|
|
||||||
// Create a V1 config json file and store it
|
|
||||||
configJSON := "{ \"version\":\"1\", \"accessKeyId\":\"abcde\", \"secretAccessKey\":\"abcdefgh\"}"
|
|
||||||
configPath := rootPath + "/fsUsers.json"
|
|
||||||
if err := os.WriteFile(configPath, []byte(configJSON), 0o644); err != nil {
|
|
||||||
t.Fatal("Unexpected error: ", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Fire a migrateConfig()
|
|
||||||
if err := migrateConfig(); err != nil {
|
|
||||||
t.Fatal("Unexpected error: ", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check if config v1 is removed from filesystem
|
|
||||||
if _, err := os.Stat(configPath); err == nil || !osIsNotExist(err) {
|
|
||||||
t.Fatal("Config V1 file is not purged")
|
|
||||||
}
|
|
||||||
|
|
||||||
// Initialize server config and check again if everything is fine
|
|
||||||
if err := loadConfig(objLayer, nil); err != nil {
|
|
||||||
t.Fatalf("Unable to initialize from updated config file %s", err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Test if all migrate code returns nil when config file does not
|
|
||||||
// exist
|
|
||||||
func TestServerConfigMigrateInexistentConfig(t *testing.T) {
|
|
||||||
globalConfigDir = &ConfigDir{path: t.TempDir()}
|
|
||||||
|
|
||||||
if err := migrateV2ToV3(); err != nil {
|
|
||||||
t.Fatal("migrate v2 to v3 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
if err := migrateV3ToV4(); err != nil {
|
|
||||||
t.Fatal("migrate v3 to v4 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
if err := migrateV4ToV5(); err != nil {
|
|
||||||
t.Fatal("migrate v4 to v5 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
if err := migrateV5ToV6(); err != nil {
|
|
||||||
t.Fatal("migrate v5 to v6 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
if err := migrateV6ToV7(); err != nil {
|
|
||||||
t.Fatal("migrate v6 to v7 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
if err := migrateV7ToV8(); err != nil {
|
|
||||||
t.Fatal("migrate v7 to v8 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
if err := migrateV8ToV9(); err != nil {
|
|
||||||
t.Fatal("migrate v8 to v9 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
if err := migrateV9ToV10(); err != nil {
|
|
||||||
t.Fatal("migrate v9 to v10 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
if err := migrateV10ToV11(); err != nil {
|
|
||||||
t.Fatal("migrate v10 to v11 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
if err := migrateV11ToV12(); err != nil {
|
|
||||||
t.Fatal("migrate v11 to v12 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
if err := migrateV12ToV13(); err != nil {
|
|
||||||
t.Fatal("migrate v12 to v13 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
if err := migrateV13ToV14(); err != nil {
|
|
||||||
t.Fatal("migrate v13 to v14 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
if err := migrateV14ToV15(); err != nil {
|
|
||||||
t.Fatal("migrate v14 to v15 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
if err := migrateV15ToV16(); err != nil {
|
|
||||||
t.Fatal("migrate v15 to v16 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
if err := migrateV16ToV17(); err != nil {
|
|
||||||
t.Fatal("migrate v16 to v17 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
if err := migrateV17ToV18(); err != nil {
|
|
||||||
t.Fatal("migrate v17 to v18 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
if err := migrateV18ToV19(); err != nil {
|
|
||||||
t.Fatal("migrate v18 to v19 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
if err := migrateV19ToV20(); err != nil {
|
|
||||||
t.Fatal("migrate v19 to v20 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
if err := migrateV20ToV21(); err != nil {
|
|
||||||
t.Fatal("migrate v20 to v21 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
if err := migrateV21ToV22(); err != nil {
|
|
||||||
t.Fatal("migrate v21 to v22 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
if err := migrateV22ToV23(); err != nil {
|
|
||||||
t.Fatal("migrate v22 to v23 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
if err := migrateV23ToV24(); err != nil {
|
|
||||||
t.Fatal("migrate v23 to v24 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
if err := migrateV24ToV25(); err != nil {
|
|
||||||
t.Fatal("migrate v24 to v25 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
if err := migrateV25ToV26(); err != nil {
|
|
||||||
t.Fatal("migrate v25 to v26 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
if err := migrateV26ToV27(); err != nil {
|
|
||||||
t.Fatal("migrate v26 to v27 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
if err := migrateV27ToV28(); err != nil {
|
|
||||||
t.Fatal("migrate v27 to v28 should succeed when no config file is found")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Test if a config migration from v2 to v33 is successfully done
|
|
||||||
func TestServerConfigMigrateV2toV33(t *testing.T) {
|
|
||||||
rootPath := t.TempDir()
|
|
||||||
ctx, cancel := context.WithCancel(context.Background())
|
|
||||||
defer cancel()
|
|
||||||
|
|
||||||
globalConfigDir = &ConfigDir{path: rootPath}
|
|
||||||
|
|
||||||
objLayer, fsDir, err := prepareFS(ctx)
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal(err)
|
|
||||||
}
|
|
||||||
defer os.RemoveAll(fsDir)
|
|
||||||
|
|
||||||
configPath := rootPath + SlashSeparator + minioConfigFile
|
|
||||||
|
|
||||||
// Create a corrupted config file
|
|
||||||
if err := os.WriteFile(configPath, []byte("{ \"version\":\"2\","), 0o644); err != nil {
|
|
||||||
t.Fatal("Unexpected error: ", err)
|
|
||||||
}
|
|
||||||
// Fire a migrateConfig()
|
|
||||||
if err := migrateConfig(); err == nil {
|
|
||||||
t.Fatal("migration should fail with corrupted config file")
|
|
||||||
}
|
|
||||||
|
|
||||||
accessKey := "accessfoo"
|
|
||||||
secretKey := "secretfoo"
|
|
||||||
|
|
||||||
// Create a V2 config json file and store it
|
|
||||||
configJSON := "{ \"version\":\"2\", \"credentials\": {\"accessKeyId\":\"" + accessKey + "\", \"secretAccessKey\":\"" + secretKey + "\", \"region\":\"us-east-1\"}, \"mongoLogger\":{\"addr\":\"127.0.0.1:3543\", \"db\":\"foodb\", \"collection\":\"foo\"}, \"syslogLogger\":{\"network\":\"127.0.0.1:543\", \"addr\":\"addr\"}, \"fileLogger\":{\"filename\":\"log.out\"}}"
|
|
||||||
if err := os.WriteFile(configPath, []byte(configJSON), 0o644); err != nil {
|
|
||||||
t.Fatal("Unexpected error: ", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Fire a migrateConfig()
|
|
||||||
if err := migrateConfig(); err != nil {
|
|
||||||
t.Fatal("Unexpected error: ", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if err := migrateConfigToMinioSys(objLayer); err != nil {
|
|
||||||
t.Fatal("Unexpected error: ", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
srvCfg, err := readConfigWithoutMigrate(context.Background(), objLayer)
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("Unexpected error: ", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if err = saveServerConfig(GlobalContext, objLayer, srvCfg); err != nil {
|
|
||||||
t.Fatal("Unexpected error: ", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Initialize server config and check again if everything is fine
|
|
||||||
if err := loadConfig(objLayer, nil); err != nil {
|
|
||||||
t.Fatalf("Unable to initialize from updated config file %s", err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Test if all migrate code returns error with corrupted config files
|
|
||||||
func TestServerConfigMigrateFaultyConfig(t *testing.T) {
|
|
||||||
rootPath := t.TempDir()
|
|
||||||
|
|
||||||
globalConfigDir = &ConfigDir{path: rootPath}
|
|
||||||
configPath := rootPath + SlashSeparator + minioConfigFile
|
|
||||||
|
|
||||||
// Create a corrupted config file
|
|
||||||
if err := os.WriteFile(configPath, []byte("{ \"version\":\"2\", \"test\":"), 0o644); err != nil {
|
|
||||||
t.Fatal("Unexpected error: ", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Test different migrate versions and be sure they are returning an error
|
|
||||||
if err := migrateV2ToV3(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV2ToV3() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
if err := migrateV3ToV4(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV3ToV4() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
if err := migrateV4ToV5(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV4ToV5() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
if err := migrateV5ToV6(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV5ToV6() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
if err := migrateV6ToV7(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV6ToV7() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
if err := migrateV7ToV8(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV7ToV8() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
if err := migrateV8ToV9(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV8ToV9() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
if err := migrateV9ToV10(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV9ToV10() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
if err := migrateV10ToV11(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV10ToV11() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
if err := migrateV11ToV12(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV11ToV12() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
if err := migrateV12ToV13(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV12ToV13() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
if err := migrateV13ToV14(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV13ToV14() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
if err := migrateV14ToV15(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV14ToV15() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
if err := migrateV15ToV16(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV15ToV16() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
if err := migrateV16ToV17(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV16ToV17() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
if err := migrateV17ToV18(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV17ToV18() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
if err := migrateV18ToV19(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV18ToV19() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
if err := migrateV19ToV20(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV19ToV20() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
if err := migrateV20ToV21(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV20ToV21() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
if err := migrateV21ToV22(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV21ToV22() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
if err := migrateV22ToV23(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV22ToV23() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
if err := migrateV23ToV24(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV23ToV24() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
if err := migrateV24ToV25(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV24ToV25() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
if err := migrateV25ToV26(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV25ToV26() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
if err := migrateV26ToV27(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV26ToV27() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
if err := migrateV27ToV28(); err == nil {
|
|
||||||
t.Fatal("migrateConfigV27ToV28() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Test if all migrate code returns error with corrupted config files
|
|
||||||
func TestServerConfigMigrateCorruptedConfig(t *testing.T) {
|
|
||||||
rootPath := t.TempDir()
|
|
||||||
|
|
||||||
globalConfigDir = &ConfigDir{path: rootPath}
|
|
||||||
configPath := rootPath + SlashSeparator + minioConfigFile
|
|
||||||
|
|
||||||
for i := 3; i <= 17; i++ {
|
|
||||||
// Create a corrupted config file
|
|
||||||
if err := os.WriteFile(configPath, []byte(fmt.Sprintf("{ \"version\":\"%d\", \"credential\": { \"accessKey\": 1 } }", i)),
|
|
||||||
0o644); err != nil {
|
|
||||||
t.Fatal("Unexpected error: ", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Test different migrate versions and be sure they are returning an error
|
|
||||||
if err := migrateConfig(); err == nil {
|
|
||||||
t.Fatal("migrateConfig() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Create a corrupted config file for version '2'.
|
|
||||||
if err := os.WriteFile(configPath, []byte("{ \"version\":\"2\", \"credentials\": { \"accessKeyId\": 1 } }"), 0o644); err != nil {
|
|
||||||
t.Fatal("Unexpected error: ", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Test different migrate versions and be sure they are returning an error
|
|
||||||
if err := migrateConfig(); err == nil {
|
|
||||||
t.Fatal("migrateConfig() should fail with a corrupted json")
|
|
||||||
}
|
|
||||||
}
|
|
@ -18,8 +18,6 @@
|
|||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"sync"
|
|
||||||
|
|
||||||
"github.com/minio/minio/internal/auth"
|
"github.com/minio/minio/internal/auth"
|
||||||
"github.com/minio/minio/internal/config"
|
"github.com/minio/minio/internal/config"
|
||||||
"github.com/minio/minio/internal/config/compress"
|
"github.com/minio/minio/internal/config/compress"
|
||||||
@ -28,407 +26,10 @@ import (
|
|||||||
"github.com/minio/minio/internal/config/notify"
|
"github.com/minio/minio/internal/config/notify"
|
||||||
"github.com/minio/minio/internal/config/policy/opa"
|
"github.com/minio/minio/internal/config/policy/opa"
|
||||||
"github.com/minio/minio/internal/config/storageclass"
|
"github.com/minio/minio/internal/config/storageclass"
|
||||||
"github.com/minio/minio/internal/event/target"
|
|
||||||
"github.com/minio/minio/internal/logger"
|
"github.com/minio/minio/internal/logger"
|
||||||
"github.com/minio/pkg/v2/quick"
|
"github.com/minio/pkg/v2/quick"
|
||||||
)
|
)
|
||||||
|
|
||||||
type configV1 struct {
|
|
||||||
Version string `json:"version"`
|
|
||||||
AccessKey string `json:"accessKeyId"`
|
|
||||||
SecretKey string `json:"secretAccessKey"`
|
|
||||||
}
|
|
||||||
|
|
||||||
type configV2 struct {
|
|
||||||
Version string `json:"version"`
|
|
||||||
Credentials struct {
|
|
||||||
AccessKey string `json:"accessKeyId"`
|
|
||||||
SecretKey string `json:"secretAccessKey"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
} `json:"credentials"`
|
|
||||||
MongoLogger struct {
|
|
||||||
Addr string `json:"addr"`
|
|
||||||
DB string `json:"db"`
|
|
||||||
Collection string `json:"collection"`
|
|
||||||
} `json:"mongoLogger"`
|
|
||||||
SyslogLogger struct {
|
|
||||||
Network string `json:"network"`
|
|
||||||
Addr string `json:"addr"`
|
|
||||||
} `json:"syslogLogger"`
|
|
||||||
FileLogger struct {
|
|
||||||
Filename string `json:"filename"`
|
|
||||||
} `json:"fileLogger"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// backendV3 type.
|
|
||||||
type backendV3 struct {
|
|
||||||
Type string `json:"type"`
|
|
||||||
Disk string `json:"disk,omitempty"`
|
|
||||||
Disks []string `json:"disks,omitempty"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// syslogLogger v3
|
|
||||||
type syslogLoggerV3 struct {
|
|
||||||
Enable bool `json:"enable"`
|
|
||||||
Addr string `json:"address"`
|
|
||||||
Level string `json:"level"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// loggerV3 type.
|
|
||||||
type loggerV3 struct {
|
|
||||||
Console struct {
|
|
||||||
Enable bool `json:"enable"`
|
|
||||||
Level string `json:"level"`
|
|
||||||
}
|
|
||||||
File struct {
|
|
||||||
Enable bool `json:"enable"`
|
|
||||||
Filename string `json:"fileName"`
|
|
||||||
Level string `json:"level"`
|
|
||||||
}
|
|
||||||
Syslog struct {
|
|
||||||
Enable bool `json:"enable"`
|
|
||||||
Addr string `json:"address"`
|
|
||||||
Level string `json:"level"`
|
|
||||||
} `json:"syslog"`
|
|
||||||
// Add new loggers here.
|
|
||||||
}
|
|
||||||
|
|
||||||
// configV3 server configuration version '3'.
|
|
||||||
type configV3 struct {
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// Backend configuration.
|
|
||||||
Backend backendV3 `json:"backend"`
|
|
||||||
|
|
||||||
// http Server configuration.
|
|
||||||
Addr string `json:"address"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
|
|
||||||
// Additional error logging configuration.
|
|
||||||
Logger loggerV3 `json:"logger"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// logger type representing version '4' logger config.
|
|
||||||
type loggerV4 struct {
|
|
||||||
Console struct {
|
|
||||||
Enable bool `json:"enable"`
|
|
||||||
Level string `json:"level"`
|
|
||||||
} `json:"console"`
|
|
||||||
File struct {
|
|
||||||
Enable bool `json:"enable"`
|
|
||||||
Filename string `json:"fileName"`
|
|
||||||
Level string `json:"level"`
|
|
||||||
} `json:"file"`
|
|
||||||
Syslog struct {
|
|
||||||
Enable bool `json:"enable"`
|
|
||||||
Addr string `json:"address"`
|
|
||||||
Level string `json:"level"`
|
|
||||||
} `json:"syslog"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// configV4 server configuration version '4'.
|
|
||||||
type configV4 struct {
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
|
|
||||||
// Additional error logging configuration.
|
|
||||||
Logger loggerV4 `json:"logger"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// logger type representing version '5' logger config.
|
|
||||||
type loggerV5 struct {
|
|
||||||
Console struct {
|
|
||||||
Enable bool `json:"enable"`
|
|
||||||
Level string `json:"level"`
|
|
||||||
} `json:"console"`
|
|
||||||
File struct {
|
|
||||||
Enable bool `json:"enable"`
|
|
||||||
Filename string `json:"fileName"`
|
|
||||||
Level string `json:"level"`
|
|
||||||
} `json:"file"`
|
|
||||||
Syslog struct {
|
|
||||||
Enable bool `json:"enable"`
|
|
||||||
Addr string `json:"address"`
|
|
||||||
Level string `json:"level"`
|
|
||||||
} `json:"syslog"`
|
|
||||||
AMQP struct {
|
|
||||||
Enable bool `json:"enable"`
|
|
||||||
Level string `json:"level"`
|
|
||||||
URL string `json:"url"`
|
|
||||||
Exchange string `json:"exchange"`
|
|
||||||
RoutingKey string `json:"routingKey"`
|
|
||||||
ExchangeType string `json:"exchangeType"`
|
|
||||||
Mandatory bool `json:"mandatory"`
|
|
||||||
Immediate bool `json:"immediate"`
|
|
||||||
Durable bool `json:"durable"`
|
|
||||||
Internal bool `json:"internal"`
|
|
||||||
NoWait bool `json:"noWait"`
|
|
||||||
AutoDeleted bool `json:"autoDeleted"`
|
|
||||||
} `json:"amqp"`
|
|
||||||
ElasticSearch struct {
|
|
||||||
Enable bool `json:"enable"`
|
|
||||||
Level string `json:"level"`
|
|
||||||
URL string `json:"url"`
|
|
||||||
Index string `json:"index"`
|
|
||||||
} `json:"elasticsearch"`
|
|
||||||
Redis struct {
|
|
||||||
Enable bool `json:"enable"`
|
|
||||||
Level string `json:"level"`
|
|
||||||
Addr string `json:"address"`
|
|
||||||
Password string `json:"password"`
|
|
||||||
Key string `json:"key"`
|
|
||||||
} `json:"redis"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// configV5 server configuration version '5'.
|
|
||||||
type configV5 struct {
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
|
|
||||||
// Additional error logging configuration.
|
|
||||||
Logger loggerV5 `json:"logger"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// consoleLogger - default logger if not other logging is enabled.
|
|
||||||
type consoleLoggerV1 struct {
|
|
||||||
Enable bool `json:"enable"`
|
|
||||||
Level string `json:"level"`
|
|
||||||
}
|
|
||||||
|
|
||||||
type fileLoggerV1 struct {
|
|
||||||
Enable bool `json:"enable"`
|
|
||||||
Filename string `json:"fileName"`
|
|
||||||
Level string `json:"level"`
|
|
||||||
}
|
|
||||||
|
|
||||||
type loggerV6 struct {
|
|
||||||
Console consoleLoggerV1 `json:"console"`
|
|
||||||
File fileLoggerV1 `json:"file"`
|
|
||||||
Syslog syslogLoggerV3 `json:"syslog"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// configV6 server configuration version '6'.
|
|
||||||
type configV6 struct {
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
|
|
||||||
// Additional error logging configuration.
|
|
||||||
Logger loggerV6 `json:"logger"`
|
|
||||||
|
|
||||||
// Notification queue configuration.
|
|
||||||
Notify notifierV1 `json:"notify"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// Notifier represents collection of supported notification queues in version
|
|
||||||
// 1 without NATS streaming.
|
|
||||||
type notifierV1 struct {
|
|
||||||
AMQP map[string]target.AMQPArgs `json:"amqp"`
|
|
||||||
NATS map[string]natsNotifyV1 `json:"nats"`
|
|
||||||
ElasticSearch map[string]target.ElasticsearchArgs `json:"elasticsearch"`
|
|
||||||
Redis map[string]target.RedisArgs `json:"redis"`
|
|
||||||
PostgreSQL map[string]target.PostgreSQLArgs `json:"postgresql"`
|
|
||||||
Kafka map[string]target.KafkaArgs `json:"kafka"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// Notifier represents collection of supported notification queues in version 2
|
|
||||||
// with NATS streaming but without webhook.
|
|
||||||
type notifierV2 struct {
|
|
||||||
AMQP map[string]target.AMQPArgs `json:"amqp"`
|
|
||||||
NATS map[string]target.NATSArgs `json:"nats"`
|
|
||||||
ElasticSearch map[string]target.ElasticsearchArgs `json:"elasticsearch"`
|
|
||||||
Redis map[string]target.RedisArgs `json:"redis"`
|
|
||||||
PostgreSQL map[string]target.PostgreSQLArgs `json:"postgresql"`
|
|
||||||
Kafka map[string]target.KafkaArgs `json:"kafka"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// configV7 server configuration version '7'.
|
|
||||||
type serverConfigV7 struct {
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
|
|
||||||
// Additional error logging configuration.
|
|
||||||
Logger loggerV6 `json:"logger"`
|
|
||||||
|
|
||||||
// Notification queue configuration.
|
|
||||||
Notify notifierV1 `json:"notify"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// serverConfigV8 server configuration version '8'. Adds NATS notify.Config
|
|
||||||
// configuration.
|
|
||||||
type serverConfigV8 struct {
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
|
|
||||||
// Additional error logging configuration.
|
|
||||||
Logger loggerV6 `json:"logger"`
|
|
||||||
|
|
||||||
// Notification queue configuration.
|
|
||||||
Notify notifierV1 `json:"notify"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// serverConfigV9 server configuration version '9'. Adds PostgreSQL
|
|
||||||
// notify.Config configuration.
|
|
||||||
type serverConfigV9 struct {
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
|
|
||||||
// Additional error logging configuration.
|
|
||||||
Logger loggerV6 `json:"logger"`
|
|
||||||
|
|
||||||
// Notification queue configuration.
|
|
||||||
Notify notifierV1 `json:"notify"`
|
|
||||||
}
|
|
||||||
|
|
||||||
type loggerV7 struct {
|
|
||||||
sync.RWMutex
|
|
||||||
Console consoleLoggerV1 `json:"console"`
|
|
||||||
File fileLoggerV1 `json:"file"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// serverConfigV10 server configuration version '10' which is like
|
|
||||||
// version '9' except it drops support of syslog config, and makes the
|
|
||||||
// RWMutex global (so it does not exist in this struct).
|
|
||||||
type serverConfigV10 struct {
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
|
|
||||||
// Additional error logging configuration.
|
|
||||||
Logger loggerV7 `json:"logger"`
|
|
||||||
|
|
||||||
// Notification queue configuration.
|
|
||||||
Notify notifierV1 `json:"notify"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// natsNotifyV1 - structure was valid until config V 11
|
|
||||||
type natsNotifyV1 struct {
|
|
||||||
Enable bool `json:"enable"`
|
|
||||||
Address string `json:"address"`
|
|
||||||
Subject string `json:"subject"`
|
|
||||||
Username string `json:"username"`
|
|
||||||
Password string `json:"password"`
|
|
||||||
Token string `json:"token"`
|
|
||||||
Secure bool `json:"secure"`
|
|
||||||
PingInterval int64 `json:"pingInterval"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// serverConfigV11 server configuration version '11' which is like
|
|
||||||
// version '10' except it adds support for Kafka notifications.
|
|
||||||
type serverConfigV11 struct {
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
|
|
||||||
// Additional error logging configuration.
|
|
||||||
Logger loggerV7 `json:"logger"`
|
|
||||||
|
|
||||||
// Notification queue configuration.
|
|
||||||
Notify notifierV1 `json:"notify"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// serverConfigV12 server configuration version '12' which is like
|
|
||||||
// version '11' except it adds support for NATS streaming notifications.
|
|
||||||
type serverConfigV12 struct {
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
|
|
||||||
// Additional error logging configuration.
|
|
||||||
Logger loggerV7 `json:"logger"`
|
|
||||||
|
|
||||||
// Notification queue configuration.
|
|
||||||
Notify notifierV2 `json:"notify"`
|
|
||||||
}
|
|
||||||
|
|
||||||
type notifierV3 struct {
|
|
||||||
AMQP map[string]target.AMQPArgs `json:"amqp"`
|
|
||||||
Elasticsearch map[string]target.ElasticsearchArgs `json:"elasticsearch"`
|
|
||||||
Kafka map[string]target.KafkaArgs `json:"kafka"`
|
|
||||||
MQTT map[string]target.MQTTArgs `json:"mqtt"`
|
|
||||||
MySQL map[string]target.MySQLArgs `json:"mysql"`
|
|
||||||
NATS map[string]target.NATSArgs `json:"nats"`
|
|
||||||
PostgreSQL map[string]target.PostgreSQLArgs `json:"postgresql"`
|
|
||||||
Redis map[string]target.RedisArgs `json:"redis"`
|
|
||||||
Webhook map[string]target.WebhookArgs `json:"webhook"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// serverConfigV13 server configuration version '13' which is like
|
|
||||||
// version '12' except it adds support for webhook notification.
|
|
||||||
type serverConfigV13 struct {
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
|
|
||||||
// Additional error logging configuration.
|
|
||||||
Logger *loggerV7 `json:"logger"`
|
|
||||||
|
|
||||||
// Notification queue configuration.
|
|
||||||
Notify *notifierV3 `json:"notify"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// serverConfigV14 server configuration version '14' which is like
|
|
||||||
// version '13' except it adds support of browser param.
|
|
||||||
type serverConfigV14 struct {
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
Browser config.BoolFlag `json:"browser"`
|
|
||||||
|
|
||||||
// Additional error logging configuration.
|
|
||||||
Logger *loggerV7 `json:"logger"`
|
|
||||||
|
|
||||||
// Notification queue configuration.
|
|
||||||
Notify *notifierV3 `json:"notify"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// serverConfigV15 server configuration version '15' which is like
|
|
||||||
// version '14' except it adds mysql support
|
|
||||||
type serverConfigV15 struct {
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
Browser config.BoolFlag `json:"browser"`
|
|
||||||
|
|
||||||
// Additional error logging configuration.
|
|
||||||
Logger *loggerV7 `json:"logger"`
|
|
||||||
|
|
||||||
// Notification queue configuration.
|
|
||||||
Notify *notifierV3 `json:"notify"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// FileLogger is introduced to workaround the dependency about logrus
|
// FileLogger is introduced to workaround the dependency about logrus
|
||||||
type FileLogger struct {
|
type FileLogger struct {
|
||||||
Enable bool `json:"enable"`
|
Enable bool `json:"enable"`
|
||||||
@ -440,264 +41,6 @@ type ConsoleLogger struct {
|
|||||||
Enable bool `json:"enable"`
|
Enable bool `json:"enable"`
|
||||||
}
|
}
|
||||||
|
|
||||||
// Loggers struct is defined with FileLogger and ConsoleLogger
|
|
||||||
// although they are removed from logging logic. They are
|
|
||||||
// kept here just to workaround the dependency migration
|
|
||||||
// code/logic has on them.
|
|
||||||
type loggers struct {
|
|
||||||
sync.RWMutex
|
|
||||||
Console ConsoleLogger `json:"console"`
|
|
||||||
File FileLogger `json:"file"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// serverConfigV16 server configuration version '16' which is like
|
|
||||||
// version '15' except it makes a change to logging configuration.
|
|
||||||
type serverConfigV16 struct {
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
Browser config.BoolFlag `json:"browser"`
|
|
||||||
|
|
||||||
// Additional error logging configuration.
|
|
||||||
Logger *loggers `json:"logger"`
|
|
||||||
|
|
||||||
// Notification queue configuration.
|
|
||||||
Notify *notifierV3 `json:"notify"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// serverConfigV17 server configuration version '17' which is like
|
|
||||||
// version '16' except it adds support for "format" parameter in
|
|
||||||
// database event notification targets: PostgreSQL, MySQL, Redis and
|
|
||||||
// Elasticsearch.
|
|
||||||
type serverConfigV17 struct {
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
Browser config.BoolFlag `json:"browser"`
|
|
||||||
|
|
||||||
// Additional error logging configuration.
|
|
||||||
Logger *loggers `json:"logger"`
|
|
||||||
|
|
||||||
// Notification queue configuration.
|
|
||||||
Notify *notifierV3 `json:"notify"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// serverConfigV18 server configuration version '18' which is like
|
|
||||||
// version '17' except it adds support for "deliveryMode" parameter in
|
|
||||||
// the AMQP notification target.
|
|
||||||
type serverConfigV18 struct {
|
|
||||||
sync.RWMutex
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
Browser config.BoolFlag `json:"browser"`
|
|
||||||
|
|
||||||
// Additional error logging configuration.
|
|
||||||
Logger *loggers `json:"logger"`
|
|
||||||
|
|
||||||
// Notification queue configuration.
|
|
||||||
Notify *notifierV3 `json:"notify"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// serverConfigV19 server configuration version '19' which is like
|
|
||||||
// version '18' except it adds support for MQTT notifications.
|
|
||||||
type serverConfigV19 struct {
|
|
||||||
sync.RWMutex
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
Browser config.BoolFlag `json:"browser"`
|
|
||||||
|
|
||||||
// Additional error logging configuration.
|
|
||||||
Logger *loggers `json:"logger"`
|
|
||||||
|
|
||||||
// Notification queue configuration.
|
|
||||||
Notify *notifierV3 `json:"notify"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// serverConfigV20 server configuration version '20' which is like
|
|
||||||
// version '19' except it adds support for VirtualHostDomain
|
|
||||||
type serverConfigV20 struct {
|
|
||||||
sync.RWMutex
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
Browser config.BoolFlag `json:"browser"`
|
|
||||||
Domain string `json:"domain"`
|
|
||||||
|
|
||||||
// Additional error logging configuration.
|
|
||||||
Logger *loggers `json:"logger"`
|
|
||||||
|
|
||||||
// Notification queue configuration.
|
|
||||||
Notify *notifierV3 `json:"notify"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// serverConfigV21 is just like version '20' without logger field
|
|
||||||
type serverConfigV21 struct {
|
|
||||||
sync.RWMutex
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
Browser config.BoolFlag `json:"browser"`
|
|
||||||
Domain string `json:"domain"`
|
|
||||||
|
|
||||||
// Notification queue configuration.
|
|
||||||
Notify *notifierV3 `json:"notify"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// serverConfigV22 is just like version '21' with added support
|
|
||||||
// for StorageClass.
|
|
||||||
type serverConfigV22 struct {
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
Browser config.BoolFlag `json:"browser"`
|
|
||||||
Domain string `json:"domain"`
|
|
||||||
|
|
||||||
// Storage class configuration
|
|
||||||
StorageClass storageclass.Config `json:"storageclass"`
|
|
||||||
|
|
||||||
// Notification queue configuration.
|
|
||||||
Notify notifierV3 `json:"notify"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// serverConfigV23 is just like version '22' with addition of cache field.
|
|
||||||
type serverConfigV23 struct {
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
Browser config.BoolFlag `json:"browser"`
|
|
||||||
Domain string `json:"domain"`
|
|
||||||
|
|
||||||
// Storage class configuration
|
|
||||||
StorageClass storageclass.Config `json:"storageclass"`
|
|
||||||
|
|
||||||
// Notification queue configuration.
|
|
||||||
Notify notifierV3 `json:"notify"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// serverConfigV24 is just like version '23', we had to revert
|
|
||||||
// the changes which were made in 6fb06045028b7a57c37c60a612c8e50735279ab4
|
|
||||||
type serverConfigV24 struct {
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
Browser config.BoolFlag `json:"browser"`
|
|
||||||
Domain string `json:"domain"`
|
|
||||||
|
|
||||||
// Storage class configuration
|
|
||||||
StorageClass storageclass.Config `json:"storageclass"`
|
|
||||||
|
|
||||||
// Notification queue configuration.
|
|
||||||
Notify notifierV3 `json:"notify"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// serverConfigV25 is just like version '24', stores additionally
|
|
||||||
// worm variable.
|
|
||||||
type serverConfigV25 struct {
|
|
||||||
quick.Config `json:"-"` // ignore interfaces
|
|
||||||
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
Browser config.BoolFlag `json:"browser"`
|
|
||||||
Worm config.BoolFlag `json:"worm"`
|
|
||||||
Domain string `json:"domain"`
|
|
||||||
|
|
||||||
// Storage class configuration
|
|
||||||
StorageClass storageclass.Config `json:"storageclass"`
|
|
||||||
|
|
||||||
// Notification queue configuration.
|
|
||||||
Notify notifierV3 `json:"notify"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// serverConfigV26 is just like version '25', stores additionally
|
|
||||||
// cache max use value in 'cache.Config'.
|
|
||||||
type serverConfigV26 struct {
|
|
||||||
quick.Config `json:"-"` // ignore interfaces
|
|
||||||
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
Browser config.BoolFlag `json:"browser"`
|
|
||||||
Worm config.BoolFlag `json:"worm"`
|
|
||||||
Domain string `json:"domain"`
|
|
||||||
|
|
||||||
// Storage class configuration
|
|
||||||
StorageClass storageclass.Config `json:"storageclass"`
|
|
||||||
|
|
||||||
// Notification queue configuration.
|
|
||||||
Notify notifierV3 `json:"notify"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// serverConfigV27 is just like version '26', stores additionally
|
|
||||||
// the logger field
|
|
||||||
type serverConfigV27 struct {
|
|
||||||
quick.Config `json:"-"` // ignore interfaces
|
|
||||||
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
Browser config.BoolFlag `json:"browser"`
|
|
||||||
Worm config.BoolFlag `json:"worm"`
|
|
||||||
Domain string `json:"domain"`
|
|
||||||
|
|
||||||
// Storage class configuration
|
|
||||||
StorageClass storageclass.Config `json:"storageclass"`
|
|
||||||
|
|
||||||
// Notification queue configuration.
|
|
||||||
Notify notifierV3 `json:"notify"`
|
|
||||||
|
|
||||||
// Logger configuration
|
|
||||||
Logger logger.Config `json:"logger"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// serverConfigV28 is just like version '27', additionally
|
|
||||||
// storing KMS config
|
|
||||||
type serverConfigV28 struct {
|
|
||||||
quick.Config `json:"-"` // ignore interfaces
|
|
||||||
|
|
||||||
Version string `json:"version"`
|
|
||||||
|
|
||||||
// S3 API configuration.
|
|
||||||
Credential auth.Credentials `json:"credential"`
|
|
||||||
Region string `json:"region"`
|
|
||||||
Worm config.BoolFlag `json:"worm"`
|
|
||||||
|
|
||||||
// Storage class configuration
|
|
||||||
StorageClass storageclass.Config `json:"storageclass"`
|
|
||||||
|
|
||||||
// Notification queue configuration.
|
|
||||||
Notify notifierV3 `json:"notify"`
|
|
||||||
|
|
||||||
// Logger configuration
|
|
||||||
Logger logger.Config `json:"logger"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// serverConfigV33 is just like version '32', removes clientID from NATS and MQTT, and adds queueDir, queueLimit in all notification targets.
|
// serverConfigV33 is just like version '32', removes clientID from NATS and MQTT, and adds queueDir, queueLimit in all notification targets.
|
||||||
type serverConfigV33 struct {
|
type serverConfigV33 struct {
|
||||||
quick.Config `json:"-"` // ignore interfaces
|
quick.Config `json:"-"` // ignore interfaces
|
||||||
|
Loading…
Reference in New Issue
Block a user