+func (r *Router) CollectDefaultSymptomData(fileName string, data interface{}) string {
+ baseDir := Config.GetString("controls.symptomdata.baseDir")
+ if baseDir == "" {
+ baseDir = "/tmp/xapp/"
+ }
+
+ if err := Util.CreateDir(baseDir); err != nil {
+ Logger.Error("CreateDir failed: %v", err)
+ return ""
+ }
+
+ //
+ // Collect some general information into one file
+ //
+ var lines []string
+
+ // uptime
+ d := XappUpTime()
+ h := d / time.Hour
+ d -= h * time.Hour
+ m := d / time.Minute
+ d -= m * time.Minute
+ s := d / time.Second
+ lines = append(lines, fmt.Sprintf("uptime: %02d:%02d:%02d", h, m, s))
+
+ Util.WriteToFile(baseDir+"information.txt", strings.Join(lines, "\n"))
+
+ //
+ // Collect metrics
+ //
+ if metrics, err := r.GetLocalMetrics(); err == nil {
+ if err := Util.WriteToFile(baseDir+"metrics.json", metrics); err != nil {
+ Logger.Error("writeToFile failed for metrics.json: %v", err)
+ }
+ }
+
+ //
+ // Collect currently used config file
+ //
+ cfile := viper.ConfigFileUsed()
+ input, err := ioutil.ReadFile(cfile)
+ if err == nil {
+ Util.WriteToFile(baseDir+path.Base(cfile), string(input))
+ } else {
+ Logger.Error("ioutil.ReadFile failed: %v", err)
+ }
+
+ //
+ // Collect environment
+ //
+ Util.WriteToFile(baseDir+"environment.txt", strings.Join(os.Environ(), "\n"))
+
+ //
+ // Collect RMR rt table
+ //
+ rtPath := os.Getenv("RMR_STASH_RT")
+ if rtPath != "" {
+ input, err = ioutil.ReadFile(rtPath)
+ if err == nil {
+ Util.WriteToFile(baseDir+"rttable.txt", string(input))
+ } else {
+ Logger.Error("ioutil.ReadFile failed: %v", err)
+ }
+ }
+
+ //
+ // Put data that was provided as argument
+ //
+ if data != nil {
+ if b, err := json.MarshalIndent(data, "", " "); err == nil {
+ Util.WriteToFile(baseDir+fileName, string(b))
+ }
+ }
+
+ return baseDir
+}
+