logfilelist.go 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. /**
  2. * @Author: zou.yingbin
  3. * @Create : 2021/10/15 16:28
  4. * @Modify : 2021/10/15 16:28
  5. */
  6. package other
  7. import (
  8. "fmt"
  9. "github.com/gin-gonic/gin"
  10. "html/template"
  11. "io"
  12. "io/ioutil"
  13. "mtp2_if/config"
  14. "net/http"
  15. "regexp"
  16. "sort"
  17. "strings"
  18. )
  19. var (
  20. VERSION string
  21. GITHASH string
  22. )
  23. // LogList 列出日志文件
  24. func LogList(c *gin.Context) {
  25. host := c.Request.Host
  26. if !strings.Contains(host, "http://") {
  27. host = "http://" + host
  28. }
  29. const templateText = `
  30. <h1>go查询服务信息</h1>
  31. <a href="{{.host}}/debug/update" title="点击后从自动构建服务拉取版本升级并重启GO服务, 请谨慎点击" target="_blank">点击升级到最新版本</a>
  32. <br><br>
  33. <a href="{{.host}}/swagger/index.html" target="_blank">点击打开swagger</a>
  34. <br>
  35. <a href="{{.host}}/debug/token" title="仅当调试模式内网段才能成功设置" target="_blank">点击设置token(用于swagger查询)</a>
  36. <p>=========配置信息============</p>
  37. version : {{.version}}<br>
  38. git hash: {{.githash}}<br>
  39. oracle : {{.db}} <br>
  40. mysql : {{.mysql}} <br>
  41. redis : {{.redis}} <br>
  42. <h3>版本列表(最近5次构建)</h3>
  43. <font color="#DC143C">*** 点击版本,将升级到对应版本 ***</font>
  44. <br>
  45. {{.verlist}}
  46. <h2>日志文件列表</h2>
  47. <p>------------------------</p>
  48. {{.data}}
  49. <p>------------------------</p>
  50. `
  51. sFile := make([]string, 0)
  52. path := config.SerCfg.LogCfg.LogPath
  53. db := fmt.Sprintf("%s/***@%s:%s/%s",
  54. config.SerCfg.DbCfg.DbUser,
  55. config.SerCfg.DbCfg.DbAddress,
  56. config.SerCfg.DbCfg.DbPort,
  57. config.SerCfg.DbCfg.DbName)
  58. mysql := fmt.Sprintf("%s/***@%s:%v/%s",
  59. config.SerCfg.MySQLCfg.Username,
  60. config.SerCfg.MySQLCfg.Host,
  61. config.SerCfg.MySQLCfg.Port,
  62. config.SerCfg.MySQLCfg.DBName)
  63. redis := fmt.Sprintf("%s:%v", config.SerCfg.RedisCfg.Address, config.SerCfg.RedisCfg.Port)
  64. if d, err := ioutil.ReadDir(path); err == nil {
  65. for _, v := range d {
  66. if !v.IsDir() {
  67. lk := fmt.Sprintf(`<a href="%v/debug/download?filename=%v" target="_blank">%v</a> size:%.2f k`,
  68. host, v.Name(), v.Name(), float64(v.Size())/1024.0)
  69. lk2 := fmt.Sprintf(`<a href="%v/debug/log/view?filename=%v" target="_blank">查看</a>`, host, v.Name())
  70. lk = lk + " " + lk2
  71. sFile = append(sFile, lk)
  72. }
  73. }
  74. str := strings.Join(sFile, "\n<br>")
  75. if tmpl, err := template.New("index").Parse(templateText); err == nil {
  76. _ = tmpl.Execute(c.Writer, gin.H{"data": template.HTML(str), "db": template.HTML(db),
  77. "mysql": template.HTML(mysql), "redis": template.HTML(redis),
  78. "version": template.HTML(VERSION), "githash": template.HTML(GITHASH), "verlist": template.HTML(GetVerlist(host))})
  79. } else {
  80. c.String(400, "index err.")
  81. }
  82. } else {
  83. c.JSON(http.StatusBadRequest, gin.H{"message": "can't list the file"})
  84. }
  85. }
  86. // GetVerlist 获取版本列表(含html标记)
  87. func GetVerlist(host string) string {
  88. var strVerList string
  89. url := `http://192.168.30.153/share/build/mtp2.0_release/`
  90. if rsp, err := http.Get(url); err == nil {
  91. if body, err2 := io.ReadAll(rsp.Body); err2 == nil {
  92. strContext := string(body)
  93. rx := regexp.MustCompile(`mtp2_queryservice_r[\d_]*\.zip`)
  94. names := rx.FindAllStringSubmatch(strContext, -1)
  95. mapName := make(map[string]string, 0)
  96. for _, v := range names {
  97. for _, d := range v {
  98. mapName[d] = url + d
  99. }
  100. }
  101. sName := make([]string, 0)
  102. for k, _ := range mapName {
  103. sName = append(sName, k)
  104. }
  105. // 按日期排序
  106. sort.Slice(sName, func(i, j int) bool {
  107. return sName[i] > sName[j]
  108. })
  109. for i := range sName {
  110. strVerList += fmt.Sprintf(`<a href="%v/debug/update?filename=%v" target="_blank">%v</a>`, host, sName[i], sName[i]) + "<br>"
  111. // 取最近n条
  112. if i > 5 {
  113. break
  114. }
  115. }
  116. } else {
  117. fmt.Println("can't read body")
  118. }
  119. rsp.Body.Close()
  120. } else {
  121. fmt.Println("can't get url.")
  122. }
  123. return strVerList
  124. }