config/main: Re-write config files - add to new config v3
- New config format.
```
{
"version": "3",
"address": ":9000",
"backend": {
"type": "fs",
"disk": "/path"
},
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
},
"console": {
"enable": true,
"level": "fatal"
}
}
}
```
New command lines in lieu of supporting XL.
Minio initialize filesystem backend.
~~~
$ minio init fs <path>
~~~
Minio initialize XL backend.
~~~
$ minio init xl <url1>...<url16>
~~~
For 'fs' backend it starts the server.
~~~
$ minio server
~~~
For 'xl' backend it waits for servers to join.
~~~
$ minio server
... [PROGRESS BAR] of servers connecting
~~~
Now on other servers execute 'join' and they connect.
~~~
....
minio join <url1> -- from <url2> && minio server
minio join <url1> -- from <url3> && minio server
...
...
minio join <url1> -- from <url16> && minio server
~~~
2016-02-12 18:27:10 -05:00
|
|
|
|
/*
|
2017-01-18 15:24:34 -05:00
|
|
|
|
* Minio Cloud Storage, (C) 2016, 2017 Minio, Inc.
|
config/main: Re-write config files - add to new config v3
- New config format.
```
{
"version": "3",
"address": ":9000",
"backend": {
"type": "fs",
"disk": "/path"
},
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
},
"console": {
"enable": true,
"level": "fatal"
}
}
}
```
New command lines in lieu of supporting XL.
Minio initialize filesystem backend.
~~~
$ minio init fs <path>
~~~
Minio initialize XL backend.
~~~
$ minio init xl <url1>...<url16>
~~~
For 'fs' backend it starts the server.
~~~
$ minio server
~~~
For 'xl' backend it waits for servers to join.
~~~
$ minio server
... [PROGRESS BAR] of servers connecting
~~~
Now on other servers execute 'join' and they connect.
~~~
....
minio join <url1> -- from <url2> && minio server
minio join <url1> -- from <url3> && minio server
...
...
minio join <url1> -- from <url16> && minio server
~~~
2016-02-12 18:27:10 -05:00
|
|
|
|
*
|
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
|
*
|
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
*
|
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
|
* limitations under the License.
|
|
|
|
|
*/
|
|
|
|
|
|
2016-08-18 19:23:42 -04:00
|
|
|
|
package cmd
|
config/main: Re-write config files - add to new config v3
- New config format.
```
{
"version": "3",
"address": ":9000",
"backend": {
"type": "fs",
"disk": "/path"
},
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
},
"console": {
"enable": true,
"level": "fatal"
}
}
}
```
New command lines in lieu of supporting XL.
Minio initialize filesystem backend.
~~~
$ minio init fs <path>
~~~
Minio initialize XL backend.
~~~
$ minio init xl <url1>...<url16>
~~~
For 'fs' backend it starts the server.
~~~
$ minio server
~~~
For 'xl' backend it waits for servers to join.
~~~
$ minio server
... [PROGRESS BAR] of servers connecting
~~~
Now on other servers execute 'join' and they connect.
~~~
....
minio join <url1> -- from <url2> && minio server
minio join <url1> -- from <url3> && minio server
...
...
minio join <url1> -- from <url16> && minio server
~~~
2016-02-12 18:27:10 -05:00
|
|
|
|
|
|
|
|
|
import (
|
2016-09-21 12:44:57 -04:00
|
|
|
|
"fmt"
|
config/main: Re-write config files - add to new config v3
- New config format.
```
{
"version": "3",
"address": ":9000",
"backend": {
"type": "fs",
"disk": "/path"
},
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
},
"console": {
"enable": true,
"level": "fatal"
}
}
}
```
New command lines in lieu of supporting XL.
Minio initialize filesystem backend.
~~~
$ minio init fs <path>
~~~
Minio initialize XL backend.
~~~
$ minio init xl <url1>...<url16>
~~~
For 'fs' backend it starts the server.
~~~
$ minio server
~~~
For 'xl' backend it waits for servers to join.
~~~
$ minio server
... [PROGRESS BAR] of servers connecting
~~~
Now on other servers execute 'join' and they connect.
~~~
....
minio join <url1> -- from <url2> && minio server
minio join <url1> -- from <url3> && minio server
...
...
minio join <url1> -- from <url16> && minio server
~~~
2016-02-12 18:27:10 -05:00
|
|
|
|
"os"
|
|
|
|
|
"path/filepath"
|
|
|
|
|
|
|
|
|
|
"github.com/minio/mc/pkg/console"
|
config: Migrate to the new version. Remove backend details.
Migrate to new config format v4.
```
{
"version": "4",
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"console": {
"enable": true,
"level": "fatal"
},
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
}
}
}
```
This patch also updates [minio cli spec](./minio.md)
2016-04-01 22:19:44 -04:00
|
|
|
|
"github.com/minio/minio/pkg/quick"
|
config/main: Re-write config files - add to new config v3
- New config format.
```
{
"version": "3",
"address": ":9000",
"backend": {
"type": "fs",
"disk": "/path"
},
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
},
"console": {
"enable": true,
"level": "fatal"
}
}
}
```
New command lines in lieu of supporting XL.
Minio initialize filesystem backend.
~~~
$ minio init fs <path>
~~~
Minio initialize XL backend.
~~~
$ minio init xl <url1>...<url16>
~~~
For 'fs' backend it starts the server.
~~~
$ minio server
~~~
For 'xl' backend it waits for servers to join.
~~~
$ minio server
... [PROGRESS BAR] of servers connecting
~~~
Now on other servers execute 'join' and they connect.
~~~
....
minio join <url1> -- from <url2> && minio server
minio join <url1> -- from <url3> && minio server
...
...
minio join <url1> -- from <url16> && minio server
~~~
2016-02-12 18:27:10 -05:00
|
|
|
|
)
|
|
|
|
|
|
2016-09-21 12:44:57 -04:00
|
|
|
|
func migrateConfig() error {
|
config/main: Re-write config files - add to new config v3
- New config format.
```
{
"version": "3",
"address": ":9000",
"backend": {
"type": "fs",
"disk": "/path"
},
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
},
"console": {
"enable": true,
"level": "fatal"
}
}
}
```
New command lines in lieu of supporting XL.
Minio initialize filesystem backend.
~~~
$ minio init fs <path>
~~~
Minio initialize XL backend.
~~~
$ minio init xl <url1>...<url16>
~~~
For 'fs' backend it starts the server.
~~~
$ minio server
~~~
For 'xl' backend it waits for servers to join.
~~~
$ minio server
... [PROGRESS BAR] of servers connecting
~~~
Now on other servers execute 'join' and they connect.
~~~
....
minio join <url1> -- from <url2> && minio server
minio join <url1> -- from <url3> && minio server
...
...
minio join <url1> -- from <url16> && minio server
~~~
2016-02-12 18:27:10 -05:00
|
|
|
|
// Purge all configs with version '1'.
|
2016-09-21 12:44:57 -04:00
|
|
|
|
if err := purgeV1(); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
config/main: Re-write config files - add to new config v3
- New config format.
```
{
"version": "3",
"address": ":9000",
"backend": {
"type": "fs",
"disk": "/path"
},
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
},
"console": {
"enable": true,
"level": "fatal"
}
}
}
```
New command lines in lieu of supporting XL.
Minio initialize filesystem backend.
~~~
$ minio init fs <path>
~~~
Minio initialize XL backend.
~~~
$ minio init xl <url1>...<url16>
~~~
For 'fs' backend it starts the server.
~~~
$ minio server
~~~
For 'xl' backend it waits for servers to join.
~~~
$ minio server
... [PROGRESS BAR] of servers connecting
~~~
Now on other servers execute 'join' and they connect.
~~~
....
minio join <url1> -- from <url2> && minio server
minio join <url1> -- from <url3> && minio server
...
...
minio join <url1> -- from <url16> && minio server
~~~
2016-02-12 18:27:10 -05:00
|
|
|
|
// Migrate version '2' to '3'.
|
2016-09-21 12:44:57 -04:00
|
|
|
|
if err := migrateV2ToV3(); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
config: Migrate to the new version. Remove backend details.
Migrate to new config format v4.
```
{
"version": "4",
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"console": {
"enable": true,
"level": "fatal"
},
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
}
}
}
```
This patch also updates [minio cli spec](./minio.md)
2016-04-01 22:19:44 -04:00
|
|
|
|
// Migrate version '3' to '4'.
|
2016-09-21 12:44:57 -04:00
|
|
|
|
if err := migrateV3ToV4(); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
2016-07-24 01:51:12 -04:00
|
|
|
|
// Migrate version '4' to '5'.
|
2016-09-21 12:44:57 -04:00
|
|
|
|
if err := migrateV4ToV5(); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
2016-08-05 01:01:58 -04:00
|
|
|
|
// Migrate version '5' to '6.
|
2016-09-21 12:44:57 -04:00
|
|
|
|
if err := migrateV5ToV6(); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
2016-09-10 03:51:25 -04:00
|
|
|
|
// Migrate version '6' to '7'.
|
2016-09-21 12:44:57 -04:00
|
|
|
|
if err := migrateV6ToV7(); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
2016-09-30 02:42:10 -04:00
|
|
|
|
// Migrate version '7' to '8'.
|
|
|
|
|
if err := migrateV7ToV8(); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
2016-10-05 05:28:04 -04:00
|
|
|
|
// Migrate version '8' to '9'.
|
|
|
|
|
if err := migrateV8ToV9(); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
2016-11-23 18:00:53 -05:00
|
|
|
|
// Migrate version '9' to '10'.
|
|
|
|
|
if err := migrateV9ToV10(); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
2016-12-15 11:23:48 -05:00
|
|
|
|
// Migrate version '10' to '11'.
|
|
|
|
|
if err := migrateV10ToV11(); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
2017-01-11 19:41:05 -05:00
|
|
|
|
// Migrate version '11' to '12'.
|
|
|
|
|
if err := migrateV11ToV12(); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
2017-01-09 17:22:10 -05:00
|
|
|
|
// Migration version '12' to '13'.
|
|
|
|
|
if err := migrateV12ToV13(); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
2017-02-27 17:59:53 -05:00
|
|
|
|
// Migration version '13' to '14'.
|
|
|
|
|
if err := migrateV13ToV14(); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
2017-03-17 12:29:17 -04:00
|
|
|
|
// Migration version '14' to '15'.
|
|
|
|
|
if err := migrateV14ToV15(); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
2017-01-11 19:41:05 -05:00
|
|
|
|
|
2016-09-21 12:44:57 -04:00
|
|
|
|
return nil
|
config/main: Re-write config files - add to new config v3
- New config format.
```
{
"version": "3",
"address": ":9000",
"backend": {
"type": "fs",
"disk": "/path"
},
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
},
"console": {
"enable": true,
"level": "fatal"
}
}
}
```
New command lines in lieu of supporting XL.
Minio initialize filesystem backend.
~~~
$ minio init fs <path>
~~~
Minio initialize XL backend.
~~~
$ minio init xl <url1>...<url16>
~~~
For 'fs' backend it starts the server.
~~~
$ minio server
~~~
For 'xl' backend it waits for servers to join.
~~~
$ minio server
... [PROGRESS BAR] of servers connecting
~~~
Now on other servers execute 'join' and they connect.
~~~
....
minio join <url1> -- from <url2> && minio server
minio join <url1> -- from <url3> && minio server
...
...
minio join <url1> -- from <url16> && minio server
~~~
2016-02-12 18:27:10 -05:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Version '1' is not supported anymore and deprecated, safe to delete.
|
2016-09-21 12:44:57 -04:00
|
|
|
|
func purgeV1() error {
|
config/main: Re-write config files - add to new config v3
- New config format.
```
{
"version": "3",
"address": ":9000",
"backend": {
"type": "fs",
"disk": "/path"
},
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
},
"console": {
"enable": true,
"level": "fatal"
}
}
}
```
New command lines in lieu of supporting XL.
Minio initialize filesystem backend.
~~~
$ minio init fs <path>
~~~
Minio initialize XL backend.
~~~
$ minio init xl <url1>...<url16>
~~~
For 'fs' backend it starts the server.
~~~
$ minio server
~~~
For 'xl' backend it waits for servers to join.
~~~
$ minio server
... [PROGRESS BAR] of servers connecting
~~~
Now on other servers execute 'join' and they connect.
~~~
....
minio join <url1> -- from <url2> && minio server
minio join <url1> -- from <url3> && minio server
...
...
minio join <url1> -- from <url16> && minio server
~~~
2016-02-12 18:27:10 -05:00
|
|
|
|
cv1, err := loadConfigV1()
|
2016-09-21 12:44:57 -04:00
|
|
|
|
if err != nil {
|
|
|
|
|
if os.IsNotExist(err) {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
return fmt.Errorf("Unable to load config version ‘1’. %v", err)
|
|
|
|
|
|
config/main: Re-write config files - add to new config v3
- New config format.
```
{
"version": "3",
"address": ":9000",
"backend": {
"type": "fs",
"disk": "/path"
},
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
},
"console": {
"enable": true,
"level": "fatal"
}
}
}
```
New command lines in lieu of supporting XL.
Minio initialize filesystem backend.
~~~
$ minio init fs <path>
~~~
Minio initialize XL backend.
~~~
$ minio init xl <url1>...<url16>
~~~
For 'fs' backend it starts the server.
~~~
$ minio server
~~~
For 'xl' backend it waits for servers to join.
~~~
$ minio server
... [PROGRESS BAR] of servers connecting
~~~
Now on other servers execute 'join' and they connect.
~~~
....
minio join <url1> -- from <url2> && minio server
minio join <url1> -- from <url3> && minio server
...
...
minio join <url1> -- from <url16> && minio server
~~~
2016-02-12 18:27:10 -05:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if cv1.Version == "1" {
|
2017-03-02 17:21:30 -05:00
|
|
|
|
// Purge old fsUsers.json file
|
|
|
|
|
configFile := filepath.Join(getConfigDir(), "fsUsers.json")
|
2016-06-13 05:53:09 -04:00
|
|
|
|
removeAll(configFile)
|
2017-03-02 17:21:30 -05:00
|
|
|
|
console.Println("Removed unsupported config version ‘1’.")
|
2016-09-21 12:44:57 -04:00
|
|
|
|
return nil
|
config/main: Re-write config files - add to new config v3
- New config format.
```
{
"version": "3",
"address": ":9000",
"backend": {
"type": "fs",
"disk": "/path"
},
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
},
"console": {
"enable": true,
"level": "fatal"
}
}
}
```
New command lines in lieu of supporting XL.
Minio initialize filesystem backend.
~~~
$ minio init fs <path>
~~~
Minio initialize XL backend.
~~~
$ minio init xl <url1>...<url16>
~~~
For 'fs' backend it starts the server.
~~~
$ minio server
~~~
For 'xl' backend it waits for servers to join.
~~~
$ minio server
... [PROGRESS BAR] of servers connecting
~~~
Now on other servers execute 'join' and they connect.
~~~
....
minio join <url1> -- from <url2> && minio server
minio join <url1> -- from <url3> && minio server
...
...
minio join <url1> -- from <url16> && minio server
~~~
2016-02-12 18:27:10 -05:00
|
|
|
|
}
|
2016-09-21 12:44:57 -04:00
|
|
|
|
return fmt.Errorf("Failed to migrate unrecognized config version ‘" + cv1.Version + "’.")
|
config/main: Re-write config files - add to new config v3
- New config format.
```
{
"version": "3",
"address": ":9000",
"backend": {
"type": "fs",
"disk": "/path"
},
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
},
"console": {
"enable": true,
"level": "fatal"
}
}
}
```
New command lines in lieu of supporting XL.
Minio initialize filesystem backend.
~~~
$ minio init fs <path>
~~~
Minio initialize XL backend.
~~~
$ minio init xl <url1>...<url16>
~~~
For 'fs' backend it starts the server.
~~~
$ minio server
~~~
For 'xl' backend it waits for servers to join.
~~~
$ minio server
... [PROGRESS BAR] of servers connecting
~~~
Now on other servers execute 'join' and they connect.
~~~
....
minio join <url1> -- from <url2> && minio server
minio join <url1> -- from <url3> && minio server
...
...
minio join <url1> -- from <url16> && minio server
~~~
2016-02-12 18:27:10 -05:00
|
|
|
|
}
|
|
|
|
|
|
config: Migrate to the new version. Remove backend details.
Migrate to new config format v4.
```
{
"version": "4",
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"console": {
"enable": true,
"level": "fatal"
},
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
}
}
}
```
This patch also updates [minio cli spec](./minio.md)
2016-04-01 22:19:44 -04:00
|
|
|
|
// Version '2' to '3' config migration adds new fields and re-orders
|
|
|
|
|
// previous fields. Simplifies config for future additions.
|
2016-09-21 12:44:57 -04:00
|
|
|
|
func migrateV2ToV3() error {
|
config/main: Re-write config files - add to new config v3
- New config format.
```
{
"version": "3",
"address": ":9000",
"backend": {
"type": "fs",
"disk": "/path"
},
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
},
"console": {
"enable": true,
"level": "fatal"
}
}
}
```
New command lines in lieu of supporting XL.
Minio initialize filesystem backend.
~~~
$ minio init fs <path>
~~~
Minio initialize XL backend.
~~~
$ minio init xl <url1>...<url16>
~~~
For 'fs' backend it starts the server.
~~~
$ minio server
~~~
For 'xl' backend it waits for servers to join.
~~~
$ minio server
... [PROGRESS BAR] of servers connecting
~~~
Now on other servers execute 'join' and they connect.
~~~
....
minio join <url1> -- from <url2> && minio server
minio join <url1> -- from <url3> && minio server
...
...
minio join <url1> -- from <url16> && minio server
~~~
2016-02-12 18:27:10 -05:00
|
|
|
|
cv2, err := loadConfigV2()
|
2016-09-21 12:44:57 -04:00
|
|
|
|
if err != nil {
|
|
|
|
|
if os.IsNotExist(err) {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
return fmt.Errorf("Unable to load config version ‘2’. %v", err)
|
config/main: Re-write config files - add to new config v3
- New config format.
```
{
"version": "3",
"address": ":9000",
"backend": {
"type": "fs",
"disk": "/path"
},
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
},
"console": {
"enable": true,
"level": "fatal"
}
}
}
```
New command lines in lieu of supporting XL.
Minio initialize filesystem backend.
~~~
$ minio init fs <path>
~~~
Minio initialize XL backend.
~~~
$ minio init xl <url1>...<url16>
~~~
For 'fs' backend it starts the server.
~~~
$ minio server
~~~
For 'xl' backend it waits for servers to join.
~~~
$ minio server
... [PROGRESS BAR] of servers connecting
~~~
Now on other servers execute 'join' and they connect.
~~~
....
minio join <url1> -- from <url2> && minio server
minio join <url1> -- from <url3> && minio server
...
...
minio join <url1> -- from <url16> && minio server
~~~
2016-02-12 18:27:10 -05:00
|
|
|
|
}
|
|
|
|
|
if cv2.Version != "2" {
|
2016-09-21 12:44:57 -04:00
|
|
|
|
return nil
|
config/main: Re-write config files - add to new config v3
- New config format.
```
{
"version": "3",
"address": ":9000",
"backend": {
"type": "fs",
"disk": "/path"
},
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
},
"console": {
"enable": true,
"level": "fatal"
}
}
}
```
New command lines in lieu of supporting XL.
Minio initialize filesystem backend.
~~~
$ minio init fs <path>
~~~
Minio initialize XL backend.
~~~
$ minio init xl <url1>...<url16>
~~~
For 'fs' backend it starts the server.
~~~
$ minio server
~~~
For 'xl' backend it waits for servers to join.
~~~
$ minio server
... [PROGRESS BAR] of servers connecting
~~~
Now on other servers execute 'join' and they connect.
~~~
....
minio join <url1> -- from <url2> && minio server
minio join <url1> -- from <url3> && minio server
...
...
minio join <url1> -- from <url16> && minio server
~~~
2016-02-12 18:27:10 -05:00
|
|
|
|
}
|
2017-03-16 03:16:06 -04:00
|
|
|
|
|
|
|
|
|
cred, err := createCredential(cv2.Credentials.AccessKey, cv2.Credentials.SecretKey)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("Invalid credential in V2 configuration file. %v", err)
|
|
|
|
|
}
|
|
|
|
|
|
config: Migrate to the new version. Remove backend details.
Migrate to new config format v4.
```
{
"version": "4",
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"console": {
"enable": true,
"level": "fatal"
},
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
}
}
}
```
This patch also updates [minio cli spec](./minio.md)
2016-04-01 22:19:44 -04:00
|
|
|
|
srvConfig := &configV3{}
|
|
|
|
|
srvConfig.Version = "3"
|
|
|
|
|
srvConfig.Addr = ":9000"
|
2017-03-16 03:16:06 -04:00
|
|
|
|
srvConfig.Credential = cred
|
config: Migrate to the new version. Remove backend details.
Migrate to new config format v4.
```
{
"version": "4",
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"console": {
"enable": true,
"level": "fatal"
},
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
}
}
}
```
This patch also updates [minio cli spec](./minio.md)
2016-04-01 22:19:44 -04:00
|
|
|
|
srvConfig.Region = cv2.Credentials.Region
|
2016-05-03 18:17:58 -04:00
|
|
|
|
if srvConfig.Region == "" {
|
|
|
|
|
// Region needs to be set for AWS Signature V4.
|
2017-01-18 15:24:34 -05:00
|
|
|
|
srvConfig.Region = globalMinioDefaultRegion
|
2016-05-03 18:17:58 -04:00
|
|
|
|
}
|
config: Migrate to the new version. Remove backend details.
Migrate to new config format v4.
```
{
"version": "4",
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"console": {
"enable": true,
"level": "fatal"
},
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
}
}
}
```
This patch also updates [minio cli spec](./minio.md)
2016-04-01 22:19:44 -04:00
|
|
|
|
srvConfig.Logger.Console = consoleLogger{
|
config/main: Re-write config files - add to new config v3
- New config format.
```
{
"version": "3",
"address": ":9000",
"backend": {
"type": "fs",
"disk": "/path"
},
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
},
"console": {
"enable": true,
"level": "fatal"
}
}
}
```
New command lines in lieu of supporting XL.
Minio initialize filesystem backend.
~~~
$ minio init fs <path>
~~~
Minio initialize XL backend.
~~~
$ minio init xl <url1>...<url16>
~~~
For 'fs' backend it starts the server.
~~~
$ minio server
~~~
For 'xl' backend it waits for servers to join.
~~~
$ minio server
... [PROGRESS BAR] of servers connecting
~~~
Now on other servers execute 'join' and they connect.
~~~
....
minio join <url1> -- from <url2> && minio server
minio join <url1> -- from <url3> && minio server
...
...
minio join <url1> -- from <url16> && minio server
~~~
2016-02-12 18:27:10 -05:00
|
|
|
|
Enable: true,
|
|
|
|
|
Level: "fatal",
|
config: Migrate to the new version. Remove backend details.
Migrate to new config format v4.
```
{
"version": "4",
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"console": {
"enable": true,
"level": "fatal"
},
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
}
}
}
```
This patch also updates [minio cli spec](./minio.md)
2016-04-01 22:19:44 -04:00
|
|
|
|
}
|
config/main: Re-write config files - add to new config v3
- New config format.
```
{
"version": "3",
"address": ":9000",
"backend": {
"type": "fs",
"disk": "/path"
},
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
},
"console": {
"enable": true,
"level": "fatal"
}
}
}
```
New command lines in lieu of supporting XL.
Minio initialize filesystem backend.
~~~
$ minio init fs <path>
~~~
Minio initialize XL backend.
~~~
$ minio init xl <url1>...<url16>
~~~
For 'fs' backend it starts the server.
~~~
$ minio server
~~~
For 'xl' backend it waits for servers to join.
~~~
$ minio server
... [PROGRESS BAR] of servers connecting
~~~
Now on other servers execute 'join' and they connect.
~~~
....
minio join <url1> -- from <url2> && minio server
minio join <url1> -- from <url3> && minio server
...
...
minio join <url1> -- from <url16> && minio server
~~~
2016-02-12 18:27:10 -05:00
|
|
|
|
flogger := fileLogger{}
|
|
|
|
|
flogger.Level = "error"
|
|
|
|
|
if cv2.FileLogger.Filename != "" {
|
|
|
|
|
flogger.Enable = true
|
|
|
|
|
flogger.Filename = cv2.FileLogger.Filename
|
|
|
|
|
}
|
config: Migrate to the new version. Remove backend details.
Migrate to new config format v4.
```
{
"version": "4",
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"console": {
"enable": true,
"level": "fatal"
},
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
}
}
}
```
This patch also updates [minio cli spec](./minio.md)
2016-04-01 22:19:44 -04:00
|
|
|
|
srvConfig.Logger.File = flogger
|
config/main: Re-write config files - add to new config v3
- New config format.
```
{
"version": "3",
"address": ":9000",
"backend": {
"type": "fs",
"disk": "/path"
},
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
},
"console": {
"enable": true,
"level": "fatal"
}
}
}
```
New command lines in lieu of supporting XL.
Minio initialize filesystem backend.
~~~
$ minio init fs <path>
~~~
Minio initialize XL backend.
~~~
$ minio init xl <url1>...<url16>
~~~
For 'fs' backend it starts the server.
~~~
$ minio server
~~~
For 'xl' backend it waits for servers to join.
~~~
$ minio server
... [PROGRESS BAR] of servers connecting
~~~
Now on other servers execute 'join' and they connect.
~~~
....
minio join <url1> -- from <url2> && minio server
minio join <url1> -- from <url3> && minio server
...
...
minio join <url1> -- from <url16> && minio server
~~~
2016-02-12 18:27:10 -05:00
|
|
|
|
|
2016-11-23 18:00:53 -05:00
|
|
|
|
slogger := syslogLoggerV3{}
|
config/main: Re-write config files - add to new config v3
- New config format.
```
{
"version": "3",
"address": ":9000",
"backend": {
"type": "fs",
"disk": "/path"
},
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
},
"console": {
"enable": true,
"level": "fatal"
}
}
}
```
New command lines in lieu of supporting XL.
Minio initialize filesystem backend.
~~~
$ minio init fs <path>
~~~
Minio initialize XL backend.
~~~
$ minio init xl <url1>...<url16>
~~~
For 'fs' backend it starts the server.
~~~
$ minio server
~~~
For 'xl' backend it waits for servers to join.
~~~
$ minio server
... [PROGRESS BAR] of servers connecting
~~~
Now on other servers execute 'join' and they connect.
~~~
....
minio join <url1> -- from <url2> && minio server
minio join <url1> -- from <url3> && minio server
...
...
minio join <url1> -- from <url16> && minio server
~~~
2016-02-12 18:27:10 -05:00
|
|
|
|
slogger.Level = "debug"
|
|
|
|
|
if cv2.SyslogLogger.Addr != "" {
|
|
|
|
|
slogger.Enable = true
|
|
|
|
|
slogger.Addr = cv2.SyslogLogger.Addr
|
|
|
|
|
}
|
config: Migrate to the new version. Remove backend details.
Migrate to new config format v4.
```
{
"version": "4",
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"console": {
"enable": true,
"level": "fatal"
},
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
}
}
}
```
This patch also updates [minio cli spec](./minio.md)
2016-04-01 22:19:44 -04:00
|
|
|
|
srvConfig.Logger.Syslog = slogger
|
|
|
|
|
|
|
|
|
|
qc, err := quick.New(srvConfig)
|
2016-09-21 12:44:57 -04:00
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("Unable to initialize config. %v", err)
|
|
|
|
|
}
|
config: Migrate to the new version. Remove backend details.
Migrate to new config format v4.
```
{
"version": "4",
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"console": {
"enable": true,
"level": "fatal"
},
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
}
}
}
```
This patch also updates [minio cli spec](./minio.md)
2016-04-01 22:19:44 -04:00
|
|
|
|
|
2017-03-02 17:21:30 -05:00
|
|
|
|
configFile := getConfigFile()
|
config: Migrate to the new version. Remove backend details.
Migrate to new config format v4.
```
{
"version": "4",
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"console": {
"enable": true,
"level": "fatal"
},
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
}
}
}
```
This patch also updates [minio cli spec](./minio.md)
2016-04-01 22:19:44 -04:00
|
|
|
|
err = qc.Save(configFile)
|
2016-09-21 12:44:57 -04:00
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("Failed to migrate config from ‘"+cv2.Version+"’ to ‘"+srvConfig.Version+"’ failed. %v", err)
|
|
|
|
|
}
|
config: Migrate to the new version. Remove backend details.
Migrate to new config format v4.
```
{
"version": "4",
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"console": {
"enable": true,
"level": "fatal"
},
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
}
}
}
```
This patch also updates [minio cli spec](./minio.md)
2016-04-01 22:19:44 -04:00
|
|
|
|
|
|
|
|
|
console.Println("Migration from version ‘" + cv2.Version + "’ to ‘" + srvConfig.Version + "’ completed successfully.")
|
2016-09-21 12:44:57 -04:00
|
|
|
|
return nil
|
config: Migrate to the new version. Remove backend details.
Migrate to new config format v4.
```
{
"version": "4",
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"console": {
"enable": true,
"level": "fatal"
},
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
}
}
}
```
This patch also updates [minio cli spec](./minio.md)
2016-04-01 22:19:44 -04:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Version '3' to '4' migrates config, removes previous fields related
|
|
|
|
|
// to backend types and server address. This change further simplifies
|
|
|
|
|
// the config for future additions.
|
2016-09-21 12:44:57 -04:00
|
|
|
|
func migrateV3ToV4() error {
|
config: Migrate to the new version. Remove backend details.
Migrate to new config format v4.
```
{
"version": "4",
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"console": {
"enable": true,
"level": "fatal"
},
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
}
}
}
```
This patch also updates [minio cli spec](./minio.md)
2016-04-01 22:19:44 -04:00
|
|
|
|
cv3, err := loadConfigV3()
|
2016-09-21 12:44:57 -04:00
|
|
|
|
if err != nil {
|
|
|
|
|
if os.IsNotExist(err) {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
return fmt.Errorf("Unable to load config version ‘3’. %v", err)
|
config: Migrate to the new version. Remove backend details.
Migrate to new config format v4.
```
{
"version": "4",
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"console": {
"enable": true,
"level": "fatal"
},
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
}
}
}
```
This patch also updates [minio cli spec](./minio.md)
2016-04-01 22:19:44 -04:00
|
|
|
|
}
|
|
|
|
|
if cv3.Version != "3" {
|
2016-09-21 12:44:57 -04:00
|
|
|
|
return nil
|
config: Migrate to the new version. Remove backend details.
Migrate to new config format v4.
```
{
"version": "4",
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"console": {
"enable": true,
"level": "fatal"
},
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
}
}
}
```
This patch also updates [minio cli spec](./minio.md)
2016-04-01 22:19:44 -04:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Save only the new fields, ignore the rest.
|
2016-07-24 01:51:12 -04:00
|
|
|
|
srvConfig := &configV4{}
|
|
|
|
|
srvConfig.Version = "4"
|
config: Migrate to the new version. Remove backend details.
Migrate to new config format v4.
```
{
"version": "4",
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"console": {
"enable": true,
"level": "fatal"
},
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
}
}
}
```
This patch also updates [minio cli spec](./minio.md)
2016-04-01 22:19:44 -04:00
|
|
|
|
srvConfig.Credential = cv3.Credential
|
|
|
|
|
srvConfig.Region = cv3.Region
|
2016-05-03 18:17:58 -04:00
|
|
|
|
if srvConfig.Region == "" {
|
|
|
|
|
// Region needs to be set for AWS Signature Version 4.
|
2017-01-18 15:24:34 -05:00
|
|
|
|
srvConfig.Region = globalMinioDefaultRegion
|
2016-05-03 18:17:58 -04:00
|
|
|
|
}
|
config: Migrate to the new version. Remove backend details.
Migrate to new config format v4.
```
{
"version": "4",
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"console": {
"enable": true,
"level": "fatal"
},
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
}
}
}
```
This patch also updates [minio cli spec](./minio.md)
2016-04-01 22:19:44 -04:00
|
|
|
|
srvConfig.Logger.Console = cv3.Logger.Console
|
|
|
|
|
srvConfig.Logger.File = cv3.Logger.File
|
|
|
|
|
srvConfig.Logger.Syslog = cv3.Logger.Syslog
|
|
|
|
|
|
|
|
|
|
qc, err := quick.New(srvConfig)
|
2016-09-21 12:44:57 -04:00
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("Unable to initialize the quick config. %v", err)
|
|
|
|
|
}
|
config/main: Re-write config files - add to new config v3
- New config format.
```
{
"version": "3",
"address": ":9000",
"backend": {
"type": "fs",
"disk": "/path"
},
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
},
"console": {
"enable": true,
"level": "fatal"
}
}
}
```
New command lines in lieu of supporting XL.
Minio initialize filesystem backend.
~~~
$ minio init fs <path>
~~~
Minio initialize XL backend.
~~~
$ minio init xl <url1>...<url16>
~~~
For 'fs' backend it starts the server.
~~~
$ minio server
~~~
For 'xl' backend it waits for servers to join.
~~~
$ minio server
... [PROGRESS BAR] of servers connecting
~~~
Now on other servers execute 'join' and they connect.
~~~
....
minio join <url1> -- from <url2> && minio server
minio join <url1> -- from <url3> && minio server
...
...
minio join <url1> -- from <url16> && minio server
~~~
2016-02-12 18:27:10 -05:00
|
|
|
|
|
2017-03-02 17:21:30 -05:00
|
|
|
|
configFile := getConfigFile()
|
config: Migrate to the new version. Remove backend details.
Migrate to new config format v4.
```
{
"version": "4",
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"console": {
"enable": true,
"level": "fatal"
},
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
}
}
}
```
This patch also updates [minio cli spec](./minio.md)
2016-04-01 22:19:44 -04:00
|
|
|
|
err = qc.Save(configFile)
|
2016-09-21 12:44:57 -04:00
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("Failed to migrate config from ‘"+cv3.Version+"’ to ‘"+srvConfig.Version+"’ failed. %v", err)
|
|
|
|
|
}
|
config/main: Re-write config files - add to new config v3
- New config format.
```
{
"version": "3",
"address": ":9000",
"backend": {
"type": "fs",
"disk": "/path"
},
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
},
"console": {
"enable": true,
"level": "fatal"
}
}
}
```
New command lines in lieu of supporting XL.
Minio initialize filesystem backend.
~~~
$ minio init fs <path>
~~~
Minio initialize XL backend.
~~~
$ minio init xl <url1>...<url16>
~~~
For 'fs' backend it starts the server.
~~~
$ minio server
~~~
For 'xl' backend it waits for servers to join.
~~~
$ minio server
... [PROGRESS BAR] of servers connecting
~~~
Now on other servers execute 'join' and they connect.
~~~
....
minio join <url1> -- from <url2> && minio server
minio join <url1> -- from <url3> && minio server
...
...
minio join <url1> -- from <url16> && minio server
~~~
2016-02-12 18:27:10 -05:00
|
|
|
|
|
config: Migrate to the new version. Remove backend details.
Migrate to new config format v4.
```
{
"version": "4",
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"console": {
"enable": true,
"level": "fatal"
},
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
}
}
}
```
This patch also updates [minio cli spec](./minio.md)
2016-04-01 22:19:44 -04:00
|
|
|
|
console.Println("Migration from version ‘" + cv3.Version + "’ to ‘" + srvConfig.Version + "’ completed successfully.")
|
2016-09-21 12:44:57 -04:00
|
|
|
|
return nil
|
config/main: Re-write config files - add to new config v3
- New config format.
```
{
"version": "3",
"address": ":9000",
"backend": {
"type": "fs",
"disk": "/path"
},
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
},
"console": {
"enable": true,
"level": "fatal"
}
}
}
```
New command lines in lieu of supporting XL.
Minio initialize filesystem backend.
~~~
$ minio init fs <path>
~~~
Minio initialize XL backend.
~~~
$ minio init xl <url1>...<url16>
~~~
For 'fs' backend it starts the server.
~~~
$ minio server
~~~
For 'xl' backend it waits for servers to join.
~~~
$ minio server
... [PROGRESS BAR] of servers connecting
~~~
Now on other servers execute 'join' and they connect.
~~~
....
minio join <url1> -- from <url2> && minio server
minio join <url1> -- from <url3> && minio server
...
...
minio join <url1> -- from <url16> && minio server
~~~
2016-02-12 18:27:10 -05:00
|
|
|
|
}
|
2016-07-24 01:51:12 -04:00
|
|
|
|
|
2016-09-10 03:51:25 -04:00
|
|
|
|
// Version '4' to '5' migrates config, removes previous fields related
|
|
|
|
|
// to backend types and server address. This change further simplifies
|
|
|
|
|
// the config for future additions.
|
2016-09-21 12:44:57 -04:00
|
|
|
|
func migrateV4ToV5() error {
|
2016-09-10 03:51:25 -04:00
|
|
|
|
cv4, err := loadConfigV4()
|
2016-09-21 12:44:57 -04:00
|
|
|
|
if err != nil {
|
|
|
|
|
if os.IsNotExist(err) {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
return fmt.Errorf("Unable to load config version ‘4’. %v", err)
|
2016-09-10 03:51:25 -04:00
|
|
|
|
}
|
|
|
|
|
if cv4.Version != "4" {
|
2016-09-21 12:44:57 -04:00
|
|
|
|
return nil
|
2016-09-10 03:51:25 -04:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Save only the new fields, ignore the rest.
|
|
|
|
|
srvConfig := &configV5{}
|
|
|
|
|
srvConfig.Version = "5"
|
|
|
|
|
srvConfig.Credential = cv4.Credential
|
|
|
|
|
srvConfig.Region = cv4.Region
|
|
|
|
|
if srvConfig.Region == "" {
|
|
|
|
|
// Region needs to be set for AWS Signature Version 4.
|
2017-01-18 15:24:34 -05:00
|
|
|
|
srvConfig.Region = globalMinioDefaultRegion
|
2016-09-10 03:51:25 -04:00
|
|
|
|
}
|
|
|
|
|
srvConfig.Logger.Console = cv4.Logger.Console
|
|
|
|
|
srvConfig.Logger.File = cv4.Logger.File
|
|
|
|
|
srvConfig.Logger.Syslog = cv4.Logger.Syslog
|
|
|
|
|
srvConfig.Logger.AMQP.Enable = false
|
|
|
|
|
srvConfig.Logger.ElasticSearch.Enable = false
|
|
|
|
|
srvConfig.Logger.Redis.Enable = false
|
|
|
|
|
|
|
|
|
|
qc, err := quick.New(srvConfig)
|
2016-09-21 12:44:57 -04:00
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("Unable to initialize the quick config. %v", err)
|
|
|
|
|
}
|
2016-09-10 03:51:25 -04:00
|
|
|
|
|
2017-03-02 17:21:30 -05:00
|
|
|
|
configFile := getConfigFile()
|
2016-09-10 03:51:25 -04:00
|
|
|
|
err = qc.Save(configFile)
|
2016-09-21 12:44:57 -04:00
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("Failed to migrate config from ‘"+cv4.Version+"’ to ‘"+srvConfig.Version+"’ failed. %v", err)
|
|
|
|
|
}
|
2016-09-10 03:51:25 -04:00
|
|
|
|
|
|
|
|
|
console.Println("Migration from version ‘" + cv4.Version + "’ to ‘" + srvConfig.Version + "’ completed successfully.")
|
2016-09-21 12:44:57 -04:00
|
|
|
|
return nil
|
2016-09-10 03:51:25 -04:00
|
|
|
|
}
|
|
|
|
|
|
2016-08-05 01:01:58 -04:00
|
|
|
|
// Version '5' to '6' migrates config, removes previous fields related
|
|
|
|
|
// to backend types and server address. This change further simplifies
|
|
|
|
|
// the config for future additions.
|
2016-09-21 12:44:57 -04:00
|
|
|
|
func migrateV5ToV6() error {
|
2016-08-05 01:01:58 -04:00
|
|
|
|
cv5, err := loadConfigV5()
|
2016-09-21 12:44:57 -04:00
|
|
|
|
if err != nil {
|
|
|
|
|
if os.IsNotExist(err) {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
return fmt.Errorf("Unable to load config version ‘5’. %v", err)
|
2016-08-05 01:01:58 -04:00
|
|
|
|
}
|
|
|
|
|
if cv5.Version != "5" {
|
2016-09-21 12:44:57 -04:00
|
|
|
|
return nil
|
2016-08-05 01:01:58 -04:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Save only the new fields, ignore the rest.
|
2016-09-10 03:51:25 -04:00
|
|
|
|
srvConfig := &configV6{}
|
|
|
|
|
srvConfig.Version = "6"
|
2016-08-05 01:01:58 -04:00
|
|
|
|
srvConfig.Credential = cv5.Credential
|
|
|
|
|
srvConfig.Region = cv5.Region
|
|
|
|
|
if srvConfig.Region == "" {
|
|
|
|
|
// Region needs to be set for AWS Signature Version 4.
|
2017-01-18 15:24:34 -05:00
|
|
|
|
srvConfig.Region = globalMinioDefaultRegion
|
2016-08-05 01:01:58 -04:00
|
|
|
|
}
|
|
|
|
|
srvConfig.Logger.Console = cv5.Logger.Console
|
|
|
|
|
srvConfig.Logger.File = cv5.Logger.File
|
|
|
|
|
srvConfig.Logger.Syslog = cv5.Logger.Syslog
|
2016-09-10 03:51:25 -04:00
|
|
|
|
|
2016-08-05 01:01:58 -04:00
|
|
|
|
srvConfig.Notify.AMQP = map[string]amqpNotify{
|
|
|
|
|
"1": {
|
|
|
|
|
Enable: cv5.Logger.AMQP.Enable,
|
|
|
|
|
URL: cv5.Logger.AMQP.URL,
|
|
|
|
|
Exchange: cv5.Logger.AMQP.Exchange,
|
|
|
|
|
RoutingKey: cv5.Logger.AMQP.RoutingKey,
|
|
|
|
|
Mandatory: cv5.Logger.AMQP.Mandatory,
|
|
|
|
|
Immediate: cv5.Logger.AMQP.Immediate,
|
|
|
|
|
Durable: cv5.Logger.AMQP.Durable,
|
|
|
|
|
Internal: cv5.Logger.AMQP.Internal,
|
|
|
|
|
NoWait: cv5.Logger.AMQP.NoWait,
|
|
|
|
|
AutoDeleted: cv5.Logger.AMQP.AutoDeleted,
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
srvConfig.Notify.ElasticSearch = map[string]elasticSearchNotify{
|
|
|
|
|
"1": {
|
|
|
|
|
Enable: cv5.Logger.ElasticSearch.Enable,
|
|
|
|
|
URL: cv5.Logger.ElasticSearch.URL,
|
|
|
|
|
Index: cv5.Logger.ElasticSearch.Index,
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
srvConfig.Notify.Redis = map[string]redisNotify{
|
|
|
|
|
"1": {
|
|
|
|
|
Enable: cv5.Logger.Redis.Enable,
|
|
|
|
|
Addr: cv5.Logger.Redis.Addr,
|
|
|
|
|
Password: cv5.Logger.Redis.Password,
|
|
|
|
|
Key: cv5.Logger.Redis.Key,
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
qc, err := quick.New(srvConfig)
|
2016-09-21 12:44:57 -04:00
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("Unable to initialize the quick config. %v", err)
|
|
|
|
|
}
|
2016-08-05 01:01:58 -04:00
|
|
|
|
|
2017-03-02 17:21:30 -05:00
|
|
|
|
configFile := getConfigFile()
|
2016-08-05 01:01:58 -04:00
|
|
|
|
err = qc.Save(configFile)
|
2016-09-21 12:44:57 -04:00
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("Failed to migrate config from ‘"+cv5.Version+"’ to ‘"+srvConfig.Version+"’ failed. %v", err)
|
|
|
|
|
}
|
2016-08-05 01:01:58 -04:00
|
|
|
|
|
|
|
|
|
console.Println("Migration from version ‘" + cv5.Version + "’ to ‘" + srvConfig.Version + "’ completed successfully.")
|
2016-09-21 12:44:57 -04:00
|
|
|
|
return nil
|
2016-08-05 01:01:58 -04:00
|
|
|
|
}
|
|
|
|
|
|
2016-09-10 03:51:25 -04:00
|
|
|
|
// Version '6' to '7' migrates config, removes previous fields related
|
2016-07-24 01:51:12 -04:00
|
|
|
|
// to backend types and server address. This change further simplifies
|
|
|
|
|
// the config for future additions.
|
2016-09-21 12:44:57 -04:00
|
|
|
|
func migrateV6ToV7() error {
|
2016-09-10 03:51:25 -04:00
|
|
|
|
cv6, err := loadConfigV6()
|
2016-09-21 12:44:57 -04:00
|
|
|
|
if err != nil {
|
|
|
|
|
if os.IsNotExist(err) {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
return fmt.Errorf("Unable to load config version ‘6’. %v", err)
|
2016-07-24 01:51:12 -04:00
|
|
|
|
}
|
2016-09-10 03:51:25 -04:00
|
|
|
|
if cv6.Version != "6" {
|
2016-09-21 12:44:57 -04:00
|
|
|
|
return nil
|
2016-07-24 01:51:12 -04:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Save only the new fields, ignore the rest.
|
2016-09-10 03:51:25 -04:00
|
|
|
|
srvConfig := &serverConfigV7{}
|
2016-10-03 20:29:55 -04:00
|
|
|
|
srvConfig.Version = "7"
|
2016-09-10 03:51:25 -04:00
|
|
|
|
srvConfig.Credential = cv6.Credential
|
|
|
|
|
srvConfig.Region = cv6.Region
|
2016-07-24 01:51:12 -04:00
|
|
|
|
if srvConfig.Region == "" {
|
|
|
|
|
// Region needs to be set for AWS Signature Version 4.
|
2017-01-18 15:24:34 -05:00
|
|
|
|
srvConfig.Region = globalMinioDefaultRegion
|
2016-07-24 01:51:12 -04:00
|
|
|
|
}
|
2016-09-10 03:51:25 -04:00
|
|
|
|
srvConfig.Logger.Console = cv6.Logger.Console
|
|
|
|
|
srvConfig.Logger.File = cv6.Logger.File
|
|
|
|
|
srvConfig.Logger.Syslog = cv6.Logger.Syslog
|
|
|
|
|
srvConfig.Notify.AMQP = make(map[string]amqpNotify)
|
|
|
|
|
srvConfig.Notify.ElasticSearch = make(map[string]elasticSearchNotify)
|
|
|
|
|
srvConfig.Notify.Redis = make(map[string]redisNotify)
|
|
|
|
|
if len(cv6.Notify.AMQP) == 0 {
|
|
|
|
|
srvConfig.Notify.AMQP["1"] = amqpNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.AMQP = cv6.Notify.AMQP
|
|
|
|
|
}
|
|
|
|
|
if len(cv6.Notify.ElasticSearch) == 0 {
|
|
|
|
|
srvConfig.Notify.ElasticSearch["1"] = elasticSearchNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.ElasticSearch = cv6.Notify.ElasticSearch
|
|
|
|
|
}
|
|
|
|
|
if len(cv6.Notify.Redis) == 0 {
|
|
|
|
|
srvConfig.Notify.Redis["1"] = redisNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.Redis = cv6.Notify.Redis
|
|
|
|
|
}
|
2016-07-24 01:51:12 -04:00
|
|
|
|
|
|
|
|
|
qc, err := quick.New(srvConfig)
|
2016-09-21 12:44:57 -04:00
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("Unable to initialize the quick config. %v", err)
|
|
|
|
|
}
|
2016-07-24 01:51:12 -04:00
|
|
|
|
|
2017-03-02 17:21:30 -05:00
|
|
|
|
configFile := getConfigFile()
|
2016-07-24 01:51:12 -04:00
|
|
|
|
err = qc.Save(configFile)
|
2016-09-21 12:44:57 -04:00
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("Failed to migrate config from ‘"+cv6.Version+"’ to ‘"+srvConfig.Version+"’ failed. %v", err)
|
|
|
|
|
}
|
2016-07-24 01:51:12 -04:00
|
|
|
|
|
2016-09-10 03:51:25 -04:00
|
|
|
|
console.Println("Migration from version ‘" + cv6.Version + "’ to ‘" + srvConfig.Version + "’ completed successfully.")
|
2016-09-21 12:44:57 -04:00
|
|
|
|
return nil
|
2016-07-24 01:51:12 -04:00
|
|
|
|
}
|
2016-09-30 02:42:10 -04:00
|
|
|
|
|
|
|
|
|
// Version '7' to '8' migrates config, removes previous fields related
|
|
|
|
|
// to backend types and server address. This change further simplifies
|
|
|
|
|
// the config for future additions.
|
|
|
|
|
func migrateV7ToV8() error {
|
|
|
|
|
cv7, err := loadConfigV7()
|
|
|
|
|
if err != nil {
|
|
|
|
|
if os.IsNotExist(err) {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
return fmt.Errorf("Unable to load config version ‘7’. %v", err)
|
|
|
|
|
}
|
|
|
|
|
if cv7.Version != "7" {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Save only the new fields, ignore the rest.
|
|
|
|
|
srvConfig := &serverConfigV8{}
|
2016-10-03 20:29:55 -04:00
|
|
|
|
srvConfig.Version = "8"
|
2016-09-30 02:42:10 -04:00
|
|
|
|
srvConfig.Credential = cv7.Credential
|
|
|
|
|
srvConfig.Region = cv7.Region
|
|
|
|
|
if srvConfig.Region == "" {
|
|
|
|
|
// Region needs to be set for AWS Signature Version 4.
|
2017-01-18 15:24:34 -05:00
|
|
|
|
srvConfig.Region = globalMinioDefaultRegion
|
2016-09-30 02:42:10 -04:00
|
|
|
|
}
|
|
|
|
|
srvConfig.Logger.Console = cv7.Logger.Console
|
|
|
|
|
srvConfig.Logger.File = cv7.Logger.File
|
|
|
|
|
srvConfig.Logger.Syslog = cv7.Logger.Syslog
|
|
|
|
|
srvConfig.Notify.AMQP = make(map[string]amqpNotify)
|
2017-01-11 19:41:05 -05:00
|
|
|
|
srvConfig.Notify.NATS = make(map[string]natsNotifyV1)
|
2016-09-30 02:42:10 -04:00
|
|
|
|
srvConfig.Notify.ElasticSearch = make(map[string]elasticSearchNotify)
|
|
|
|
|
srvConfig.Notify.Redis = make(map[string]redisNotify)
|
2016-10-03 20:29:55 -04:00
|
|
|
|
srvConfig.Notify.PostgreSQL = make(map[string]postgreSQLNotify)
|
2016-09-30 02:42:10 -04:00
|
|
|
|
if len(cv7.Notify.AMQP) == 0 {
|
|
|
|
|
srvConfig.Notify.AMQP["1"] = amqpNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.AMQP = cv7.Notify.AMQP
|
|
|
|
|
}
|
|
|
|
|
if len(cv7.Notify.NATS) == 0 {
|
2017-01-11 19:41:05 -05:00
|
|
|
|
srvConfig.Notify.NATS["1"] = natsNotifyV1{}
|
2016-09-30 02:42:10 -04:00
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.NATS = cv7.Notify.NATS
|
|
|
|
|
}
|
|
|
|
|
if len(cv7.Notify.ElasticSearch) == 0 {
|
|
|
|
|
srvConfig.Notify.ElasticSearch["1"] = elasticSearchNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.ElasticSearch = cv7.Notify.ElasticSearch
|
|
|
|
|
}
|
|
|
|
|
if len(cv7.Notify.Redis) == 0 {
|
|
|
|
|
srvConfig.Notify.Redis["1"] = redisNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.Redis = cv7.Notify.Redis
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
qc, err := quick.New(srvConfig)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("Unable to initialize the quick config. %v", err)
|
|
|
|
|
}
|
|
|
|
|
|
2017-03-02 17:21:30 -05:00
|
|
|
|
configFile := getConfigFile()
|
2016-09-30 02:42:10 -04:00
|
|
|
|
err = qc.Save(configFile)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("Failed to migrate config from ‘"+cv7.Version+"’ to ‘"+srvConfig.Version+"’ failed. %v", err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
console.Println("Migration from version ‘" + cv7.Version + "’ to ‘" + srvConfig.Version + "’ completed successfully.")
|
|
|
|
|
return nil
|
|
|
|
|
}
|
2016-10-03 20:29:55 -04:00
|
|
|
|
|
|
|
|
|
// Version '8' to '9' migration. Adds postgresql notifier
|
|
|
|
|
// configuration, but it's otherwise the same as V8.
|
|
|
|
|
func migrateV8ToV9() error {
|
|
|
|
|
cv8, err := loadConfigV8()
|
|
|
|
|
if err != nil {
|
|
|
|
|
if os.IsNotExist(err) {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
return fmt.Errorf("Unable to load config version ‘8’. %v", err)
|
|
|
|
|
}
|
|
|
|
|
if cv8.Version != "8" {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Copy over fields from V8 into V9 config struct
|
|
|
|
|
srvConfig := &serverConfigV9{}
|
|
|
|
|
srvConfig.Version = "9"
|
|
|
|
|
srvConfig.Credential = cv8.Credential
|
|
|
|
|
srvConfig.Region = cv8.Region
|
|
|
|
|
if srvConfig.Region == "" {
|
|
|
|
|
// Region needs to be set for AWS Signature Version 4.
|
2017-01-18 15:24:34 -05:00
|
|
|
|
srvConfig.Region = globalMinioDefaultRegion
|
2016-10-03 20:29:55 -04:00
|
|
|
|
}
|
|
|
|
|
srvConfig.Logger.Console = cv8.Logger.Console
|
2016-11-23 19:36:26 -05:00
|
|
|
|
srvConfig.Logger.Console.Level = "error"
|
2016-10-03 20:29:55 -04:00
|
|
|
|
srvConfig.Logger.File = cv8.Logger.File
|
|
|
|
|
srvConfig.Logger.Syslog = cv8.Logger.Syslog
|
|
|
|
|
|
|
|
|
|
// check and set notifiers config
|
|
|
|
|
if len(cv8.Notify.AMQP) == 0 {
|
|
|
|
|
srvConfig.Notify.AMQP = make(map[string]amqpNotify)
|
|
|
|
|
srvConfig.Notify.AMQP["1"] = amqpNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.AMQP = cv8.Notify.AMQP
|
|
|
|
|
}
|
|
|
|
|
if len(cv8.Notify.NATS) == 0 {
|
2017-01-11 19:41:05 -05:00
|
|
|
|
srvConfig.Notify.NATS = make(map[string]natsNotifyV1)
|
|
|
|
|
srvConfig.Notify.NATS["1"] = natsNotifyV1{}
|
2016-10-03 20:29:55 -04:00
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.NATS = cv8.Notify.NATS
|
|
|
|
|
}
|
|
|
|
|
if len(cv8.Notify.ElasticSearch) == 0 {
|
|
|
|
|
srvConfig.Notify.ElasticSearch = make(map[string]elasticSearchNotify)
|
|
|
|
|
srvConfig.Notify.ElasticSearch["1"] = elasticSearchNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.ElasticSearch = cv8.Notify.ElasticSearch
|
|
|
|
|
}
|
|
|
|
|
if len(cv8.Notify.Redis) == 0 {
|
|
|
|
|
srvConfig.Notify.Redis = make(map[string]redisNotify)
|
|
|
|
|
srvConfig.Notify.Redis["1"] = redisNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.Redis = cv8.Notify.Redis
|
|
|
|
|
}
|
|
|
|
|
if len(cv8.Notify.PostgreSQL) == 0 {
|
|
|
|
|
srvConfig.Notify.PostgreSQL = make(map[string]postgreSQLNotify)
|
|
|
|
|
srvConfig.Notify.PostgreSQL["1"] = postgreSQLNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.PostgreSQL = cv8.Notify.PostgreSQL
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
qc, err := quick.New(srvConfig)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("Unable to initialize the quick config. %v",
|
|
|
|
|
err)
|
|
|
|
|
}
|
|
|
|
|
|
2017-03-02 17:21:30 -05:00
|
|
|
|
configFile := getConfigFile()
|
2016-10-03 20:29:55 -04:00
|
|
|
|
err = qc.Save(configFile)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf(
|
|
|
|
|
"Failed to migrate config from ‘"+
|
|
|
|
|
cv8.Version+"’ to ‘"+srvConfig.Version+
|
|
|
|
|
"’ failed. %v", err,
|
|
|
|
|
)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
console.Println(
|
|
|
|
|
"Migration from version ‘" +
|
|
|
|
|
cv8.Version + "’ to ‘" + srvConfig.Version +
|
|
|
|
|
"’ completed successfully.",
|
|
|
|
|
)
|
|
|
|
|
return nil
|
|
|
|
|
}
|
2016-11-23 18:00:53 -05:00
|
|
|
|
|
|
|
|
|
// Version '9' to '10' migration. Remove syslog config
|
|
|
|
|
// but it's otherwise the same as V9.
|
|
|
|
|
func migrateV9ToV10() error {
|
|
|
|
|
cv9, err := loadConfigV9()
|
|
|
|
|
if err != nil {
|
|
|
|
|
if os.IsNotExist(err) {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
return fmt.Errorf("Unable to load config version ‘9’. %v", err)
|
|
|
|
|
}
|
|
|
|
|
if cv9.Version != "9" {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Copy over fields from V9 into V10 config struct
|
|
|
|
|
srvConfig := &serverConfigV10{}
|
|
|
|
|
srvConfig.Version = "10"
|
|
|
|
|
srvConfig.Credential = cv9.Credential
|
|
|
|
|
srvConfig.Region = cv9.Region
|
|
|
|
|
if srvConfig.Region == "" {
|
|
|
|
|
// Region needs to be set for AWS Signature Version 4.
|
2017-01-18 15:24:34 -05:00
|
|
|
|
srvConfig.Region = globalMinioDefaultRegion
|
2016-11-23 18:00:53 -05:00
|
|
|
|
}
|
|
|
|
|
srvConfig.Logger.Console = cv9.Logger.Console
|
|
|
|
|
srvConfig.Logger.File = cv9.Logger.File
|
|
|
|
|
|
|
|
|
|
// check and set notifiers config
|
|
|
|
|
if len(cv9.Notify.AMQP) == 0 {
|
|
|
|
|
srvConfig.Notify.AMQP = make(map[string]amqpNotify)
|
|
|
|
|
srvConfig.Notify.AMQP["1"] = amqpNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.AMQP = cv9.Notify.AMQP
|
|
|
|
|
}
|
|
|
|
|
if len(cv9.Notify.NATS) == 0 {
|
2017-01-11 19:41:05 -05:00
|
|
|
|
srvConfig.Notify.NATS = make(map[string]natsNotifyV1)
|
|
|
|
|
srvConfig.Notify.NATS["1"] = natsNotifyV1{}
|
2016-11-23 18:00:53 -05:00
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.NATS = cv9.Notify.NATS
|
|
|
|
|
}
|
|
|
|
|
if len(cv9.Notify.ElasticSearch) == 0 {
|
|
|
|
|
srvConfig.Notify.ElasticSearch = make(map[string]elasticSearchNotify)
|
|
|
|
|
srvConfig.Notify.ElasticSearch["1"] = elasticSearchNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.ElasticSearch = cv9.Notify.ElasticSearch
|
|
|
|
|
}
|
|
|
|
|
if len(cv9.Notify.Redis) == 0 {
|
|
|
|
|
srvConfig.Notify.Redis = make(map[string]redisNotify)
|
|
|
|
|
srvConfig.Notify.Redis["1"] = redisNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.Redis = cv9.Notify.Redis
|
|
|
|
|
}
|
|
|
|
|
if len(cv9.Notify.PostgreSQL) == 0 {
|
|
|
|
|
srvConfig.Notify.PostgreSQL = make(map[string]postgreSQLNotify)
|
|
|
|
|
srvConfig.Notify.PostgreSQL["1"] = postgreSQLNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.PostgreSQL = cv9.Notify.PostgreSQL
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
qc, err := quick.New(srvConfig)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("Unable to initialize the quick config. %v",
|
|
|
|
|
err)
|
|
|
|
|
}
|
|
|
|
|
|
2017-03-02 17:21:30 -05:00
|
|
|
|
configFile := getConfigFile()
|
2016-11-23 18:00:53 -05:00
|
|
|
|
err = qc.Save(configFile)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf(
|
|
|
|
|
"Failed to migrate config from ‘"+
|
|
|
|
|
cv9.Version+"’ to ‘"+srvConfig.Version+
|
|
|
|
|
"’ failed. %v", err,
|
|
|
|
|
)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
console.Println(
|
|
|
|
|
"Migration from version ‘" +
|
|
|
|
|
cv9.Version + "’ to ‘" + srvConfig.Version +
|
|
|
|
|
"’ completed successfully.",
|
|
|
|
|
)
|
|
|
|
|
return nil
|
|
|
|
|
}
|
2016-12-15 11:23:48 -05:00
|
|
|
|
|
|
|
|
|
// Version '10' to '11' migration. Add support for Kafka
|
|
|
|
|
// notifications.
|
|
|
|
|
func migrateV10ToV11() error {
|
|
|
|
|
cv10, err := loadConfigV10()
|
|
|
|
|
if err != nil {
|
|
|
|
|
if os.IsNotExist(err) {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
return fmt.Errorf("Unable to load config version ‘10’. %v", err)
|
|
|
|
|
}
|
|
|
|
|
if cv10.Version != "10" {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Copy over fields from V10 into V11 config struct
|
|
|
|
|
srvConfig := &serverConfigV11{}
|
|
|
|
|
srvConfig.Version = "11"
|
|
|
|
|
srvConfig.Credential = cv10.Credential
|
|
|
|
|
srvConfig.Region = cv10.Region
|
|
|
|
|
if srvConfig.Region == "" {
|
|
|
|
|
// Region needs to be set for AWS Signature Version 4.
|
2017-01-18 15:24:34 -05:00
|
|
|
|
srvConfig.Region = globalMinioDefaultRegion
|
2016-12-15 11:23:48 -05:00
|
|
|
|
}
|
|
|
|
|
srvConfig.Logger.Console = cv10.Logger.Console
|
|
|
|
|
srvConfig.Logger.File = cv10.Logger.File
|
|
|
|
|
|
|
|
|
|
// check and set notifiers config
|
|
|
|
|
if len(cv10.Notify.AMQP) == 0 {
|
|
|
|
|
srvConfig.Notify.AMQP = make(map[string]amqpNotify)
|
|
|
|
|
srvConfig.Notify.AMQP["1"] = amqpNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.AMQP = cv10.Notify.AMQP
|
|
|
|
|
}
|
|
|
|
|
if len(cv10.Notify.NATS) == 0 {
|
2017-01-11 19:41:05 -05:00
|
|
|
|
srvConfig.Notify.NATS = make(map[string]natsNotifyV1)
|
|
|
|
|
srvConfig.Notify.NATS["1"] = natsNotifyV1{}
|
2016-12-15 11:23:48 -05:00
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.NATS = cv10.Notify.NATS
|
|
|
|
|
}
|
|
|
|
|
if len(cv10.Notify.ElasticSearch) == 0 {
|
|
|
|
|
srvConfig.Notify.ElasticSearch = make(map[string]elasticSearchNotify)
|
|
|
|
|
srvConfig.Notify.ElasticSearch["1"] = elasticSearchNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.ElasticSearch = cv10.Notify.ElasticSearch
|
|
|
|
|
}
|
|
|
|
|
if len(cv10.Notify.Redis) == 0 {
|
|
|
|
|
srvConfig.Notify.Redis = make(map[string]redisNotify)
|
|
|
|
|
srvConfig.Notify.Redis["1"] = redisNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.Redis = cv10.Notify.Redis
|
|
|
|
|
}
|
|
|
|
|
if len(cv10.Notify.PostgreSQL) == 0 {
|
|
|
|
|
srvConfig.Notify.PostgreSQL = make(map[string]postgreSQLNotify)
|
|
|
|
|
srvConfig.Notify.PostgreSQL["1"] = postgreSQLNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.PostgreSQL = cv10.Notify.PostgreSQL
|
|
|
|
|
}
|
|
|
|
|
// V10 will not have a Kafka config. So we initialize one here.
|
|
|
|
|
srvConfig.Notify.Kafka = make(map[string]kafkaNotify)
|
|
|
|
|
srvConfig.Notify.Kafka["1"] = kafkaNotify{}
|
|
|
|
|
|
|
|
|
|
qc, err := quick.New(srvConfig)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("Unable to initialize the quick config. %v",
|
|
|
|
|
err)
|
|
|
|
|
}
|
|
|
|
|
|
2017-03-02 17:21:30 -05:00
|
|
|
|
configFile := getConfigFile()
|
2016-12-15 11:23:48 -05:00
|
|
|
|
err = qc.Save(configFile)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf(
|
|
|
|
|
"Failed to migrate config from ‘"+
|
|
|
|
|
cv10.Version+"’ to ‘"+srvConfig.Version+
|
|
|
|
|
"’ failed. %v", err,
|
|
|
|
|
)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
console.Println(
|
|
|
|
|
"Migration from version ‘" +
|
|
|
|
|
cv10.Version + "’ to ‘" + srvConfig.Version +
|
|
|
|
|
"’ completed successfully.",
|
|
|
|
|
)
|
|
|
|
|
return nil
|
|
|
|
|
}
|
2017-01-11 19:41:05 -05:00
|
|
|
|
|
|
|
|
|
// Version '11' to '12' migration. Add support for NATS streaming
|
|
|
|
|
// notifications.
|
|
|
|
|
func migrateV11ToV12() error {
|
|
|
|
|
cv11, err := loadConfigV11()
|
|
|
|
|
if err != nil {
|
|
|
|
|
if os.IsNotExist(err) {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
return fmt.Errorf("Unable to load config version ‘11’. %v", err)
|
|
|
|
|
}
|
|
|
|
|
if cv11.Version != "11" {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Copy over fields from V11 into V12 config struct
|
|
|
|
|
srvConfig := &serverConfigV12{}
|
|
|
|
|
srvConfig.Version = "12"
|
|
|
|
|
srvConfig.Credential = cv11.Credential
|
|
|
|
|
srvConfig.Region = cv11.Region
|
|
|
|
|
if srvConfig.Region == "" {
|
|
|
|
|
// Region needs to be set for AWS Signature Version 4.
|
2017-01-18 15:24:34 -05:00
|
|
|
|
srvConfig.Region = globalMinioDefaultRegion
|
2017-01-11 19:41:05 -05:00
|
|
|
|
}
|
|
|
|
|
srvConfig.Logger.Console = cv11.Logger.Console
|
|
|
|
|
srvConfig.Logger.File = cv11.Logger.File
|
|
|
|
|
|
|
|
|
|
// check and set notifiers config
|
|
|
|
|
if len(cv11.Notify.AMQP) == 0 {
|
|
|
|
|
srvConfig.Notify.AMQP = make(map[string]amqpNotify)
|
|
|
|
|
srvConfig.Notify.AMQP["1"] = amqpNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.AMQP = cv11.Notify.AMQP
|
|
|
|
|
}
|
|
|
|
|
if len(cv11.Notify.ElasticSearch) == 0 {
|
|
|
|
|
srvConfig.Notify.ElasticSearch = make(map[string]elasticSearchNotify)
|
|
|
|
|
srvConfig.Notify.ElasticSearch["1"] = elasticSearchNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.ElasticSearch = cv11.Notify.ElasticSearch
|
|
|
|
|
}
|
|
|
|
|
if len(cv11.Notify.Redis) == 0 {
|
|
|
|
|
srvConfig.Notify.Redis = make(map[string]redisNotify)
|
|
|
|
|
srvConfig.Notify.Redis["1"] = redisNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.Redis = cv11.Notify.Redis
|
|
|
|
|
}
|
|
|
|
|
if len(cv11.Notify.PostgreSQL) == 0 {
|
|
|
|
|
srvConfig.Notify.PostgreSQL = make(map[string]postgreSQLNotify)
|
|
|
|
|
srvConfig.Notify.PostgreSQL["1"] = postgreSQLNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.PostgreSQL = cv11.Notify.PostgreSQL
|
|
|
|
|
}
|
|
|
|
|
if len(cv11.Notify.Kafka) == 0 {
|
|
|
|
|
srvConfig.Notify.Kafka = make(map[string]kafkaNotify)
|
|
|
|
|
srvConfig.Notify.Kafka["1"] = kafkaNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.Kafka = cv11.Notify.Kafka
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// V12 will have an updated config of nats. So we create a new one or we
|
|
|
|
|
// update the old one if found.
|
|
|
|
|
if len(cv11.Notify.NATS) == 0 {
|
|
|
|
|
srvConfig.Notify.NATS = make(map[string]natsNotify)
|
|
|
|
|
srvConfig.Notify.NATS["1"] = natsNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.NATS = make(map[string]natsNotify)
|
|
|
|
|
for k, v := range cv11.Notify.NATS {
|
|
|
|
|
n := natsNotify{}
|
|
|
|
|
n.Enable = v.Enable
|
|
|
|
|
n.Address = v.Address
|
|
|
|
|
n.Subject = v.Subject
|
|
|
|
|
n.Username = v.Username
|
|
|
|
|
n.Password = v.Password
|
|
|
|
|
n.Token = v.Token
|
|
|
|
|
n.Secure = v.Secure
|
|
|
|
|
n.PingInterval = v.PingInterval
|
|
|
|
|
srvConfig.Notify.NATS[k] = n
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
qc, err := quick.New(srvConfig)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("Unable to initialize the quick config. %v",
|
|
|
|
|
err)
|
|
|
|
|
}
|
|
|
|
|
|
2017-03-02 17:21:30 -05:00
|
|
|
|
configFile := getConfigFile()
|
2017-01-11 19:41:05 -05:00
|
|
|
|
err = qc.Save(configFile)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf(
|
|
|
|
|
"Failed to migrate config from ‘"+
|
|
|
|
|
cv11.Version+"’ to ‘"+srvConfig.Version+
|
|
|
|
|
"’ failed. %v", err,
|
|
|
|
|
)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
console.Println(
|
|
|
|
|
"Migration from version ‘" +
|
|
|
|
|
cv11.Version + "’ to ‘" + srvConfig.Version +
|
|
|
|
|
"’ completed successfully.",
|
|
|
|
|
)
|
|
|
|
|
return nil
|
|
|
|
|
}
|
2017-01-09 17:22:10 -05:00
|
|
|
|
|
|
|
|
|
// Version '12' to '13' migration. Add support for custom webhook endpoint.
|
|
|
|
|
func migrateV12ToV13() error {
|
|
|
|
|
cv12, err := loadConfigV12()
|
|
|
|
|
if err != nil {
|
|
|
|
|
if os.IsNotExist(err) {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
return fmt.Errorf("Unable to load config version ‘12’. %v", err)
|
|
|
|
|
}
|
|
|
|
|
if cv12.Version != "12" {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Copy over fields from V12 into V13 config struct
|
2017-02-09 18:20:54 -05:00
|
|
|
|
srvConfig := &serverConfigV13{
|
|
|
|
|
Logger: &logger{},
|
|
|
|
|
Notify: ¬ifier{},
|
|
|
|
|
}
|
2017-01-09 17:22:10 -05:00
|
|
|
|
srvConfig.Version = "13"
|
|
|
|
|
srvConfig.Credential = cv12.Credential
|
|
|
|
|
srvConfig.Region = cv12.Region
|
|
|
|
|
if srvConfig.Region == "" {
|
|
|
|
|
// Region needs to be set for AWS Signature Version 4.
|
2017-01-18 15:24:34 -05:00
|
|
|
|
srvConfig.Region = globalMinioDefaultRegion
|
2017-01-09 17:22:10 -05:00
|
|
|
|
}
|
|
|
|
|
srvConfig.Logger.Console = cv12.Logger.Console
|
|
|
|
|
srvConfig.Logger.File = cv12.Logger.File
|
|
|
|
|
|
|
|
|
|
// check and set notifiers config
|
|
|
|
|
if len(cv12.Notify.AMQP) == 0 {
|
|
|
|
|
srvConfig.Notify.AMQP = make(map[string]amqpNotify)
|
|
|
|
|
srvConfig.Notify.AMQP["1"] = amqpNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.AMQP = cv12.Notify.AMQP
|
|
|
|
|
}
|
|
|
|
|
if len(cv12.Notify.ElasticSearch) == 0 {
|
|
|
|
|
srvConfig.Notify.ElasticSearch = make(map[string]elasticSearchNotify)
|
|
|
|
|
srvConfig.Notify.ElasticSearch["1"] = elasticSearchNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.ElasticSearch = cv12.Notify.ElasticSearch
|
|
|
|
|
}
|
|
|
|
|
if len(cv12.Notify.Redis) == 0 {
|
|
|
|
|
srvConfig.Notify.Redis = make(map[string]redisNotify)
|
|
|
|
|
srvConfig.Notify.Redis["1"] = redisNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.Redis = cv12.Notify.Redis
|
|
|
|
|
}
|
|
|
|
|
if len(cv12.Notify.PostgreSQL) == 0 {
|
|
|
|
|
srvConfig.Notify.PostgreSQL = make(map[string]postgreSQLNotify)
|
|
|
|
|
srvConfig.Notify.PostgreSQL["1"] = postgreSQLNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.PostgreSQL = cv12.Notify.PostgreSQL
|
|
|
|
|
}
|
|
|
|
|
if len(cv12.Notify.Kafka) == 0 {
|
|
|
|
|
srvConfig.Notify.Kafka = make(map[string]kafkaNotify)
|
|
|
|
|
srvConfig.Notify.Kafka["1"] = kafkaNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.Kafka = cv12.Notify.Kafka
|
|
|
|
|
}
|
|
|
|
|
if len(cv12.Notify.NATS) == 0 {
|
|
|
|
|
srvConfig.Notify.NATS = make(map[string]natsNotify)
|
|
|
|
|
srvConfig.Notify.NATS["1"] = natsNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.NATS = cv12.Notify.NATS
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// V12 will not have a webhook config. So we initialize one here.
|
|
|
|
|
srvConfig.Notify.Webhook = make(map[string]webhookNotify)
|
|
|
|
|
srvConfig.Notify.Webhook["1"] = webhookNotify{}
|
|
|
|
|
|
|
|
|
|
qc, err := quick.New(srvConfig)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("Unable to initialize the quick config. %v",
|
|
|
|
|
err)
|
|
|
|
|
}
|
|
|
|
|
|
2017-03-02 17:21:30 -05:00
|
|
|
|
configFile := getConfigFile()
|
2017-01-09 17:22:10 -05:00
|
|
|
|
err = qc.Save(configFile)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf(
|
|
|
|
|
"Failed to migrate config from ‘"+
|
|
|
|
|
cv12.Version+"’ to ‘"+srvConfig.Version+
|
|
|
|
|
"’ failed. %v", err,
|
|
|
|
|
)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
console.Println(
|
|
|
|
|
"Migration from version ‘" +
|
|
|
|
|
cv12.Version + "’ to ‘" + srvConfig.Version +
|
|
|
|
|
"’ completed successfully.",
|
|
|
|
|
)
|
|
|
|
|
return nil
|
|
|
|
|
}
|
2017-02-27 17:59:53 -05:00
|
|
|
|
|
2017-03-17 12:29:17 -04:00
|
|
|
|
// Version '13' to '14' migration. Add support for browser param.
|
2017-02-27 17:59:53 -05:00
|
|
|
|
func migrateV13ToV14() error {
|
|
|
|
|
cv13, err := loadConfigV13()
|
|
|
|
|
if err != nil {
|
|
|
|
|
if os.IsNotExist(err) {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
return fmt.Errorf("Unable to load config version ‘13’. %v", err)
|
|
|
|
|
}
|
|
|
|
|
if cv13.Version != "13" {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Copy over fields from V13 into V14 config struct
|
|
|
|
|
srvConfig := &serverConfigV14{
|
|
|
|
|
Logger: &logger{},
|
|
|
|
|
Notify: ¬ifier{},
|
|
|
|
|
}
|
|
|
|
|
srvConfig.Version = "14"
|
|
|
|
|
srvConfig.Credential = cv13.Credential
|
|
|
|
|
srvConfig.Region = cv13.Region
|
|
|
|
|
if srvConfig.Region == "" {
|
|
|
|
|
// Region needs to be set for AWS Signature Version 4.
|
|
|
|
|
srvConfig.Region = globalMinioDefaultRegion
|
|
|
|
|
}
|
|
|
|
|
srvConfig.Logger.Console = cv13.Logger.Console
|
|
|
|
|
srvConfig.Logger.File = cv13.Logger.File
|
|
|
|
|
|
|
|
|
|
// check and set notifiers config
|
|
|
|
|
if len(cv13.Notify.AMQP) == 0 {
|
|
|
|
|
srvConfig.Notify.AMQP = make(map[string]amqpNotify)
|
|
|
|
|
srvConfig.Notify.AMQP["1"] = amqpNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.AMQP = cv13.Notify.AMQP
|
|
|
|
|
}
|
|
|
|
|
if len(cv13.Notify.ElasticSearch) == 0 {
|
|
|
|
|
srvConfig.Notify.ElasticSearch = make(map[string]elasticSearchNotify)
|
|
|
|
|
srvConfig.Notify.ElasticSearch["1"] = elasticSearchNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.ElasticSearch = cv13.Notify.ElasticSearch
|
|
|
|
|
}
|
|
|
|
|
if len(cv13.Notify.Redis) == 0 {
|
|
|
|
|
srvConfig.Notify.Redis = make(map[string]redisNotify)
|
|
|
|
|
srvConfig.Notify.Redis["1"] = redisNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.Redis = cv13.Notify.Redis
|
|
|
|
|
}
|
|
|
|
|
if len(cv13.Notify.PostgreSQL) == 0 {
|
|
|
|
|
srvConfig.Notify.PostgreSQL = make(map[string]postgreSQLNotify)
|
|
|
|
|
srvConfig.Notify.PostgreSQL["1"] = postgreSQLNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.PostgreSQL = cv13.Notify.PostgreSQL
|
|
|
|
|
}
|
|
|
|
|
if len(cv13.Notify.Kafka) == 0 {
|
|
|
|
|
srvConfig.Notify.Kafka = make(map[string]kafkaNotify)
|
|
|
|
|
srvConfig.Notify.Kafka["1"] = kafkaNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.Kafka = cv13.Notify.Kafka
|
|
|
|
|
}
|
|
|
|
|
if len(cv13.Notify.NATS) == 0 {
|
|
|
|
|
srvConfig.Notify.NATS = make(map[string]natsNotify)
|
|
|
|
|
srvConfig.Notify.NATS["1"] = natsNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.NATS = cv13.Notify.NATS
|
|
|
|
|
}
|
|
|
|
|
if len(cv13.Notify.Webhook) == 0 {
|
|
|
|
|
srvConfig.Notify.Webhook = make(map[string]webhookNotify)
|
|
|
|
|
srvConfig.Notify.Webhook["1"] = webhookNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.Webhook = cv13.Notify.Webhook
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Set the new browser parameter to true by default
|
|
|
|
|
srvConfig.Browser = "on"
|
|
|
|
|
|
|
|
|
|
qc, err := quick.New(srvConfig)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("Unable to initialize the quick config. %v",
|
|
|
|
|
err)
|
|
|
|
|
}
|
|
|
|
|
|
2017-03-02 17:21:30 -05:00
|
|
|
|
configFile := getConfigFile()
|
2017-02-27 17:59:53 -05:00
|
|
|
|
err = qc.Save(configFile)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf(
|
|
|
|
|
"Failed to migrate config from ‘"+
|
|
|
|
|
cv13.Version+"’ to ‘"+srvConfig.Version+
|
|
|
|
|
"’ failed. %v", err,
|
|
|
|
|
)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
console.Println(
|
|
|
|
|
"Migration from version ‘" +
|
|
|
|
|
cv13.Version + "’ to ‘" + srvConfig.Version +
|
|
|
|
|
"’ completed successfully.",
|
|
|
|
|
)
|
|
|
|
|
return nil
|
|
|
|
|
}
|
2017-03-17 12:29:17 -04:00
|
|
|
|
|
|
|
|
|
// Version '14' to '15' migration. Add support for MySQL notifications.
|
|
|
|
|
func migrateV14ToV15() error {
|
|
|
|
|
cv14, err := loadConfigV14()
|
|
|
|
|
if err != nil {
|
|
|
|
|
if os.IsNotExist(err) {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
return fmt.Errorf("Unable to load config version ‘14’. %v", err)
|
|
|
|
|
}
|
|
|
|
|
if cv14.Version != "14" {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Copy over fields from V14 into V15 config struct
|
|
|
|
|
srvConfig := &serverConfigV15{
|
|
|
|
|
Logger: &logger{},
|
|
|
|
|
Notify: ¬ifier{},
|
|
|
|
|
}
|
|
|
|
|
srvConfig.Version = "15"
|
|
|
|
|
srvConfig.Credential = cv14.Credential
|
|
|
|
|
srvConfig.Region = cv14.Region
|
|
|
|
|
if srvConfig.Region == "" {
|
|
|
|
|
// Region needs to be set for AWS Signature Version 4.
|
|
|
|
|
srvConfig.Region = globalMinioDefaultRegion
|
|
|
|
|
}
|
|
|
|
|
srvConfig.Logger.Console = cv14.Logger.Console
|
|
|
|
|
srvConfig.Logger.File = cv14.Logger.File
|
|
|
|
|
|
|
|
|
|
// check and set notifiers config
|
|
|
|
|
if len(cv14.Notify.AMQP) == 0 {
|
|
|
|
|
srvConfig.Notify.AMQP = make(map[string]amqpNotify)
|
|
|
|
|
srvConfig.Notify.AMQP["1"] = amqpNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.AMQP = cv14.Notify.AMQP
|
|
|
|
|
}
|
|
|
|
|
if len(cv14.Notify.ElasticSearch) == 0 {
|
|
|
|
|
srvConfig.Notify.ElasticSearch = make(map[string]elasticSearchNotify)
|
|
|
|
|
srvConfig.Notify.ElasticSearch["1"] = elasticSearchNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.ElasticSearch = cv14.Notify.ElasticSearch
|
|
|
|
|
}
|
|
|
|
|
if len(cv14.Notify.Redis) == 0 {
|
|
|
|
|
srvConfig.Notify.Redis = make(map[string]redisNotify)
|
|
|
|
|
srvConfig.Notify.Redis["1"] = redisNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.Redis = cv14.Notify.Redis
|
|
|
|
|
}
|
|
|
|
|
if len(cv14.Notify.PostgreSQL) == 0 {
|
|
|
|
|
srvConfig.Notify.PostgreSQL = make(map[string]postgreSQLNotify)
|
|
|
|
|
srvConfig.Notify.PostgreSQL["1"] = postgreSQLNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.PostgreSQL = cv14.Notify.PostgreSQL
|
|
|
|
|
}
|
|
|
|
|
if len(cv14.Notify.Kafka) == 0 {
|
|
|
|
|
srvConfig.Notify.Kafka = make(map[string]kafkaNotify)
|
|
|
|
|
srvConfig.Notify.Kafka["1"] = kafkaNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.Kafka = cv14.Notify.Kafka
|
|
|
|
|
}
|
|
|
|
|
if len(cv14.Notify.NATS) == 0 {
|
|
|
|
|
srvConfig.Notify.NATS = make(map[string]natsNotify)
|
|
|
|
|
srvConfig.Notify.NATS["1"] = natsNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.NATS = cv14.Notify.NATS
|
|
|
|
|
}
|
|
|
|
|
if len(cv14.Notify.Webhook) == 0 {
|
|
|
|
|
srvConfig.Notify.Webhook = make(map[string]webhookNotify)
|
|
|
|
|
srvConfig.Notify.Webhook["1"] = webhookNotify{}
|
|
|
|
|
} else {
|
|
|
|
|
srvConfig.Notify.Webhook = cv14.Notify.Webhook
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// V14 will not have mysql support, so we add that here.
|
|
|
|
|
srvConfig.Notify.MySQL = make(map[string]mySQLNotify)
|
|
|
|
|
srvConfig.Notify.MySQL["1"] = mySQLNotify{}
|
|
|
|
|
|
|
|
|
|
// Load browser config from existing config in the file.
|
|
|
|
|
srvConfig.Browser = cv14.Browser
|
|
|
|
|
|
|
|
|
|
qc, err := quick.New(srvConfig)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("Unable to initialize the quick config. %v",
|
|
|
|
|
err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
configFile := getConfigFile()
|
|
|
|
|
err = qc.Save(configFile)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf(
|
|
|
|
|
"Failed to migrate config from ‘"+
|
|
|
|
|
cv14.Version+"’ to ‘"+srvConfig.Version+
|
|
|
|
|
"’ failed. %v", err,
|
|
|
|
|
)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
console.Println(
|
|
|
|
|
"Migration from version ‘" +
|
|
|
|
|
cv14.Version + "’ to ‘" + srvConfig.Version +
|
|
|
|
|
"’ completed successfully.",
|
|
|
|
|
)
|
|
|
|
|
return nil
|
|
|
|
|
}
|