2014-04-26 09:18:56 +00:00
|
|
|
package Configuration
|
|
|
|
|
2014-10-19 17:19:11 +00:00
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
"github.com/SommerEngineering/Ocean/Log"
|
|
|
|
"github.com/SommerEngineering/Ocean/Log/Meta"
|
|
|
|
"os"
|
|
|
|
"path/filepath"
|
|
|
|
)
|
2014-04-26 09:18:56 +00:00
|
|
|
|
2015-06-17 15:44:52 +00:00
|
|
|
// Function to read the configuration file.
|
2014-04-26 09:18:56 +00:00
|
|
|
func readConfiguration() {
|
|
|
|
if isInit {
|
|
|
|
Log.LogFull(senderName, Meta.CategorySYSTEM, Meta.LevelWARN, Meta.SeverityNone, Meta.ImpactNone, Meta.MessageNameINIT, `The configuration package is already init!`)
|
|
|
|
return
|
|
|
|
} else {
|
|
|
|
Log.LogShort(senderName, Meta.CategorySYSTEM, Meta.LevelINFO, Meta.MessageNameCONFIGURATION, `Init of configuration starting.`)
|
|
|
|
}
|
|
|
|
|
2015-06-17 15:44:52 +00:00
|
|
|
// Access to the working directory?
|
2014-04-26 09:18:56 +00:00
|
|
|
currentDir, dirError := os.Getwd()
|
|
|
|
if dirError != nil {
|
|
|
|
panic(`Was not able to read the working directory: ` + dirError.Error())
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2015-06-17 15:44:52 +00:00
|
|
|
// Access to the configuration file?
|
2014-04-26 09:18:56 +00:00
|
|
|
currentPath := filepath.Join(currentDir, filename)
|
|
|
|
if _, errFile := os.Stat(currentPath); errFile != nil {
|
|
|
|
if os.IsNotExist(errFile) {
|
|
|
|
panic(`It was not possible to find the necessary configuration file 'configuration.json' at the application directory.`)
|
|
|
|
} else {
|
|
|
|
panic(`There was an error while open the configuration: ` + errFile.Error())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-06-17 15:44:52 +00:00
|
|
|
// Open the file:
|
2014-04-26 09:18:56 +00:00
|
|
|
file, fileError := os.Open(currentPath)
|
|
|
|
defer file.Close()
|
|
|
|
|
|
|
|
if fileError != nil {
|
|
|
|
panic(`The configuration file is not accessible: ` + fileError.Error())
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2015-06-17 15:44:52 +00:00
|
|
|
// Try to decode / parse the file:
|
2014-04-26 09:18:56 +00:00
|
|
|
decoder := json.NewDecoder(file)
|
|
|
|
decError := decoder.Decode(&configuration)
|
|
|
|
|
|
|
|
if decError != nil {
|
|
|
|
panic(`Decoding of the configuration file was not possible: ` + decError.Error())
|
|
|
|
}
|
|
|
|
|
|
|
|
Log.LogShort(senderName, Meta.CategorySYSTEM, Meta.LevelINFO, Meta.MessageNameINIT, `Init of configuration is done.`)
|
|
|
|
isInit = true
|
|
|
|
return
|
|
|
|
}
|