conf_util.go 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. package main
  2. import (
  3. "fmt"
  4. "github.com/go-yaml/yaml"
  5. "io/ioutil"
  6. "os"
  7. "strconv"
  8. "strings"
  9. )
  10. var khome = os.Getenv("KUIPER_HOME")
  11. var fileMap = map[string]string{
  12. "edgex": khome + "/etc/sources/edgex.yaml",
  13. "random": khome + "/etc/sources/random.yaml",
  14. "zmq": khome + "/etc/sources/zmq.yaml",
  15. "mqtt_source": khome + "/etc/mqtt_source.yaml",
  16. "kuiper": khome + "/etc/kuiper.yaml",
  17. "client": khome + "/etc/client.yaml",
  18. }
  19. var file_keys_map = map[string]map[string]string{
  20. "edgex": {
  21. "SERVICESERVER": "serviceServer",
  22. "CLIENTID": "ClientId",
  23. "USERNAME": "Username",
  24. "PASSWORD": "Password",
  25. "QOS": "Qos",
  26. "KEEPALIVE": "KeepAlive",
  27. "RETAINED": "Retained",
  28. "CONNECTIONPAYLOAD": "ConnectionPayload",
  29. "CERTFILE": "CertFile",
  30. "KEYFILE": "KeyFile",
  31. "CERTPEMBLOCK": "CertPEMBlock",
  32. "KEYPEMBLOCK": "KeyPEMBlock",
  33. "SKIPCERTVERIFY": "SkipCertVerify",
  34. },
  35. "mqtt_source": {
  36. "SHAREDSUBSCRIPTION": "sharedSubscription",
  37. "CERTIFICATIONPATH": "certificationPath",
  38. "PRIVATEKEYPATH": "privateKeyPath",
  39. },
  40. "kuiper": {
  41. "CONSOLELOG": "consoleLog",
  42. "FILELOG": "fileLog",
  43. "RESTPORT": "restPort",
  44. "RESTTLS": "restTls",
  45. "PROMETHEUSPORT": "prometheusPort",
  46. "PLUGINHOSTS": "pluginHosts",
  47. "CHECKPOINTINTERVAL": "checkpointInterval",
  48. "CACHETHRESHOLD": "cacheThreshold",
  49. "CACHETRIGGERCOUNT": "cacheTriggerCount",
  50. "DISABLECACHE": "disableCache",
  51. },
  52. }
  53. func fileExists(filename string) bool {
  54. info, err := os.Stat(filename)
  55. if os.IsNotExist(err) {
  56. return false
  57. }
  58. return !info.IsDir()
  59. }
  60. func deleteFile(path string) {
  61. // delete file
  62. var err = os.Remove(path)
  63. if err != nil {
  64. fmt.Printf("Failed to delete original file: %s due to error %s... The conf util is going to exit.\n", path, err)
  65. os.Exit(0)
  66. return
  67. }
  68. fmt.Println("File Deleted")
  69. }
  70. func main() {
  71. fmt.Println(fileMap["edgex"])
  72. files := make(map[string]map[interface{}]interface{})
  73. ProcessEnv(files, os.Environ())
  74. for f, v := range files {
  75. if bs, err := yaml.Marshal(v); err != nil {
  76. fmt.Println(err)
  77. } else {
  78. message := fmt.Sprintf("-------------------\nConf file %s: \n %s", f, string(bs))
  79. fmt.Println(message)
  80. if fname, ok := fileMap[f]; ok {
  81. if fileExists(fname) {
  82. deleteFile(fname)
  83. }
  84. if e := ioutil.WriteFile(fname, bs, 0644); e != nil {
  85. fmt.Println(e)
  86. }
  87. }
  88. }
  89. }
  90. }
  91. func ProcessEnv(files map[string]map[interface{}]interface{}, vars []string) {
  92. for _, e := range vars {
  93. pair := strings.SplitN(e, "=", 2)
  94. if len(pair) != 2 {
  95. fmt.Printf("invalid env %s, skip it.\n", e)
  96. continue
  97. }
  98. valid := false
  99. for k, _ := range fileMap {
  100. if strings.HasPrefix(pair[0], strings.ToUpper(k)) {
  101. valid = true
  102. break
  103. }
  104. }
  105. if !valid {
  106. continue
  107. } else {
  108. fmt.Printf("Find env: %s, start to handle it.\n", e)
  109. }
  110. env_v := strings.ReplaceAll(pair[0], "__", ".")
  111. keys := strings.Split(env_v, ".")
  112. for i, v := range keys {
  113. keys[i] = v
  114. }
  115. if len(keys) < 2 {
  116. fmt.Printf("not concerned env %s, skip it.\n", e)
  117. continue
  118. } else {
  119. k := strings.ToLower(keys[0])
  120. if v, ok := files[k]; !ok {
  121. if data, err := ioutil.ReadFile(fileMap[k]); err != nil {
  122. fmt.Printf("%s\n", err)
  123. } else {
  124. m := make(map[interface{}]interface{})
  125. err = yaml.Unmarshal([]byte(data), &m)
  126. if err != nil {
  127. fmt.Println(err)
  128. }
  129. files[k] = m
  130. Handle(k, m, keys[1:], pair[1])
  131. }
  132. } else {
  133. Handle(k, v, keys[1:], pair[1])
  134. }
  135. }
  136. }
  137. }
  138. func Handle(file string, conf map[interface{}]interface{}, skeys []string, val string) {
  139. key := getKey(file, skeys[0])
  140. if len(skeys) == 1 {
  141. conf[key] = getValueType(val)
  142. } else if len(skeys) >= 2 {
  143. if v, ok := conf[key]; ok {
  144. if v1, ok1 := v.(map[interface{}]interface{}); ok1 {
  145. Handle(file, v1, skeys[1:], val)
  146. } else {
  147. fmt.Printf("Not expected map: %v\n", v)
  148. }
  149. } else {
  150. v1 := make(map[interface{}]interface{})
  151. conf[key] = v1
  152. Handle(file, v1, skeys[1:], val)
  153. }
  154. }
  155. }
  156. func getKey(file string, key string) string {
  157. if m, ok := file_keys_map[file][key]; ok {
  158. return m
  159. } else {
  160. return strings.ToLower(key)
  161. }
  162. }
  163. func getValueType(val string) interface{} {
  164. if i, err := strconv.ParseInt(val, 10, 64); err == nil {
  165. return i
  166. } else if b, err := strconv.ParseBool(val); err == nil {
  167. return b
  168. } else if f, err := strconv.ParseFloat(val, 64); err == nil {
  169. return f
  170. }
  171. return val
  172. }