2024-02-19 08:16:27 +00:00
|
|
|
package common
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"errors"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/rs/zerolog/log"
|
2024-07-17 23:26:35 +00:00
|
|
|
"github.com/urfave/cli/v3"
|
2024-02-19 08:16:27 +00:00
|
|
|
|
2024-12-22 09:44:34 +00:00
|
|
|
"go.woodpecker-ci.org/woodpecker/v3/cli/internal/config"
|
|
|
|
"go.woodpecker-ci.org/woodpecker/v3/cli/update"
|
2024-02-19 08:16:27 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
waitForUpdateCheck context.Context
|
|
|
|
cancelWaitForUpdate context.CancelCauseFunc
|
|
|
|
)
|
|
|
|
|
2024-11-18 18:40:45 +00:00
|
|
|
func Before(ctx context.Context, c *cli.Command) (context.Context, error) {
|
2024-07-17 23:26:35 +00:00
|
|
|
if err := setupGlobalLogger(ctx, c); err != nil {
|
2024-11-18 18:40:45 +00:00
|
|
|
return ctx, err
|
2024-02-19 08:16:27 +00:00
|
|
|
}
|
|
|
|
|
2024-07-17 23:26:35 +00:00
|
|
|
go func(context.Context) {
|
2024-02-19 08:16:27 +00:00
|
|
|
if c.Bool("disable-update-check") {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Don't check for updates when the update command is executed
|
|
|
|
if firstArg := c.Args().First(); firstArg == "update" {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
waitForUpdateCheck, cancelWaitForUpdate = context.WithCancelCause(context.Background())
|
|
|
|
defer cancelWaitForUpdate(errors.New("update check finished"))
|
|
|
|
|
2024-11-30 14:23:44 +00:00
|
|
|
log.Debug().Msg("checking for updates ...")
|
2024-02-19 08:16:27 +00:00
|
|
|
|
2024-07-17 23:26:35 +00:00
|
|
|
newVersion, err := update.CheckForUpdate(waitForUpdateCheck, false) //nolint:contextcheck
|
2024-02-19 08:16:27 +00:00
|
|
|
if err != nil {
|
2024-11-30 14:23:44 +00:00
|
|
|
log.Error().Err(err).Msgf("failed to check for updates")
|
2024-02-19 08:16:27 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if newVersion != nil {
|
2024-11-30 14:23:44 +00:00
|
|
|
log.Warn().Msgf("new version of woodpecker-cli is available: %s, update with: %s update", newVersion.Version, c.Root().Name)
|
2024-02-19 08:16:27 +00:00
|
|
|
} else {
|
2024-11-30 14:23:44 +00:00
|
|
|
log.Debug().Msgf("no update required")
|
2024-02-19 08:16:27 +00:00
|
|
|
}
|
2024-07-17 23:26:35 +00:00
|
|
|
}(ctx)
|
2024-02-19 08:16:27 +00:00
|
|
|
|
2024-11-18 18:40:45 +00:00
|
|
|
return ctx, config.Load(ctx, c)
|
2024-02-19 08:16:27 +00:00
|
|
|
}
|
|
|
|
|
2024-07-17 23:26:35 +00:00
|
|
|
func After(_ context.Context, _ *cli.Command) error {
|
2024-02-19 08:16:27 +00:00
|
|
|
if waitForUpdateCheck != nil {
|
|
|
|
select {
|
|
|
|
case <-waitForUpdateCheck.Done():
|
2024-04-15 19:18:02 +00:00
|
|
|
// When the actual command already finished, we still wait 500ms for the update check to finish
|
2024-03-28 09:36:39 +00:00
|
|
|
case <-time.After(time.Millisecond * 500):
|
2024-11-30 14:23:44 +00:00
|
|
|
log.Debug().Msg("update check stopped due to timeout")
|
2024-02-19 08:16:27 +00:00
|
|
|
cancelWaitForUpdate(errors.New("update check timeout"))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|