代码拉取完成,页面将自动刷新
package logic
import (
"bytes"
"io/ioutil"
"model"
"github.com/polaris1119/config"
"golang.org/x/net/context"
. "db"
)
type InstallLogic struct{}
var DefaultInstall = InstallLogic{}
func (InstallLogic) CreateTable(ctx context.Context) error {
objLog := GetLogger(ctx)
dbFile := config.ROOT + "/config/db.sql"
buf, err := ioutil.ReadFile(dbFile)
if err != nil {
objLog.Errorln("create table, read db file error:", err)
return err
}
sqlSlice := bytes.Split(buf, []byte("CREATE TABLE"))
MasterDB.Exec("SET SQL_MODE='ALLOW_INVALID_DATES';")
for _, oneSql := range sqlSlice {
strSql := string(bytes.TrimSpace(oneSql))
if strSql == "" {
continue
}
strSql = "CREATE TABLE " + strSql
_, err1 := MasterDB.Exec(strSql)
if err1 != nil {
objLog.Errorln("create table error:", err1)
err = err1
}
}
return err
}
// InitTable 初始化数据表
func (InstallLogic) InitTable(ctx context.Context) error {
objLog := GetLogger(ctx)
total, err := MasterDB.Count(new(model.Role))
if err != nil {
return err
}
if total > 0 {
return nil
}
dbFile := config.ROOT + "/config/init.sql"
buf, err := ioutil.ReadFile(dbFile)
if err != nil {
objLog.Errorln("init table, read init file error:", err)
return err
}
sqlSlice := bytes.Split(buf, []byte("INSERT INTO"))
for _, oneSql := range sqlSlice {
strSql := string(bytes.TrimSpace(oneSql))
if strSql == "" {
continue
}
strSql = "INSERT INTO " + strSql
_, err1 := MasterDB.Exec(strSql)
if err1 != nil {
objLog.Errorln("create table error:", err1)
err = err1
}
}
return err
}
func (InstallLogic) IsTableExist(ctx context.Context) bool {
exists, err := MasterDB.IsTableExist(new(model.User))
if err != nil || !exists {
return false
}
return true
}
// HadRootUser 是否已经创建了超级用户
func (InstallLogic) HadRootUser(ctx context.Context) bool {
user := &model.User{}
_, err := MasterDB.Where("is_root=?", 1).Get(user)
if err != nil {
// 发生错误,认为已经创建了
return true
}
return user.Uid != 0
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。