diff --git a/README.md b/README.md index 89f2986d2..a8544f051 100644 --- a/README.md +++ b/README.md @@ -210,6 +210,10 @@ lfs: # Enable Git SSH transfer. ssh_enabled: true +# Cron job configuration +jobs: + mirror_pull: "@every 10m" + # The stats server configuration. stats: # The address on which the stats server will listen. diff --git a/server/config/config.go b/server/config/config.go index aba8f508e..46afc6cfa 100644 --- a/server/config/config.go +++ b/server/config/config.go @@ -105,6 +105,11 @@ type LFSConfig struct { SSHEnabled bool `env:"SSH_ENABLED" yaml:"ssh_enabled"` } +// JobsConfig is the configuration for cron jobs. +type JobsConfig struct { + MirrorPull string `env:"MIRROR_PULL" yaml:"mirror_pull"` +} + // Config is the configuration for Soft Serve. type Config struct { // Name is the name of the server. @@ -131,6 +136,9 @@ type Config struct { // LFS is the configuration for Git LFS. LFS LFSConfig `envPrefix:"LFS_" yaml:"lfs"` + // Jobs is the configuration for cron jobs + Jobs JobsConfig `envPrefix:"JOBS_" yaml:"jobs"` + // InitialAdminKeys is a list of public keys that will be added to the list of admins. InitialAdminKeys []string `env:"INITIAL_ADMIN_KEYS" envSeparator:"\n" yaml:"initial_admin_keys"` diff --git a/server/config/file.go b/server/config/file.go index 6560dd15c..98cdc6be1 100644 --- a/server/config/file.go +++ b/server/config/file.go @@ -98,6 +98,10 @@ lfs: # Enable Git SSH transfer. ssh_enabled: {{ .LFS.SSHEnabled }} +# Cron job configuration +jobs: + mirror_pull: "{{ .Jobs.MirrorPull }}" + # Additional admin keys. #initial_admin_keys: # - "ssh-rsa AAAAB3NzaC1yc2..." diff --git a/server/jobs/jobs.go b/server/jobs/jobs.go index ba39af85c..505863ea0 100644 --- a/server/jobs/jobs.go +++ b/server/jobs/jobs.go @@ -7,9 +7,14 @@ import ( // Job is a job that can be registered with the scheduler. type Job struct { - ID int - Spec string - Func func(context.Context) func() + ID int + Runner Runner +} + +// Runner is a job runner. +type Runner interface { + Spec(context.Context) string + Func(context.Context) func() } var ( @@ -18,10 +23,10 @@ var ( ) // Register registers a job. -func Register(name, spec string, fn func(context.Context) func()) { +func Register(name string, runner Runner) { mtx.Lock() defer mtx.Unlock() - jobs[name] = &Job{Spec: spec, Func: fn} + jobs[name] = &Job{Runner: runner} } // List returns a map of registered jobs. diff --git a/server/jobs/mirror.go b/server/jobs/mirror.go index 8b14d2511..4a8f08053 100644 --- a/server/jobs/mirror.go +++ b/server/jobs/mirror.go @@ -17,11 +17,22 @@ import ( ) func init() { - Register("mirror-pull", "@every 10m", mirrorPull) + Register("mirror-pull", mirrorPull{}) } -// mirrorPull runs the (pull) mirror job task. -func mirrorPull(ctx context.Context) func() { +type mirrorPull struct{} + +// Spec derives the spec used for pull mirrors and implements Runner. +func (m mirrorPull) Spec(ctx context.Context) string { + cfg := config.FromContext(ctx) + if cfg.Jobs.MirrorPull != "" { + return cfg.Jobs.MirrorPull + } + return "@every 10m" +} + +// Func runs the (pull) mirror job task and implements Runner. +func (m mirrorPull) Func(ctx context.Context) func() { cfg := config.FromContext(ctx) logger := log.FromContext(ctx).WithPrefix("jobs.mirror") b := backend.FromContext(ctx) diff --git a/server/server.go b/server/server.go index 8c73ad213..71f796522 100644 --- a/server/server.go +++ b/server/server.go @@ -57,7 +57,7 @@ func NewServer(ctx context.Context) (*Server, error) { // Add cron jobs. sched := cron.NewScheduler(ctx) for n, j := range jobs.List() { - id, err := sched.AddFunc(j.Spec, j.Func(ctx)) + id, err := sched.AddFunc(j.Runner.Spec(ctx), j.Runner.Func(ctx)) if err != nil { logger.Warn("error adding cron job", "job", n, "err", err) }