table_row.go 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304
  1. package client
  2. import (
  3. "errors"
  4. "git.sxidc.com/service-supports/dps-sdk/pb/v1/request"
  5. "git.sxidc.com/service-supports/dps-sdk/pb/v1/response"
  6. "reflect"
  7. "strings"
  8. "time"
  9. )
  10. type TableRow struct {
  11. row map[string]any
  12. }
  13. func NewTableRow() *TableRow {
  14. return &TableRow{row: make(map[string]any)}
  15. }
  16. func (tableRow *TableRow) AddColumnValueTime(columnName string, value time.Time) *TableRow {
  17. tableRow.row[columnName] = value
  18. return tableRow
  19. }
  20. func (tableRow *TableRow) AddColumnValueBool(columnName string, value bool) *TableRow {
  21. tableRow.row[columnName] = value
  22. return tableRow
  23. }
  24. func (tableRow *TableRow) AddColumnValueString(columnName string, value string) *TableRow {
  25. tableRow.row[columnName] = value
  26. return tableRow
  27. }
  28. func (tableRow *TableRow) AddColumnValueInt(columnName string, value int) *TableRow {
  29. tableRow.row[columnName] = uint64(value)
  30. return tableRow
  31. }
  32. func (tableRow *TableRow) AddColumnValueInt8(columnName string, value int8) *TableRow {
  33. tableRow.row[columnName] = uint64(value)
  34. return tableRow
  35. }
  36. func (tableRow *TableRow) AddColumnValueInt16(columnName string, value int16) *TableRow {
  37. tableRow.row[columnName] = uint64(value)
  38. return tableRow
  39. }
  40. func (tableRow *TableRow) AddColumnValueInt32(columnName string, value int32) *TableRow {
  41. tableRow.row[columnName] = uint64(value)
  42. return tableRow
  43. }
  44. func (tableRow *TableRow) AddColumnValueInt64(columnName string, value int64) *TableRow {
  45. tableRow.row[columnName] = uint64(value)
  46. return tableRow
  47. }
  48. func (tableRow *TableRow) AddColumnValueUint(columnName string, value uint) *TableRow {
  49. tableRow.row[columnName] = uint64(value)
  50. return tableRow
  51. }
  52. func (tableRow *TableRow) AddColumnValueUint8(columnName string, value uint8) *TableRow {
  53. tableRow.row[columnName] = uint64(value)
  54. return tableRow
  55. }
  56. func (tableRow *TableRow) AddColumnValueUint16(columnName string, value uint16) *TableRow {
  57. tableRow.row[columnName] = uint64(value)
  58. return tableRow
  59. }
  60. func (tableRow *TableRow) AddColumnValueUint32(columnName string, value uint32) *TableRow {
  61. tableRow.row[columnName] = uint64(value)
  62. return tableRow
  63. }
  64. func (tableRow *TableRow) AddColumnValueUint64(columnName string, value uint64) *TableRow {
  65. tableRow.row[columnName] = value
  66. return tableRow
  67. }
  68. func (tableRow *TableRow) AddColumnValueFloat32(columnName string, value float32) *TableRow {
  69. tableRow.row[columnName] = float64(value)
  70. return tableRow
  71. }
  72. func (tableRow *TableRow) AddColumnValueFloat64(columnName string, value float64) *TableRow {
  73. tableRow.row[columnName] = value
  74. return tableRow
  75. }
  76. func (tableRow *TableRow) ColumnValueTime(columnName string) time.Time {
  77. value, ok := tableRow.row[columnName].(time.Time)
  78. if !ok {
  79. return time.Time{}
  80. }
  81. return value
  82. }
  83. func (tableRow *TableRow) ColumnValueBool(columnName string) bool {
  84. value, ok := tableRow.row[columnName].(bool)
  85. if !ok {
  86. return false
  87. }
  88. return value
  89. }
  90. func (tableRow *TableRow) ColumnValueString(columnName string) string {
  91. value, ok := tableRow.row[columnName].(string)
  92. if !ok {
  93. return ""
  94. }
  95. return value
  96. }
  97. func (tableRow *TableRow) ColumnValueInt(columnName string) int {
  98. value, ok := tableRow.row[columnName].(uint64)
  99. if !ok {
  100. return 0
  101. }
  102. return int(value)
  103. }
  104. func (tableRow *TableRow) ColumnValueInt8(columnName string) int8 {
  105. value, ok := tableRow.row[columnName].(uint64)
  106. if !ok {
  107. return 0
  108. }
  109. return int8(value)
  110. }
  111. func (tableRow *TableRow) ColumnValueInt16(columnName string) int16 {
  112. value, ok := tableRow.row[columnName].(uint64)
  113. if !ok {
  114. return 0
  115. }
  116. return int16(value)
  117. }
  118. func (tableRow *TableRow) ColumnValueInt32(columnName string) int32 {
  119. value, ok := tableRow.row[columnName].(uint64)
  120. if !ok {
  121. return 0
  122. }
  123. return int32(value)
  124. }
  125. func (tableRow *TableRow) ColumnValueInt64(columnName string) int64 {
  126. value, ok := tableRow.row[columnName].(uint64)
  127. if !ok {
  128. return 0
  129. }
  130. return int64(value)
  131. }
  132. func (tableRow *TableRow) ColumnValueUint(columnName string) uint {
  133. value, ok := tableRow.row[columnName].(uint64)
  134. if !ok {
  135. return 0
  136. }
  137. return uint(value)
  138. }
  139. func (tableRow *TableRow) ColumnValueUint8(columnName string) uint8 {
  140. value, ok := tableRow.row[columnName].(uint64)
  141. if !ok {
  142. return 0
  143. }
  144. return uint8(value)
  145. }
  146. func (tableRow *TableRow) ColumnValueUint16(columnName string) uint16 {
  147. value, ok := tableRow.row[columnName].(uint64)
  148. if !ok {
  149. return 0
  150. }
  151. return uint16(value)
  152. }
  153. func (tableRow *TableRow) ColumnValueUint32(columnName string) uint32 {
  154. value, ok := tableRow.row[columnName].(uint64)
  155. if !ok {
  156. return 0
  157. }
  158. return uint32(value)
  159. }
  160. func (tableRow *TableRow) ColumnValueUint64(columnName string) uint64 {
  161. value, ok := tableRow.row[columnName].(uint64)
  162. if !ok {
  163. return 0
  164. }
  165. return value
  166. }
  167. func (tableRow *TableRow) ColumnValueFloat32(columnName string) float32 {
  168. value, ok := tableRow.row[columnName].(float64)
  169. if !ok {
  170. return 0
  171. }
  172. return float32(value)
  173. }
  174. func (tableRow *TableRow) ColumnValueFloat64(columnName string) float64 {
  175. value, ok := tableRow.row[columnName].(float64)
  176. if !ok {
  177. return 0
  178. }
  179. return value
  180. }
  181. func (tableRow *TableRow) ToDPSTableRow() (*request.TableRow, error) {
  182. if tableRow.row == nil || len(tableRow.row) == 0 {
  183. return &request.TableRow{Columns: make([]*request.Column, 0)}, nil
  184. }
  185. columns := make([]*request.Column, 0)
  186. for columnName, value := range tableRow.row {
  187. valueType := reflect.TypeOf(value)
  188. typedValue := new(request.ColumnValue)
  189. typedValue.Type = valueType.Name()
  190. switch valueType.Name() {
  191. case "Time":
  192. timeObj := value.(time.Time)
  193. typedValue.TypedValue = &request.ColumnValue_Uint64Value{Uint64Value: uint64(timeObj.Unix())}
  194. case "string":
  195. typedValue.TypedValue = &request.ColumnValue_StringValue{StringValue: value.(string)}
  196. case "bool":
  197. typedValue.TypedValue = &request.ColumnValue_BoolValue{BoolValue: value.(bool)}
  198. case "uint64":
  199. typedValue.TypedValue = &request.ColumnValue_Uint64Value{Uint64Value: value.(uint64)}
  200. case "float64":
  201. typedValue.TypedValue = &request.ColumnValue_Float64Value{Float64Value: value.(float64)}
  202. default:
  203. return nil, errors.New("不支持的数据类型" + valueType.Name())
  204. }
  205. columns = append(columns, &request.Column{
  206. Name: columnName,
  207. Value: typedValue,
  208. })
  209. }
  210. return &request.TableRow{Columns: columns}, nil
  211. }
  212. func (tableRow *TableRow) FromDSPInfoData(infoData *response.InfoData) error {
  213. for _, column := range infoData.Columns {
  214. typeStr := column.Value.Type
  215. if typeStr == "Time" {
  216. timeObj := time.Unix(int64(column.Value.GetUint64Value()), 0)
  217. tableRow.row[column.Name] = timeObj
  218. } else if typeStr == "string" {
  219. tableRow.row[column.Name] = column.Value.GetStringValue()
  220. } else if typeStr == "bool" {
  221. tableRow.row[column.Name] = column.Value.GetBoolValue()
  222. } else if strings.Contains(typeStr, "int") {
  223. tableRow.row[column.Name] = column.Value.GetUint64Value()
  224. } else if strings.Contains(typeStr, "float") {
  225. tableRow.row[column.Name] = column.Value.GetFloat64Value()
  226. } else {
  227. return errors.New("不支持的数据类型" + column.Value.Type)
  228. }
  229. }
  230. return nil
  231. }
  232. func FromDSPInfosData(infosData []*response.InfoData) ([]TableRow, error) {
  233. tableRows := make([]TableRow, 0)
  234. for _, infoData := range infosData {
  235. tableRow := NewTableRow()
  236. err := tableRow.FromDSPInfoData(infoData)
  237. if err != nil {
  238. return nil, err
  239. }
  240. tableRows = append(tableRows, *tableRow)
  241. }
  242. return tableRows, nil
  243. }