Nelze vybrat více než 25 témat Téma musí začínat písmenem nebo číslem, může obsahovat pomlčky („-“) a může být dlouhé až 35 znaků.
 
 
 
 

87 řádky
2.1 KiB

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