| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158 |
- // 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/cloudcommon/db/taskman"
- "yunion.io/x/onecloud/pkg/devtool/options"
- "yunion.io/x/onecloud/pkg/mcclient"
- "yunion.io/x/onecloud/pkg/mcclient/auth"
- "yunion.io/x/onecloud/pkg/mcclient/modules/ansible"
- )
- 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 := ansible.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(ctx context.Context) error {
- err := taskman.TaskManager.InitializeData()
- if err != nil {
- log.Fatalf("TaskManager.InitializeData fail %s", err)
- }
- DevToolCronManager = cronman.InitCronJobManager(true, 8, options.Options.TimeZone)
- DevToolCronManager.AddJobAtIntervalsWithStartRun("TaskCleanupJob", time.Duration(options.Options.TaskArchiveIntervalMinutes)*time.Minute, taskman.TaskManager.TaskCleanupJob, true)
- DevToolCronManager.Start()
- Session := auth.GetAdminSession(ctx, "")
- 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(ctx, "")
- 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(ctx, "")
- job.SStandaloneResourceBase.PostUpdate(ctx, userCred, query, data)
- DevToolCronManager.Remove(job.Id)
- AddOneCronjob(job, Session)
- }
|