mirror of https://github.com/portainer/portainer
37 lines
1.1 KiB
Go
37 lines
1.1 KiB
Go
package stacks
|
|
|
|
import (
|
|
"time"
|
|
|
|
httperror "github.com/portainer/libhttp/error"
|
|
portainer "github.com/portainer/portainer/api"
|
|
"github.com/portainer/portainer/api/dataservices"
|
|
"github.com/portainer/portainer/api/scheduler"
|
|
"github.com/portainer/portainer/api/stacks"
|
|
|
|
"github.com/rs/zerolog/log"
|
|
)
|
|
|
|
func startAutoupdate(stackID portainer.StackID, interval string, scheduler *scheduler.Scheduler, stackDeployer stacks.StackDeployer, datastore dataservices.DataStore, gitService portainer.GitService) (jobID string, e *httperror.HandlerError) {
|
|
d, err := time.ParseDuration(interval)
|
|
if err != nil {
|
|
return "", httperror.BadRequest("Unable to parse stack's auto update interval", err)
|
|
}
|
|
|
|
jobID = scheduler.StartJobEvery(d, func() error {
|
|
return stacks.RedeployWhenChanged(stackID, stackDeployer, datastore, gitService)
|
|
})
|
|
|
|
return jobID, nil
|
|
}
|
|
|
|
func stopAutoupdate(stackID portainer.StackID, jobID string, scheduler scheduler.Scheduler) {
|
|
if jobID == "" {
|
|
return
|
|
}
|
|
|
|
if err := scheduler.StopJob(jobID); err != nil {
|
|
log.Warn().Int("stack_id", int(stackID)).Msg("could not stop the job for the stack")
|
|
}
|
|
}
|