mirror of https://github.com/ouqiang/gocron
292 lines
6.1 KiB
Go
292 lines
6.1 KiB
Go
package models
|
|
|
|
import (
|
|
"encoding/json"
|
|
)
|
|
|
|
type Setting struct {
|
|
Id int `xorm:"int pk autoincr"`
|
|
Code string `xorm:"varchar(32) notnull"`
|
|
Key string `xorm:"varchar(64) notnull"`
|
|
Value string `xorm:"varchar(4096) notnull default '' "`
|
|
}
|
|
|
|
const slackTemplate = `
|
|
任务ID: {{.TaskId}}
|
|
任务名称: {{.TaskName}}
|
|
状态: {{.Status}}
|
|
执行结果: {{.Result}}
|
|
`
|
|
const emailTemplate = `
|
|
任务ID: {{.TaskId}}
|
|
任务名称: {{.TaskName}}
|
|
状态: {{.Status}}
|
|
执行结果: {{.Result}}
|
|
`
|
|
const webhookTemplate = `
|
|
{
|
|
"task_id": "{{.TaskId}}",
|
|
"task_name": "{{.TaskName}}",
|
|
"status": "{{.Status}}",
|
|
"result": "{{.Result}}"
|
|
}
|
|
`
|
|
|
|
const (
|
|
SlackCode = "slack"
|
|
SlackUrlKey = "url"
|
|
SlackTemplateKey = "template"
|
|
SlackChannelKey = "channel"
|
|
)
|
|
|
|
const (
|
|
MailCode = "mail"
|
|
MailTemplateKey = "template"
|
|
MailServerKey = "server"
|
|
MailUserKey = "user"
|
|
)
|
|
|
|
const (
|
|
WebhookCode = "webhook"
|
|
WebhookTemplateKey = "template"
|
|
WebhookUrlKey = "url"
|
|
)
|
|
|
|
// 初始化基本字段 邮件、slack等
|
|
func (setting *Setting) InitBasicField() {
|
|
setting.Code = SlackCode
|
|
setting.Key = SlackUrlKey
|
|
setting.Value = ""
|
|
Db.Insert(setting)
|
|
setting.Id = 0
|
|
|
|
setting.Code = SlackCode
|
|
setting.Key = SlackTemplateKey
|
|
setting.Value = slackTemplate
|
|
Db.Insert(setting)
|
|
setting.Id = 0
|
|
|
|
setting.Code = MailCode
|
|
setting.Key = MailServerKey
|
|
setting.Value = ""
|
|
Db.Insert(setting)
|
|
setting.Id = 0
|
|
|
|
setting.Code = MailCode
|
|
setting.Key = MailTemplateKey
|
|
setting.Value = emailTemplate
|
|
Db.Insert(setting)
|
|
setting.Id = 0
|
|
|
|
setting.Code = WebhookCode
|
|
setting.Key = WebhookTemplateKey
|
|
setting.Value = webhookTemplate
|
|
Db.Insert(setting)
|
|
setting.Id = 0
|
|
|
|
setting.Code = WebhookCode
|
|
setting.Key = WebhookUrlKey
|
|
setting.Value = ""
|
|
Db.Insert(setting)
|
|
}
|
|
|
|
// region slack配置
|
|
|
|
type Slack struct {
|
|
Url string `json:"url"`
|
|
Channels []Channel `json:"channels"`
|
|
Template string `json:"template"`
|
|
}
|
|
|
|
type Channel struct {
|
|
Id int `json:"id"`
|
|
Name string `json:"name"`
|
|
}
|
|
|
|
func (setting *Setting) Slack() (Slack, error) {
|
|
list := make([]Setting, 0)
|
|
err := Db.Where("code = ?", SlackCode).Find(&list)
|
|
slack := Slack{}
|
|
if err != nil {
|
|
return slack, err
|
|
}
|
|
|
|
setting.formatSlack(list, &slack)
|
|
|
|
return slack, err
|
|
}
|
|
|
|
func (setting *Setting) formatSlack(list []Setting, slack *Slack) {
|
|
for _, v := range list {
|
|
switch v.Key {
|
|
case SlackUrlKey:
|
|
slack.Url = v.Value
|
|
case SlackTemplateKey:
|
|
slack.Template = v.Value
|
|
default:
|
|
slack.Channels = append(slack.Channels, Channel{
|
|
v.Id, v.Value,
|
|
})
|
|
}
|
|
}
|
|
}
|
|
|
|
func (setting *Setting) UpdateSlack(url, template string) error {
|
|
setting.Value = url
|
|
|
|
Db.Cols("value").Update(setting, Setting{Code: SlackCode, Key: SlackUrlKey})
|
|
|
|
setting.Value = template
|
|
Db.Cols("value").Update(setting, Setting{Code: SlackCode, Key: SlackTemplateKey})
|
|
|
|
return nil
|
|
}
|
|
|
|
// 创建slack渠道
|
|
func (setting *Setting) CreateChannel(channel string) (int64, error) {
|
|
setting.Code = SlackCode
|
|
setting.Key = SlackChannelKey
|
|
setting.Value = channel
|
|
|
|
return Db.Insert(setting)
|
|
}
|
|
|
|
func (setting *Setting) IsChannelExist(channel string) bool {
|
|
setting.Code = SlackCode
|
|
setting.Key = SlackChannelKey
|
|
setting.Value = channel
|
|
|
|
count, _ := Db.Count(setting)
|
|
|
|
return count > 0
|
|
}
|
|
|
|
// 删除slack渠道
|
|
func (setting *Setting) RemoveChannel(id int) (int64, error) {
|
|
setting.Code = SlackCode
|
|
setting.Key = SlackChannelKey
|
|
setting.Id = id
|
|
return Db.Delete(setting)
|
|
}
|
|
|
|
// endregion
|
|
|
|
type Mail struct {
|
|
Host string `json:"host"`
|
|
Port int `json:"port"`
|
|
User string `json:"user"`
|
|
Password string `json:"password"`
|
|
MailUsers []MailUser `json:"mail_users"`
|
|
Template string `json:"template"`
|
|
}
|
|
|
|
type MailUser struct {
|
|
Id int `json:"id"`
|
|
Username string `json:"username"`
|
|
Email string `json:"email"`
|
|
}
|
|
|
|
// region 邮件配置
|
|
func (setting *Setting) Mail() (Mail, error) {
|
|
list := make([]Setting, 0)
|
|
err := Db.Where("code = ?", MailCode).Find(&list)
|
|
mail := Mail{MailUsers: make([]MailUser, 0)}
|
|
if err != nil {
|
|
return mail, err
|
|
}
|
|
|
|
setting.formatMail(list, &mail)
|
|
|
|
return mail, err
|
|
}
|
|
|
|
func (setting *Setting) formatMail(list []Setting, mail *Mail) {
|
|
mailUser := MailUser{}
|
|
for _, v := range list {
|
|
switch v.Key {
|
|
case MailServerKey:
|
|
json.Unmarshal([]byte(v.Value), mail)
|
|
case MailUserKey:
|
|
json.Unmarshal([]byte(v.Value), &mailUser)
|
|
mailUser.Id = v.Id
|
|
mail.MailUsers = append(mail.MailUsers, mailUser)
|
|
case MailTemplateKey:
|
|
mail.Template = v.Value
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
func (setting *Setting) UpdateMail(config, template string) error {
|
|
setting.Value = config
|
|
Db.Cols("value").Update(setting, Setting{Code: MailCode, Key: MailServerKey})
|
|
|
|
setting.Value = template
|
|
Db.Cols("value").Update(setting, Setting{Code: MailCode, Key: MailTemplateKey})
|
|
|
|
return nil
|
|
}
|
|
|
|
func (setting *Setting) CreateMailUser(username, email string) (int64, error) {
|
|
setting.Code = MailCode
|
|
setting.Key = MailUserKey
|
|
mailUser := MailUser{0, username, email}
|
|
jsonByte, err := json.Marshal(mailUser)
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
setting.Value = string(jsonByte)
|
|
|
|
return Db.Insert(setting)
|
|
}
|
|
|
|
func (setting *Setting) RemoveMailUser(id int) (int64, error) {
|
|
setting.Code = MailCode
|
|
setting.Key = MailUserKey
|
|
setting.Id = id
|
|
return Db.Delete(setting)
|
|
}
|
|
|
|
type WebHook struct {
|
|
Url string `json:"url"`
|
|
Template string `json:"template"`
|
|
}
|
|
|
|
func (setting *Setting) Webhook() (WebHook, error) {
|
|
list := make([]Setting, 0)
|
|
err := Db.Where("code = ?", WebhookCode).Find(&list)
|
|
webHook := WebHook{}
|
|
if err != nil {
|
|
return webHook, err
|
|
}
|
|
|
|
setting.formatWebhook(list, &webHook)
|
|
|
|
return webHook, err
|
|
}
|
|
|
|
func (setting *Setting) formatWebhook(list []Setting, webHook *WebHook) {
|
|
for _, v := range list {
|
|
switch v.Key {
|
|
case WebhookUrlKey:
|
|
webHook.Url = v.Value
|
|
case WebhookTemplateKey:
|
|
webHook.Template = v.Value
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
func (setting *Setting) UpdateWebHook(url, template string) error {
|
|
setting.Value = url
|
|
|
|
Db.Cols("value").Update(setting, Setting{Code: WebhookCode, Key: WebhookUrlKey})
|
|
|
|
setting.Value = template
|
|
Db.Cols("value").Update(setting, Setting{Code: WebhookCode, Key: WebhookTemplateKey})
|
|
|
|
return nil
|
|
}
|
|
|
|
// endregion
|