summaryrefslogtreecommitdiffstats
path: root/vendor/github.com/mattermost/mattermost-server/v6/model/job.go
diff options
context:
space:
mode:
authorWim <wim@42.be>2021-10-16 23:11:32 +0200
committerWim <wim@42.be>2021-10-16 23:23:24 +0200
commit20f6c05ec50739d31f4dbe9fde0d223f2c43f6e8 (patch)
tree230edca06449a8d1755f08aabf45a03e07e6f17c /vendor/github.com/mattermost/mattermost-server/v6/model/job.go
parent57fce93af7f64f025cec6f3ed6088163086bc9fe (diff)
downloadmatterbridge-msglm-20f6c05ec50739d31f4dbe9fde0d223f2c43f6e8.tar.gz
matterbridge-msglm-20f6c05ec50739d31f4dbe9fde0d223f2c43f6e8.tar.bz2
matterbridge-msglm-20f6c05ec50739d31f4dbe9fde0d223f2c43f6e8.zip
Update vendor
Diffstat (limited to 'vendor/github.com/mattermost/mattermost-server/v6/model/job.go')
-rw-r--r--vendor/github.com/mattermost/mattermost-server/v6/model/job.go130
1 files changed, 130 insertions, 0 deletions
diff --git a/vendor/github.com/mattermost/mattermost-server/v6/model/job.go b/vendor/github.com/mattermost/mattermost-server/v6/model/job.go
new file mode 100644
index 00000000..13c6154f
--- /dev/null
+++ b/vendor/github.com/mattermost/mattermost-server/v6/model/job.go
@@ -0,0 +1,130 @@
+// 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 map[string]string `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.Type {
+ case JobTypeDataRetention:
+ case JobTypeElasticsearchPostIndexing:
+ case JobTypeElasticsearchPostAggregation:
+ case JobTypeBlevePostIndexing:
+ case JobTypeLdapSync:
+ case JobTypeMessageExport:
+ case JobTypeMigrations:
+ case JobTypePlugins:
+ case JobTypeProductNotices:
+ case JobTypeExpiryNotify:
+ case JobTypeActiveUsers:
+ case JobTypeImportProcess:
+ case JobTypeImportDelete:
+ case JobTypeExportProcess:
+ case JobTypeExportDelete:
+ case JobTypeCloud:
+ case JobTypeResendInvitationEmail:
+ case JobTypeExtractContent:
+ default:
+ return NewAppError("Job.IsValid", "model.job.is_valid.type.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
+}
+
+type Scheduler interface {
+ Name() string
+ JobType() string
+ 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)
+}