daemon: Job types as dedicated type

refs #67
This commit is contained in:
Christian Schwarz 2018-04-05 22:22:55 +02:00
parent 0895e02844
commit aa3865d0a3
6 changed files with 44 additions and 5 deletions

View File

@ -31,6 +31,8 @@ func (j *ControlJob) JobName() string {
return j.Name return j.Name
} }
func (j *ControlJob) JobType() JobType { return JobTypeControl }
func (j *ControlJob) JobStatus(ctx context.Context) (*JobStatus, error) { func (j *ControlJob) JobStatus(ctx context.Context) (*JobStatus, error) {
return &JobStatus{Tasks: nil}, nil return &JobStatus{Tasks: nil}, nil
} }

View File

@ -84,6 +84,8 @@ func (j *LocalJob) JobName() string {
return j.Name return j.Name
} }
func (j *LocalJob) JobType() JobType { return JobTypeLocal }
func (j *LocalJob) JobStart(ctx context.Context) { func (j *LocalJob) JobStart(ctx context.Context) {
rootLog := ctx.Value(contextKeyLog).(Logger) rootLog := ctx.Value(contextKeyLog).(Logger)

View File

@ -94,6 +94,8 @@ func (j *PullJob) JobName() string {
return j.Name return j.Name
} }
func (j *PullJob) JobType() JobType { return JobTypePull }
func (j *PullJob) JobStart(ctx context.Context) { func (j *PullJob) JobStart(ctx context.Context) {
log := ctx.Value(contextKeyLog).(Logger) log := ctx.Value(contextKeyLog).(Logger)

View File

@ -76,6 +76,8 @@ func (j *SourceJob) JobName() string {
return j.Name return j.Name
} }
func (j *SourceJob) JobType() JobType { return JobTypeSource }
func (j *SourceJob) JobStart(ctx context.Context) { func (j *SourceJob) JobStart(ctx context.Context) {
log := ctx.Value(contextKeyLog).(Logger) log := ctx.Value(contextKeyLog).(Logger)

View File

@ -162,20 +162,25 @@ func parseJob(c JobParsingContext, i map[string]interface{}) (j Job, err error)
} }
} }
jobtype, err := extractStringField(i, "type", true) jobtypeStr, err := extractStringField(i, "type", true)
if err != nil {
return
}
jobtype, err := ParseUserJobType(jobtypeStr)
if err != nil { if err != nil {
return return
} }
switch jobtype { switch jobtype {
case "pull": case JobTypePull:
return parsePullJob(c, name, i) return parsePullJob(c, name, i)
case "source": case JobTypeSource:
return parseSourceJob(c, name, i) return parseSourceJob(c, name, i)
case "local": case JobTypeLocal:
return parseLocalJob(c, name, i) return parseLocalJob(c, name, i)
default: default:
return nil, errors.Errorf("unknown job type '%s'", jobtype) panic(fmt.Sprintf("implementation error: unknown job type %s", jobtype))
} }
} }

View File

@ -28,10 +28,36 @@ func init() {
type Job interface { type Job interface {
JobName() string JobName() string
JobType() JobType
JobStart(ctxt context.Context) JobStart(ctxt context.Context)
JobStatus(ctxt context.Context) (*JobStatus, error) JobStatus(ctxt context.Context) (*JobStatus, error)
} }
type JobType string
const (
JobTypePull JobType = "pull"
JobTypeSource JobType = "source"
JobTypeLocal JobType = "local"
JobTypeControl JobType = "control"
)
func ParseUserJobType(s string) (JobType, error) {
switch s {
case "pull":
return JobTypePull, nil
case "source":
return JobTypeSource, nil
case "local":
return JobTypeLocal, nil
}
return "", fmt.Errorf("unknown job type '%s'", s)
}
func (j JobType) String() string {
return string(j)
}
func doDaemon(cmd *cobra.Command, args []string) { func doDaemon(cmd *cobra.Command, args []string) {
conf, err := ParseConfig(rootArgs.configFile) conf, err := ParseConfig(rootArgs.configFile)