mindoc/models/Options.go

169 lines
4.4 KiB
Go
Raw Normal View History

2017-04-21 18:20:35 +08:00
package models
import (
"github.com/beego/beego/v2/client/orm"
"github.com/mindoc-org/mindoc/conf"
2017-04-21 18:20:35 +08:00
)
// Option struct .
type Option struct {
OptionId int `orm:"column(option_id);pk;auto;unique;" json:"option_id"`
OptionTitle string `orm:"column(option_title);size(500)" json:"option_title"`
OptionName string `orm:"column(option_name);unique;size(80)" json:"option_name"`
OptionValue string `orm:"column(option_value);type(text);null" json:"option_value"`
Remark string `orm:"column(remark);type(text);null" json:"remark"`
2017-04-21 18:20:35 +08:00
}
// TableName 获取对应数据库表名.
func (m *Option) TableName() string {
return "options"
}
2017-04-21 18:20:35 +08:00
// TableEngine 获取数据使用的引擎.
func (m *Option) TableEngine() string {
return "INNODB"
}
func (m *Option) TableNameWithPrefix() string {
return conf.GetDatabasePrefix() + m.TableName()
2017-04-26 18:17:38 +08:00
}
func NewOption() *Option {
2017-04-21 18:20:35 +08:00
return &Option{}
}
func (p *Option) Find(id int) (*Option, error) {
2017-04-21 18:20:35 +08:00
o := orm.NewOrm()
p.OptionId = id
if err := o.Read(p); err != nil {
return p, err
2017-04-21 18:20:35 +08:00
}
return p, nil
2017-04-21 18:20:35 +08:00
}
func (p *Option) FindByKey(key string) (*Option, error) {
2017-04-21 18:20:35 +08:00
o := orm.NewOrm()
p.OptionName = key
if err := o.Read(p); err != nil {
return p, err
2017-04-21 18:20:35 +08:00
}
return p, nil
2017-04-21 18:20:35 +08:00
}
func GetOptionValue(key, def string) string {
if option, err := NewOption().FindByKey(key); err == nil {
2017-04-21 18:20:35 +08:00
return option.OptionValue
}
return def
}
func (p *Option) InsertOrUpdate() error {
2017-04-21 18:20:35 +08:00
o := orm.NewOrm()
2017-04-21 18:20:35 +08:00
var err error
2017-05-31 15:26:51 +08:00
if p.OptionId > 0 || o.QueryTable(p.TableNameWithPrefix()).Filter("option_name", p.OptionName).Exist() {
_, err = o.Update(p)
} else {
_, err = o.Insert(p)
2017-04-21 18:20:35 +08:00
}
return err
}
func (p *Option) InsertMulti(option ...Option) error {
2017-04-21 18:20:35 +08:00
o := orm.NewOrm()
_, err := o.InsertMulti(len(option), option)
2017-04-21 18:20:35 +08:00
return err
}
func (p *Option) All() ([]*Option, error) {
2017-04-21 18:20:35 +08:00
o := orm.NewOrm()
2017-04-26 18:17:38 +08:00
var options []*Option
2017-04-21 18:20:35 +08:00
_, err := o.QueryTable(p.TableNameWithPrefix()).All(&options)
2017-04-21 18:20:35 +08:00
if err != nil {
return options, err
2017-04-21 18:20:35 +08:00
}
return options, nil
2017-05-31 15:26:51 +08:00
}
func (m *Option) Init() error {
o := orm.NewOrm()
if !o.QueryTable(m.TableNameWithPrefix()).Filter("option_name", "ENABLED_REGISTER").Exist() {
2017-05-31 15:26:51 +08:00
option := NewOption()
option.OptionValue = "false"
option.OptionName = "ENABLED_REGISTER"
option.OptionTitle = "是否启用注册"
if _, err := o.Insert(option); err != nil {
2017-05-31 15:26:51 +08:00
return err
}
}
if !o.QueryTable(m.TableNameWithPrefix()).Filter("option_name", "ENABLE_DOCUMENT_HISTORY").Exist() {
2017-05-31 15:26:51 +08:00
option := NewOption()
option.OptionValue = "true"
option.OptionName = "ENABLE_DOCUMENT_HISTORY"
option.OptionTitle = "是否启用文档历史"
if _, err := o.Insert(option); err != nil {
2017-05-31 15:26:51 +08:00
return err
}
}
if !o.QueryTable(m.TableNameWithPrefix()).Filter("option_name", "ENABLED_CAPTCHA").Exist() {
2017-05-31 15:26:51 +08:00
option := NewOption()
option.OptionValue = "true"
option.OptionName = "ENABLED_CAPTCHA"
option.OptionTitle = "是否启用验证码"
if _, err := o.Insert(option); err != nil {
2017-05-31 15:26:51 +08:00
return err
}
}
if !o.QueryTable(m.TableNameWithPrefix()).Filter("option_name", "ENABLE_ANONYMOUS").Exist() {
2017-05-31 15:26:51 +08:00
option := NewOption()
option.OptionValue = "false"
option.OptionName = "ENABLE_ANONYMOUS"
option.OptionTitle = "启用匿名访问"
if _, err := o.Insert(option); err != nil {
2017-05-31 15:26:51 +08:00
return err
}
}
if !o.QueryTable(m.TableNameWithPrefix()).Filter("option_name", "SITE_NAME").Exist() {
2017-05-31 15:26:51 +08:00
option := NewOption()
2018-01-27 13:34:48 +08:00
option.OptionValue = "MinDoc文档管理系统"
2017-05-31 15:26:51 +08:00
option.OptionName = "SITE_NAME"
option.OptionTitle = "站点名称"
if _, err := o.Insert(option); err != nil {
2017-05-31 15:26:51 +08:00
return err
}
}
2018-01-27 13:34:48 +08:00
if !o.QueryTable(m.TableNameWithPrefix()).Filter("option_name", "site_description").Exist() {
option := NewOption()
option.OptionValue = "MinDoc 是一款针对IT团队开发的简单好用的文档管理系统可以用来储存日常接口文档数据库字典手册说明等文档。内置项目管理用户管理权限管理等功能支持Markdown和富文本两种编辑器能够满足大部分中小团队的文档管理需求。"
option.OptionName = "site_description"
option.OptionTitle = "站点描述"
if _, err := o.Insert(option); err != nil {
return err
}
}
2018-03-19 17:46:47 +08:00
if !o.QueryTable(m.TableNameWithPrefix()).Filter("option_name", "site_beian").Exist() {
option := NewOption()
option.OptionValue = ""
option.OptionName = "site_beian"
option.OptionTitle = "域名备案"
if _, err := o.Insert(option); err != nil {
return err
}
}
2017-05-31 15:26:51 +08:00
return nil
}