amocrm/internal/workers/tokens/tokens_updater.go

81 lines
1.6 KiB
Go
Raw Normal View History

package tokens
2024-04-10 16:50:41 +00:00
import (
"amocrm/internal/models"
"amocrm/internal/models/amo"
"amocrm/internal/repository"
"amocrm/pkg/amoClient"
"context"
"go.uber.org/zap"
"time"
)
type Deps struct {
AmoClient *amoClient.Amo
Repo *repository.Repository
Logger *zap.Logger
}
type Refresh struct {
amoClient *amoClient.Amo
repo *repository.Repository
logger *zap.Logger
}
func NewRefreshWC(deps Deps) *Refresh {
return &Refresh{
amoClient: deps.AmoClient,
repo: deps.Repo,
logger: deps.Logger,
}
}
func (wc *Refresh) Start(ctx context.Context) {
ticker := time.NewTicker(5 * time.Minute)
2024-04-10 16:50:41 +00:00
defer ticker.Stop()
for {
select {
case <-ticker.C:
wc.processTasks(ctx)
case <-ctx.Done():
return
}
}
}
func (wc Refresh) processTasks(ctx context.Context) {
tokens, err := wc.repo.CheckExpired(ctx)
2024-04-10 16:50:41 +00:00
if err != nil {
wc.logger.Error("error fetch expired tokens in mongo", zap.Error(err))
2024-04-10 16:50:41 +00:00
return
}
for _, token := range tokens {
req := amo.UpdateWebHookReq{
GrantType: "refresh_token",
RefreshToken: token.RefreshToken,
}
newTokens, err := wc.amoClient.CreateWebHook(&req)
if err != nil {
wc.logger.Error("error create webhook for update tokens", zap.Error(err))
2024-04-10 16:50:41 +00:00
continue
}
err = wc.repo.WebhookUpdate(ctx, models.Token{
AccountID: token.AccountID,
RefreshToken: newTokens.RefreshToken,
AccessToken: newTokens.AccessToken,
Expiration: time.Now().Unix() + newTokens.ExpiresIn,
CreatedAt: time.Now().Unix(),
})
if err != nil {
wc.logger.Error("error update new tokens in mongo", zap.Error(err))
continue
}
}
}
func (wc *Refresh) Stop(ctx context.Context) error {
return nil
}