2024-04-11 12:45:01 +00:00
|
|
|
|
package data_updater
|
|
|
|
|
|
|
|
|
|
import (
|
2024-04-21 14:52:55 +00:00
|
|
|
|
"amocrm/internal/workers_methods"
|
2024-04-11 12:45:01 +00:00
|
|
|
|
"context"
|
|
|
|
|
"go.uber.org/zap"
|
|
|
|
|
"time"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
type Deps struct {
|
2024-04-21 14:52:55 +00:00
|
|
|
|
Logger *zap.Logger
|
|
|
|
|
Methods *workers_methods.Methods
|
2024-04-11 12:45:01 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
type DataUpdater struct {
|
2024-04-21 14:52:55 +00:00
|
|
|
|
logger *zap.Logger
|
|
|
|
|
methods *workers_methods.Methods
|
2024-04-11 12:45:01 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func NewDataUpdaterWC(deps Deps) *DataUpdater {
|
|
|
|
|
return &DataUpdater{
|
2024-04-21 14:52:55 +00:00
|
|
|
|
logger: deps.Logger,
|
|
|
|
|
methods: deps.Methods,
|
2024-04-11 12:45:01 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (wc *DataUpdater) Start(ctx context.Context) {
|
|
|
|
|
nextStart := calculateTime()
|
|
|
|
|
ticker := time.NewTicker(time.Second * time.Duration(nextStart))
|
2024-04-20 19:02:13 +00:00
|
|
|
|
//ticker := time.NewTicker(10 * time.Second)
|
2024-04-11 12:45:01 +00:00
|
|
|
|
defer ticker.Stop()
|
|
|
|
|
|
|
|
|
|
for {
|
|
|
|
|
select {
|
|
|
|
|
case <-ticker.C:
|
|
|
|
|
wc.processTasks(ctx)
|
|
|
|
|
nextStart = calculateTime()
|
|
|
|
|
ticker.Reset(time.Second * time.Duration(nextStart))
|
|
|
|
|
case <-ctx.Done():
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (wc *DataUpdater) processTasks(ctx context.Context) {
|
2024-04-11 15:08:54 +00:00
|
|
|
|
// сначала получаем список токенов
|
2024-04-21 14:52:55 +00:00
|
|
|
|
newTokens, err := wc.methods.UpdateTokens(ctx)
|
2024-04-11 15:08:54 +00:00
|
|
|
|
if err != nil {
|
2024-04-21 14:52:55 +00:00
|
|
|
|
wc.logger.Error("error updating tokens and getting new tokens", zap.Error(err))
|
2024-04-11 15:08:54 +00:00
|
|
|
|
return
|
|
|
|
|
}
|
2024-04-19 16:05:42 +00:00
|
|
|
|
|
|
|
|
|
// обновляем информацию о пользователях
|
2024-04-21 14:52:55 +00:00
|
|
|
|
err = wc.methods.CheckUsers(ctx, newTokens)
|
2024-04-19 16:05:42 +00:00
|
|
|
|
if err != nil {
|
2024-04-21 14:52:55 +00:00
|
|
|
|
wc.logger.Error("error update users information", zap.Error(err))
|
2024-04-19 16:05:42 +00:00
|
|
|
|
}
|
|
|
|
|
|
2024-04-21 14:52:55 +00:00
|
|
|
|
// обновляем информацию о pipelines и их steps
|
|
|
|
|
err = wc.methods.CheckPipelinesAndSteps(ctx, newTokens)
|
|
|
|
|
if err != nil {
|
|
|
|
|
wc.logger.Error("error updating users pipelines and users pipelines-steps", zap.Error(err))
|
2024-04-11 15:08:54 +00:00
|
|
|
|
}
|
2024-04-11 12:45:01 +00:00
|
|
|
|
|
2024-04-21 14:52:55 +00:00
|
|
|
|
// обновляем информацию о tags
|
|
|
|
|
err = wc.methods.CheckTags(ctx, newTokens)
|
|
|
|
|
if err != nil {
|
|
|
|
|
wc.logger.Error("error updating users tags", zap.Error(err))
|
2024-04-12 14:51:26 +00:00
|
|
|
|
}
|
|
|
|
|
|
2024-04-21 14:52:55 +00:00
|
|
|
|
// обновляем информацию о fields
|
|
|
|
|
err = wc.methods.CheckFields(ctx, newTokens)
|
|
|
|
|
if err != nil {
|
|
|
|
|
wc.logger.Error("error updating users fields", zap.Error(err))
|
2024-04-12 14:51:26 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-04-11 12:45:01 +00:00
|
|
|
|
func (wc *DataUpdater) Stop(ctx context.Context) error {
|
|
|
|
|
return nil
|
|
|
|
|
}
|