107 lines
3.2 KiB
Go
107 lines
3.2 KiB
Go
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
|
|
package model
|
|
|
|
import (
|
|
"net/http"
|
|
"time"
|
|
)
|
|
|
|
const (
|
|
JobTypeDataRetention = "data_retention"
|
|
JobTypeMessageExport = "message_export"
|
|
JobTypeElasticsearchPostIndexing = "elasticsearch_post_indexing"
|
|
JobTypeElasticsearchPostAggregation = "elasticsearch_post_aggregation"
|
|
JobTypeBlevePostIndexing = "bleve_post_indexing"
|
|
JobTypeLdapSync = "ldap_sync"
|
|
JobTypeMigrations = "migrations"
|
|
JobTypePlugins = "plugins"
|
|
JobTypeExpiryNotify = "expiry_notify"
|
|
JobTypeProductNotices = "product_notices"
|
|
JobTypeActiveUsers = "active_users"
|
|
JobTypeImportProcess = "import_process"
|
|
JobTypeImportDelete = "import_delete"
|
|
JobTypeExportProcess = "export_process"
|
|
JobTypeExportDelete = "export_delete"
|
|
JobTypeCloud = "cloud"
|
|
JobTypeResendInvitationEmail = "resend_invitation_email"
|
|
JobTypeExtractContent = "extract_content"
|
|
|
|
JobStatusPending = "pending"
|
|
JobStatusInProgress = "in_progress"
|
|
JobStatusSuccess = "success"
|
|
JobStatusError = "error"
|
|
JobStatusCancelRequested = "cancel_requested"
|
|
JobStatusCanceled = "canceled"
|
|
JobStatusWarning = "warning"
|
|
)
|
|
|
|
var AllJobTypes = [...]string{
|
|
JobTypeDataRetention,
|
|
JobTypeMessageExport,
|
|
JobTypeElasticsearchPostIndexing,
|
|
JobTypeElasticsearchPostAggregation,
|
|
JobTypeBlevePostIndexing,
|
|
JobTypeLdapSync,
|
|
JobTypeMigrations,
|
|
JobTypePlugins,
|
|
JobTypeExpiryNotify,
|
|
JobTypeProductNotices,
|
|
JobTypeActiveUsers,
|
|
JobTypeImportProcess,
|
|
JobTypeImportDelete,
|
|
JobTypeExportProcess,
|
|
JobTypeExportDelete,
|
|
JobTypeCloud,
|
|
JobTypeExtractContent,
|
|
}
|
|
|
|
type Job struct {
|
|
Id string `json:"id"`
|
|
Type string `json:"type"`
|
|
Priority int64 `json:"priority"`
|
|
CreateAt int64 `json:"create_at"`
|
|
StartAt int64 `json:"start_at"`
|
|
LastActivityAt int64 `json:"last_activity_at"`
|
|
Status string `json:"status"`
|
|
Progress int64 `json:"progress"`
|
|
Data StringMap `json:"data"`
|
|
}
|
|
|
|
func (j *Job) IsValid() *AppError {
|
|
if !IsValidId(j.Id) {
|
|
return NewAppError("Job.IsValid", "model.job.is_valid.id.app_error", nil, "id="+j.Id, http.StatusBadRequest)
|
|
}
|
|
|
|
if j.CreateAt == 0 {
|
|
return NewAppError("Job.IsValid", "model.job.is_valid.create_at.app_error", nil, "id="+j.Id, http.StatusBadRequest)
|
|
}
|
|
|
|
switch j.Status {
|
|
case JobStatusPending:
|
|
case JobStatusInProgress:
|
|
case JobStatusSuccess:
|
|
case JobStatusError:
|
|
case JobStatusCancelRequested:
|
|
case JobStatusCanceled:
|
|
default:
|
|
return NewAppError("Job.IsValid", "model.job.is_valid.status.app_error", nil, "id="+j.Id, http.StatusBadRequest)
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
type Worker interface {
|
|
Run()
|
|
Stop()
|
|
JobChannel() chan<- Job
|
|
IsEnabled(cfg *Config) bool
|
|
}
|
|
|
|
type Scheduler interface {
|
|
Enabled(cfg *Config) bool
|
|
NextScheduleTime(cfg *Config, now time.Time, pendingJobs bool, lastSuccessfulJob *Job) *time.Time
|
|
ScheduleJob(cfg *Config, pendingJobs bool, lastSuccessfulJob *Job) (*Job, *AppError)
|
|
}
|