conf_util.go 4.8 KB

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