edb_terminal.go 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246
  1. package data_manage
  2. import (
  3. "eta/eta_api/global"
  4. "eta/eta_api/utils"
  5. "fmt"
  6. "gorm.io/gorm"
  7. "time"
  8. )
  9. // EdbTerminal 指标终端
  10. type EdbTerminal struct {
  11. TerminalId int `orm:"column(terminal_id);pk" gorm:"primaryKey"`
  12. Source int `orm:"column(source)" description:"指标来源类型"`
  13. Name string `description:"终端名称"`
  14. TerminalCode string `description:"终端编码,用于配置在机器上"`
  15. ServerUrl string `description:"终端地址"`
  16. DirPath string `description:"终端存放的文件夹路径"`
  17. Num int `description:"终端最大指标数"`
  18. Status int `description:"状态,1启用,2禁用"`
  19. Value string `description:"终端相关的token"`
  20. ModifyTime time.Time `description:"修改时间"`
  21. CreateTime time.Time `description:"创建时间"`
  22. AccountQuota string `description:"账号额度"`
  23. IsApi int8 `description:"获取类型(1,接口类型,0终端类型)"`
  24. }
  25. type EdbTerminalItem struct {
  26. TerminalId int `orm:"column(terminal_id);pk" gorm:"primaryKey"`
  27. Source int `description:"指标来源类型"`
  28. SourceName string `description:"数据源类型名称"`
  29. Name string `description:"终端别名"`
  30. TerminalCode string `description:"终端编码,用于配置在机器上"`
  31. ServerUrl string `description:"终端地址"`
  32. DirPath string `description:"终端存放的文件夹路径"`
  33. Num int `description:"终端最大指标数"`
  34. Status int `description:"状态,1启用,2禁用"`
  35. Value string `description:"终端相关的token"`
  36. ModifyTime string `description:"修改时间"`
  37. CreateTime string `description:"创建时间"`
  38. AccountQuota string `description:"账号额度"`
  39. IsApi int8 `description:"获取类型(1,接口类型,0终端类型)"`
  40. UsedQuota string `description:"已使用额度"`
  41. }
  42. func (e *EdbTerminalItem) AfterFind(db *gorm.DB) (err error) {
  43. e.ModifyTime = utils.GormDateStrToDateTimeStr(e.ModifyTime)
  44. e.CreateTime = utils.GormDateStrToDateTimeStr(e.CreateTime)
  45. return
  46. }
  47. type EdbTerminalCode struct {
  48. TerminalCode string `description:"终端编码,用于配置在机器上"`
  49. Source int `description:"指标来源类型"`
  50. Name string `description:"终端别名"`
  51. }
  52. // GetEdbTerminalListBySource 根据指标来源类型获取所有的终端列表
  53. func GetEdbTerminalListBySource(source int) (items []*EdbTerminal, err error) {
  54. o := global.DbMap[utils.DbNameIndex]
  55. sql := ` SELECT * FROM edb_terminal WHERE source = ? and status=1 ORDER BY terminal_id ASC `
  56. err = o.Raw(sql, source).Find(&items).Error
  57. return
  58. }
  59. type BaseIndexTerminalCode struct {
  60. TerminalCode string `description:"终端编码,用于配置在机器上"`
  61. IndexName string
  62. }
  63. type EdbTerminalListResp struct {
  64. List []*EdbTerminalItem `description:"列表数据"`
  65. }
  66. type EdbTerminalCodeResp struct {
  67. List []*EdbTerminalCode `description:"终端编码列表"`
  68. }
  69. type AddEdbTerminalListReq struct {
  70. TerminalId int `description:"终端id"`
  71. Source int `description:"指标来源类型"`
  72. Name string `description:"终端别名"`
  73. //TerminalCode string `description:"终端编码,用于配置在机器上"`
  74. ServerUrl string `description:"终端地址"`
  75. DirPath string `description:"终端存放的文件夹路径"`
  76. Num int `description:"终端最大指标数"`
  77. //Status int `description:"状态,1启用,2禁用"`
  78. Value string `description:"终端相关的token"`
  79. AccountQuota string `description:"账号额度"`
  80. IsApi int8 `description:"获取类型(1,接口类型,0终端类型)"`
  81. }
  82. type SetEdbTerminalStatusReq struct {
  83. TerminalId int `description:"终端id"`
  84. Status int `description:"状态,1启用,2禁用"`
  85. }
  86. // GetBaseIndexTerminalCode 获取数据源的终端code
  87. func GetBaseIndexTerminalCode(edbCode, tableName string) (item BaseIndexTerminalCode, err error) {
  88. o := global.DbMap[utils.DbNameIndex]
  89. sql := fmt.Sprintf(`select terminal_code, index_name from %s where index_code = ? `, tableName)
  90. err = o.Raw(sql, edbCode).First(&item).Error
  91. return
  92. }
  93. // GetEdbTerminalById 主键获取终端
  94. func GetEdbTerminalById(id int) (item *EdbTerminal, err error) {
  95. o := global.DbMap[utils.DbNameIndex]
  96. sql := `SELECT * FROM edb_terminal WHERE terminal_id = ? LIMIT 1`
  97. err = o.Raw(sql, id).First(&item).Error
  98. return
  99. }
  100. func GetEdbTerminalByTerminalCode(terminalCode string) (item *EdbTerminal, err error) {
  101. o := global.DbMap[utils.DbNameIndex]
  102. sql := `SELECT * FROM edb_terminal WHERE terminal_code = ? LIMIT 1`
  103. err = o.Raw(sql, terminalCode).First(&item).Error
  104. return
  105. }
  106. func GetEdbTerminalList(source int) (item []*EdbTerminalItem, err error) {
  107. o := global.DbMap[utils.DbNameIndex]
  108. var sql string
  109. if source == 0 {
  110. sql = ` SELECT t.*, s.source_name FROM edb_terminal t left join edb_source s on t.source = s.edb_source_id ORDER BY terminal_id ASC`
  111. err = o.Raw(sql).Find(&item).Error
  112. } else {
  113. sql = ` SELECT t.*, s.source_name FROM edb_terminal t left join edb_source s on t.source = s.edb_source_id WHERE t.source = ? ORDER BY terminal_id ASC`
  114. err = o.Raw(sql, source).Find(&item).Error
  115. }
  116. return
  117. }
  118. func GetEdbTerminalBySourceAndIsApi(source int, isApi int) (item []*EdbTerminalItem, err error) {
  119. o := global.DbMap[utils.DbNameIndex]
  120. sql := ` SELECT * FROM edb_terminal where source=? and is_api=? ORDER BY terminal_id ASC`
  121. err = o.Raw(sql, source, isApi).Find(&item).Error
  122. return
  123. }
  124. func (item *EdbTerminal) Add() (err error) {
  125. o := global.DbMap[utils.DbNameIndex]
  126. err = o.Create(item).Error
  127. return
  128. }
  129. func (item *EdbTerminal) Update(cols []string) (err error) {
  130. o := global.DbMap[utils.DbNameIndex]
  131. err = o.Model(item).Select(cols).Updates(item).Error
  132. return
  133. }
  134. // GetEdbTerminalByCode 根据终端编码获取终端信息
  135. func GetEdbTerminalByCode(terminalCode string) (item *EdbTerminal, err error) {
  136. o := global.DbMap[utils.DbNameIndex]
  137. sql := ` SELECT * FROM edb_terminal WHERE terminal_code = ? `
  138. err = o.Raw(sql, terminalCode).First(&item).Error
  139. return
  140. }
  141. type TerminalCodeCountGroup struct {
  142. TerminalCode string
  143. Total int
  144. }
  145. // GetEdbCountGroupByTerminal 获取终端code分组总数
  146. func GetEdbCountGroupByTerminal(source int) (list []TerminalCodeCountGroup, err error) {
  147. o := global.DbMap[utils.DbNameIndex]
  148. sql := `select terminal_code,count(1) total from edb_info where source = ? AND no_update=0 AND terminal_code != "" group by terminal_code; `
  149. err = o.Raw(sql, source).Find(&list).Error
  150. return
  151. }
  152. // EdbTerminalDirInfo 指标终端文件夹信息
  153. type EdbTerminalDirInfo struct {
  154. Name string `description:"终端名称"`
  155. TerminalCode string `description:"终端编码,用于配置在机器上"`
  156. DirPath string `description:"终端存放的文件夹路径"`
  157. FilePath string `description:"文件夹路径"`
  158. }
  159. type EdbInfoTerminalList struct {
  160. EdbInfoId int `gorm:"column:edb_info_id"`
  161. EdbCode string `gorm:"column:edb_code"`
  162. EdbName string `gorm:"column:edb_name"`
  163. TerminalCode string `gorm:"column:terminal_code"`
  164. TerminalName string `gorm:"column:terminal_name"`
  165. }
  166. func GetSimpleEdbListPageByCondition(condition string, pars []interface{}, pageIndex int, pageSize int) (list []*EdbInfoTerminalList, err error) {
  167. sql := `SELECT e.*, t.name as terminal_name FROM edb_info e left join edb_terminal t on e.terminal_code = t.terminal_code WHERE 1=1 ` + condition + ` ORDER BY e.edb_info_id ASC LIMIT ?, ?`
  168. err = global.DbMap[utils.DbNameIndex].Raw(sql, append(pars, pageIndex, pageSize)...).Find(&list).Error
  169. return
  170. }
  171. func GetSimpleEdbListCountByCondition(condition string, pars []interface{}) (count int64, err error) {
  172. sql := `SELECT COUNT(*) FROM edb_info e left join edb_terminal t on e.terminal_code = t.terminal_code WHERE 1=1 ` + condition
  173. err = global.DbMap[utils.DbNameIndex].Raw(sql, pars...).Count(&count).Error
  174. return
  175. }
  176. type SetEdbInfoTerminalReq struct {
  177. EdbInfoIds []int `description:"指标ID"`
  178. TerminalCode string `description:"要更换的终端编码"`
  179. Source int `description:"指标来源类型"`
  180. }
  181. func UpdateEdbInfoTerminal(edbInfoIds []int, terminalCode string, source int) (err error) {
  182. o := global.DbMap[utils.DbNameIndex]
  183. err = o.Exec("UPDATE edb_info SET terminal_code = ? WHERE edb_info_id IN (?) AND source = ?", terminalCode, edbInfoIds, source).Error
  184. return
  185. }
  186. type IndexNumBySource struct {
  187. SubSource int
  188. Num int
  189. }
  190. func GetIndexNumBySource(source int, terminalCode string) (num int, list []*IndexNumBySource, err error) {
  191. o := global.DbMap[utils.DbNameIndex]
  192. tableName := EdbSourceIdMap[source].IndexTableName
  193. var pars []interface{}
  194. if tableName != "" {
  195. sql := fmt.Sprintf(`SELECT COUNT(*) FROM %s WHERE terminal_code = ?`, tableName)
  196. pars = append(pars, terminalCode)
  197. err = o.Raw(sql, pars...).Scan(&num).Error
  198. return
  199. } else {
  200. sql := `SELECT COUNT(*) as num, sub_source FROM edb_info WHERE terminal_code = ? and source = ? group by sub_source`
  201. pars = append(pars, terminalCode, source)
  202. err = o.Raw(sql, pars...).Find(&list).Error
  203. return
  204. }
  205. }
  206. // 根据source和is_api获取终端编码
  207. func GetTerminalCodeBySourceAndIsApi(source int, isApi int) (terminalCode []string, err error) {
  208. o := global.DbMap[utils.DbNameIndex]
  209. sql := `SELECT terminal_code FROM edb_terminal WHERE source = ? AND is_api = ?`
  210. err = o.Raw(sql, source, isApi).Find(&terminalCode).Error
  211. return
  212. }