No puede seleccionar más de 25 temas Los temas deben comenzar con una letra o número, pueden incluir guiones ('-') y pueden tener hasta 35 caracteres de largo.
 
 
 
 

97 líneas
2.4 KiB

  1. package apiclient
  2. import (
  3. "context"
  4. "crypto/tls"
  5. "fmt"
  6. "log/slog"
  7. "net/http"
  8. "reflect"
  9. "github.com/AFASystems/presence/internal/pkg/common/appcontext"
  10. "github.com/AFASystems/presence/internal/pkg/config"
  11. "github.com/AFASystems/presence/internal/pkg/controller"
  12. "github.com/AFASystems/presence/internal/pkg/model"
  13. "github.com/segmentio/kafka-go"
  14. "gorm.io/gorm"
  15. "gorm.io/gorm/clause"
  16. )
  17. func UpdateDB(db *gorm.DB, ctx context.Context, cfg *config.Config, writer *kafka.Writer, appState *appcontext.AppState) error {
  18. tr := &http.Transport{
  19. TLSClientConfig: &tls.Config{InsecureSkipVerify: true},
  20. }
  21. client := &http.Client{Transport: tr}
  22. token, err := GetToken(ctx, cfg, client)
  23. if err != nil {
  24. return err
  25. }
  26. if trackers, err := GetTrackers(token, client, cfg); err == nil {
  27. syncTable(db, trackers)
  28. if err := controller.SendKafkaMessage(writer, &model.ApiUpdate{Method: "DELETE", MAC: "all"}, ctx); err != nil {
  29. slog.Error("Error in sending delete all from lookup message", "error", err)
  30. }
  31. for _, v := range trackers {
  32. apiUpdate := model.ApiUpdate{
  33. Method: "POST",
  34. ID: v.ID,
  35. MAC: v.MAC,
  36. }
  37. if err := controller.SendKafkaMessage(writer, &apiUpdate, ctx); err != nil {
  38. msg := fmt.Sprintf("Error in sending POST kafka message: %v", err)
  39. slog.Error(msg)
  40. }
  41. }
  42. }
  43. if gateways, err := GetGateways(token, client, cfg); err == nil {
  44. syncTable(db, gateways)
  45. }
  46. if zones, err := GetZones(token, client, cfg); err == nil {
  47. syncTable(db, zones)
  48. }
  49. if trackerZones, err := GetTrackerZones(token, client, cfg); err == nil {
  50. syncTable(db, trackerZones)
  51. }
  52. if inferredPosition, err := InferPosition(token, client, cfg); err == nil {
  53. for _, v := range inferredPosition.Items {
  54. mac := convertMac(v.Mac)
  55. db.Model(&model.Tracker{}).Where("mac = ?", mac).Update("x", v.X).Update("y", v.Y)
  56. }
  57. }
  58. var settings appcontext.Settings
  59. db.First(&settings)
  60. if settings.ID == 0 {
  61. msg := "settings are empty"
  62. slog.Info(msg)
  63. db.Create(appState.GetSettings())
  64. }
  65. return nil
  66. }
  67. func syncTable[T any](db *gorm.DB, data []T) {
  68. if len(data) == 0 {
  69. return
  70. }
  71. var ids []string
  72. for _, item := range data {
  73. v := reflect.ValueOf(item).FieldByName("ID").String()
  74. ids = append(ids, v)
  75. }
  76. db.Transaction(func(tx *gorm.DB) error {
  77. tx.Where("id NOT IN ?", ids).Delete(new(T))
  78. return tx.Clauses(clause.OnConflict{UpdateAll: true}).Create(&data).Error
  79. })
  80. }