Files
cloudpods/pkg/devtool/models/devtoolcronjob.go
2019-12-24 11:42:33 +08:00

149 lines
5.5 KiB
Go

// Copyright 2019 Yunion
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package models
import (
"context"
"time"
"yunion.io/x/jsonutils"
"yunion.io/x/log"
"yunion.io/x/onecloud/pkg/cloudcommon/cronman"
"yunion.io/x/onecloud/pkg/cloudcommon/db"
"yunion.io/x/onecloud/pkg/mcclient"
"yunion.io/x/onecloud/pkg/mcclient/auth"
"yunion.io/x/onecloud/pkg/mcclient/modules"
)
type SVSCronjob struct {
Day int `json:"day" nullable:"true" create:"optional" list:"user" update:"user" default:"0"`
Hour int `nullable:"true" create:"optional" list:"user" update:"user" default:"0"`
Min int `nullable:"true" create:"optional" list:"user" update:"user" default:"0"`
Sec int `nullable:"true" create:"optional" list:"user" update:"user" default:"0"`
Interval int64 `nullable:"true" create:"optional" list:"user" update:"user" default:"0"`
Start bool `nullable:"true" create:"optional" list:"user" update:"user" default:"false"`
Enabled bool `nullable:"true" create:"optional" list:"user" update:"user" default:"false"`
}
type SCronjob struct {
SVSCronjob
AnsiblePlaybookID string `width:"36" nullable:"false" create:"required" index:"true" list:"user" update:"user"`
TemplateID string `width:"36" nullable:"true" create:"optional" index:"true" list:"user" update:"user"`
ServerID string `width:"36" nullable:"true" create:"optional" index:"true" list:"user" update:"user"`
db.SVirtualResourceBase
}
type SCronjobManager struct {
db.SVirtualResourceBaseManager
}
var (
CronjobManager *SCronjobManager
DevToolCronManager *cronman.SCronJobManager
)
func init() {
CronjobManager = &SCronjobManager{
SVirtualResourceBaseManager: db.NewVirtualResourceBaseManager(
SCronjob{},
"devtool_cronjobs_tbl",
"devtool_cronjob",
"devtool_cronjobs",
),
}
CronjobManager.SetVirtualObject(CronjobManager)
}
func RunAnsibleCronjob(id string, s *mcclient.ClientSession) cronman.TCronJobFunction {
return func(ctx context.Context, userCred mcclient.TokenCredential, isStart bool) {
obj, err := CronjobManager.FetchById(id)
if err != nil {
log.Errorf("No cronjob with id: %s", id)
return
}
log.Debugf("[RunAnsibleCronjob] %+v: ", obj)
item := obj.(*SCronjob)
log.Debugf("[RunAnsibleCronjob] perform ansible cronjob run: %s", item.AnsiblePlaybookID)
ret, err := modules.AnsiblePlaybooks.PerformAction(s, item.AnsiblePlaybookID, "run", nil)
if err != nil {
log.Errorf("AnsiblePlaybooks.PerformAction error: %s", err)
}
log.Debugf("AnsiblePlaybooks.PerformAction ret: %+v", ret)
}
}
func AddOneCronjob(item *SCronjob, s *mcclient.ClientSession) error {
if !item.Enabled {
log.Debugf("ansible cronjob %s (devtool item.Id: %s) is not enabled", item.Name, item.Id)
return nil
}
if item.Interval > 0 {
err := DevToolCronManager.AddJobAtIntervalsWithStartRun(item.Id, time.Duration(item.Interval)*time.Second, RunAnsibleCronjob(item.Id, s), item.Start)
if err != nil {
log.Errorf("ansible cronjob %s (devtool item.Id: %s) error! %s", item.Name, item.Id, err)
return err
}
log.Infof("ansible cronjob %s (devtool item.Id: %s) registered at item.Interval: %ds", item.Name, item.Id, item.Interval)
} else {
err := DevToolCronManager.AddJobEveryFewDays(item.Id, int(item.Day), int(item.Hour), int(item.Min), int(item.Sec), RunAnsibleCronjob(item.Id, s), item.Start)
if err != nil {
log.Errorf("ansible cronjob %s (devtool item.Id: %s) registered at item.Interval: item.Day(%d) item.Hour(%d) item.Min(%d) item.Sec(%d) error: %s", item.Name, item.Id, int(item.Day), int(item.Hour), int(item.Min), int(item.Sec), err)
return err
}
log.Infof("ansible cronjob %s (devtool item.Id: %s) registered at item.Interval: item.Day(%d) item.Hour(%d) item.Min(%d) item.Sec(%d)", item.Name, item.Id, int(item.Day), int(item.Hour), int(item.Min), int(item.Sec))
}
return nil
}
func InitializeCronjobs() error {
DevToolCronManager = cronman.InitCronJobManager(true, 8)
DevToolCronManager.Start()
Session := auth.GetAdminSession(nil, "", "")
go func() {
items := make([]SCronjob, 0)
q := CronjobManager.Query().Equals("enabled", true)
err := q.All(&items)
if err != nil {
log.Errorf("query error: %s", err)
}
for _, item := range items {
AddOneCronjob(&item, Session)
}
}()
return nil
}
func (job *SCronjob) PostCreate(ctx context.Context, userCred mcclient.TokenCredential, ownerID mcclient.IIdentityProvider, query jsonutils.JSONObject, data jsonutils.JSONObject) {
Session := auth.GetAdminSession(nil, "", "")
job.SStandaloneResourceBase.PostCreate(ctx, userCred, nil, query, data)
AddOneCronjob(job, Session)
}
func (job *SCronjob) PostDelete(ctx context.Context, userCred mcclient.TokenCredential) {
DevToolCronManager.Remove(job.Id)
}
func (job *SCronjob) PostUpdate(ctx context.Context, userCred mcclient.TokenCredential, query jsonutils.JSONObject, data jsonutils.JSONObject) {
Session := auth.GetAdminSession(nil, "", "")
job.SStandaloneResourceBase.PostUpdate(ctx, userCred, query, data)
DevToolCronManager.Remove(job.Id)
AddOneCronjob(job, Session)
}