hotime/application.go

769 lines
20 KiB
Go
Raw Permalink Normal View History

2017-08-17 02:14:59 +00:00
package hotime
import (
2022-03-12 17:12:29 +00:00
. "code.hoteas.com/golang/hotime/cache"
"code.hoteas.com/golang/hotime/code"
. "code.hoteas.com/golang/hotime/common"
. "code.hoteas.com/golang/hotime/db"
. "code.hoteas.com/golang/hotime/log"
2017-08-17 02:14:59 +00:00
"database/sql"
2022-08-03 04:07:55 +00:00
"fmt"
2021-05-22 19:35:49 +00:00
"github.com/sirupsen/logrus"
2017-08-17 02:14:59 +00:00
"io/ioutil"
"net/http"
2019-05-19 15:33:01 +00:00
"net/url"
2017-08-17 02:14:59 +00:00
"os"
"path/filepath"
"strconv"
"strings"
2021-11-07 22:49:34 +00:00
"time"
2017-08-17 02:14:59 +00:00
)
type Application struct {
2022-03-12 21:06:28 +00:00
MakeCodeRouter map[string]*code.MakeCode
2018-11-14 02:31:08 +00:00
MethodRouter
2017-08-17 02:14:59 +00:00
Router
2021-05-25 12:27:24 +00:00
Error
Log *logrus.Logger
WebConnectLog *logrus.Logger
2017-08-17 02:14:59 +00:00
Port string //端口号
2019-11-10 10:00:45 +00:00
TLSPort string //ssl访问端口号
2022-03-12 17:48:54 +00:00
connectListener []func(that *Context) bool //所有的访问监听,true按原计划继续使用false表示有监听器处理
2021-05-23 22:14:58 +00:00
connectDbFunc func(err ...*Error) (master, slave *sql.DB)
2017-08-17 02:14:59 +00:00
configPath string
Config Map
Db HoTimeDB
*HoTimeCache
*http.Server
2017-10-27 04:28:47 +00:00
http.Handler
}
func (that *Application) ServeHTTP(w http.ResponseWriter, req *http.Request) {
that.handler(w, req)
2017-08-17 02:14:59 +00:00
}
// Run 启动实例
func (that *Application) Run(router Router) {
2020-02-21 13:44:53 +00:00
//如果没有设置配置自动生成配置
if that.configPath == "" || len(that.Config) == 0 {
that.SetConfig()
2020-02-21 13:44:53 +00:00
}
//防止手动设置缓存误伤
if that.HoTimeCache == nil {
that.SetCache()
2020-02-21 13:44:53 +00:00
}
//防止手动设置session误伤
//if that.sessionShort == nil && that.sessionLong == nil {
// if that.connectDbFunc == nil {
// that.SetSession(CacheIns(&CacheMemory{}), nil)
2021-05-23 23:27:41 +00:00
// } else {
// that.SetSession(CacheIns(&CacheMemory{}), CacheIns(&CacheDb{Db: &that.Db, Time: that.Config.GetInt64("cacheLongTime")}))
2021-05-23 23:27:41 +00:00
// }
//
//}
2018-04-03 17:54:27 +00:00
2021-12-27 12:40:16 +00:00
//that.Router = router
if that.Router == nil {
that.Router = Router{}
}
for k, v := range router {
2022-03-16 01:58:24 +00:00
if that.Router[k] == nil {
that.Router[k] = v
}
2022-06-08 19:54:33 +00:00
//直达接口层复用
2022-03-16 01:58:24 +00:00
for k1, v1 := range v {
2022-06-08 19:54:33 +00:00
if that.Router[k][k1] == nil {
that.Router[k][k1] = v1
}
for k2, v2 := range v1 {
that.Router[k][k1][k2] = v2
}
2022-03-16 01:58:24 +00:00
}
2022-06-08 19:54:33 +00:00
2021-12-27 12:40:16 +00:00
}
2018-11-14 02:31:08 +00:00
//重新设置MethodRouter//直达路由
that.MethodRouter = MethodRouter{}
2019-05-19 15:33:01 +00:00
modeRouterStrict := true
if that.Config.GetBool("modeRouterStrict") == false {
2019-05-19 15:33:01 +00:00
modeRouterStrict = false
2018-11-15 03:44:50 +00:00
}
2021-12-27 12:40:16 +00:00
if that.Router != nil {
for pk, pv := range that.Router {
2019-05-19 15:33:01 +00:00
if !modeRouterStrict {
pk = strings.ToLower(pk)
2018-11-15 03:44:50 +00:00
}
2019-05-19 15:33:01 +00:00
if pv != nil {
for ck, cv := range pv {
if !modeRouterStrict {
ck = strings.ToLower(ck)
2018-11-15 03:44:50 +00:00
}
2019-05-19 15:33:01 +00:00
if cv != nil {
for mk, mv := range cv {
if !modeRouterStrict {
mk = strings.ToLower(mk)
2018-11-14 02:31:08 +00:00
}
that.MethodRouter["/"+pk+"/"+ck+"/"+mk] = mv
2018-11-14 02:31:08 +00:00
}
2019-05-19 15:33:01 +00:00
}
2018-11-14 02:31:08 +00:00
}
}
}
}
//that.Port = port
that.Port = that.Config.GetString("port")
that.TLSPort = that.Config.GetString("tlsPort")
2017-08-17 02:14:59 +00:00
if that.connectDbFunc != nil && (that.Db.DB == nil || that.Db.DB.Ping() != nil) {
that.Db.SetConnect(that.connectDbFunc)
2017-08-17 02:14:59 +00:00
}
2017-10-13 09:52:34 +00:00
//异常处理
defer func() {
if err := recover(); err != nil {
//that.SetError(errors.New(fmt.Sprint(err)), LOG_FMT)
that.Log.Warn(err)
that.Run(router)
2017-10-13 09:52:34 +00:00
}
}()
that.Server = &http.Server{}
2017-10-27 04:28:47 +00:00
if !IsRun {
IsRun = true
}
2019-05-27 05:46:03 +00:00
ch := make(chan int)
if ObjToCeilInt(that.Port) != 0 {
2019-11-10 10:00:45 +00:00
go func() {
2019-07-01 04:35:04 +00:00
App[that.Port] = that
that.Server.Handler = that
2019-05-27 05:46:03 +00:00
//启动服务
that.Server.Addr = ":" + that.Port
err := that.Server.ListenAndServe()
that.Log.Error(err)
2019-11-10 10:00:45 +00:00
ch <- 1
2019-05-27 05:46:03 +00:00
2019-11-10 10:00:45 +00:00
}()
2020-07-16 17:10:28 +00:00
}
if ObjToCeilInt(that.TLSPort) != 0 {
2019-07-01 04:35:04 +00:00
go func() {
2019-05-27 05:46:03 +00:00
App[that.TLSPort] = that
that.Server.Handler = that
2019-11-10 10:00:45 +00:00
//启动服务
that.Server.Addr = ":" + that.TLSPort
err := that.Server.ListenAndServeTLS(that.Config.GetString("tlsCert"), that.Config.GetString("tlsKey"))
that.Log.Error(err)
2019-11-10 10:00:45 +00:00
ch <- 2
2019-07-01 04:35:04 +00:00
}()
2020-07-16 17:10:28 +00:00
}
if ObjToCeilInt(that.Port) == 0 && ObjToCeilInt(that.TLSPort) == 0 {
that.Log.Error("没有端口启用")
2019-07-01 04:35:04 +00:00
return
}
2019-11-10 10:00:45 +00:00
value := <-ch
2017-08-17 02:14:59 +00:00
that.Log.Error("启动服务失败 : " + ObjToStr(value))
2017-08-17 02:14:59 +00:00
}
// SetConnectDB 启动实例
func (that *Application) SetConnectDB(connect func(err ...*Error) (master, slave *sql.DB)) {
2019-05-27 17:01:13 +00:00
that.connectDbFunc = connect
2021-05-25 11:53:34 +00:00
that.Db.SetConnect(that.connectDbFunc, &that.Error)
2019-05-27 17:01:13 +00:00
2017-08-17 02:14:59 +00:00
}
// SetDefault 默认配置缓存和session实现
func (that *Application) SetDefault(connect func(err ...*Error) (*sql.DB, *sql.DB)) {
that.SetConfig()
2019-11-10 10:10:26 +00:00
if connect != nil {
that.connectDbFunc = connect
that.Db.SetConnect(that.connectDbFunc)
2017-10-24 01:31:20 +00:00
}
2017-08-17 02:14:59 +00:00
}
// SetCache 设置配置文件路径全路径或者相对路径
func (that *Application) SetCache() {
cacheIns := HoTimeCache{}
cacheIns.Init(that.Config.GetMap("cache"), HoTimeDBInterface(&that.Db), &that.Error)
that.HoTimeCache = &cacheIns
//mode生产模式开启的时候才开启数据库缓存防止调试出问题
if that.Config.GetInt("mode") == 0 {
2021-05-29 16:01:15 +00:00
that.Db.HoTimeCache = &cacheIns
}
2017-08-17 02:14:59 +00:00
}
// SetConfig 设置配置文件路径全路径或者相对路径
func (that *Application) SetConfig(configPath ...string) {
that.Log = GetLog("", true)
2021-05-25 11:53:34 +00:00
that.Error = Error{Logger: that.Log}
2017-08-17 02:14:59 +00:00
if len(configPath) != 0 {
that.configPath = configPath[0]
2017-08-17 02:14:59 +00:00
}
if that.configPath == "" {
that.configPath = "config/config.json"
2017-08-17 02:14:59 +00:00
}
//加载配置文件
btes, err := ioutil.ReadFile(that.configPath)
that.Config = DeepCopyMap(Config).(Map)
2017-08-17 02:14:59 +00:00
if err == nil {
cmap := Map{}
//文件是否损坏
cmap.JsonToMap(string(btes), &that.Error)
2017-08-17 02:14:59 +00:00
for k, v := range cmap {
that.Config[k] = v //程序配置
Config[k] = v //系统配置
2017-08-17 02:14:59 +00:00
}
2019-11-10 10:00:45 +00:00
} else {
that.Log.Error("配置文件不存在,或者配置出错,使用缺省默认配置")
2019-05-27 05:46:03 +00:00
2017-08-17 02:14:59 +00:00
}
2019-09-03 03:55:05 +00:00
2022-08-03 04:07:55 +00:00
if that.Error.GetError() != nil {
fmt.Println(that.Error.GetError().Error())
2021-05-24 21:28:56 +00:00
}
2017-08-17 02:14:59 +00:00
//文件如果损坏则不写入配置防止配置文件数据丢失
if that.Error.GetError() == nil {
2021-06-04 18:18:56 +00:00
//var configByte bytes.Buffer
2017-08-17 02:14:59 +00:00
2021-05-24 21:28:56 +00:00
//判断配置文件是否序列有变化,有则修改配置,无则不变
2019-07-01 04:35:04 +00:00
//fmt.Println(len(btes))
2021-06-04 18:18:56 +00:00
configStr := that.Config.ToJsonString()
if len(btes) != 0 && configStr == string(btes) {
2019-07-01 04:35:04 +00:00
return
}
//写入配置说明
2021-06-04 18:18:56 +00:00
//var configNoteByte bytes.Buffer
configNoteStr := ConfigNote.ToJsonString()
//_ = json.Indent(&configNoteByte, []byte(ConfigNote.ToJsonString()), "", "\t")
_ = os.MkdirAll(filepath.Dir(that.configPath), os.ModeDir)
2021-06-04 18:18:56 +00:00
err = ioutil.WriteFile(that.configPath, []byte(configStr), os.ModePerm)
2017-08-17 02:14:59 +00:00
if err != nil {
that.Error.SetError(err)
2017-08-17 02:14:59 +00:00
}
2021-06-04 18:18:56 +00:00
_ = ioutil.WriteFile(filepath.Dir(that.configPath)+"/configNote.json", []byte(configNoteStr), os.ModePerm)
2017-08-17 02:14:59 +00:00
}
2022-08-03 04:07:55 +00:00
that.Log = GetLog(that.Config.GetString("logFile"), true)
that.Error = Error{Logger: that.Log}
if that.Config.Get("webConnectLogShow") == nil || that.Config.GetBool("webConnectLogShow") {
that.WebConnectLog = GetLog(that.Config.GetString("webConnectLogFile"), false)
}
2017-08-17 02:14:59 +00:00
}
2022-03-13 09:02:19 +00:00
// SetConnectListener 连接判断,返回false继续传输至控制层true则停止传输
func (that *Application) SetConnectListener(lis func(that *Context) (isFinished bool)) {
that.connectListener = append(that.connectListener, lis)
2017-08-17 02:14:59 +00:00
}
//网络错误
2022-03-12 17:48:54 +00:00
//func (that *Application) session(w http.ResponseWriter, req *http.Request) {
2018-04-03 17:54:27 +00:00
//
//}
2017-08-17 02:14:59 +00:00
2017-08-22 08:24:55 +00:00
//序列化链接
func (that *Application) urlSer(url string) (string, []string) {
2017-08-22 08:24:55 +00:00
q := strings.Index(url, "?")
2017-08-17 02:14:59 +00:00
if q == -1 {
2017-08-22 08:24:55 +00:00
q = len(url)
2017-08-17 02:14:59 +00:00
}
2017-08-22 08:24:55 +00:00
o := Substr(url, 0, q)
2017-08-17 02:14:59 +00:00
r := strings.SplitN(o, "/", -1)
var s = make([]string, 0)
for i := 0; i < len(r); i++ {
if !strings.EqualFold("", r[i]) {
s = append(s, r[i])
}
}
2017-08-22 08:24:55 +00:00
return o, s
}
//访问
2018-11-15 03:44:50 +00:00
func (that *Application) handler(w http.ResponseWriter, req *http.Request) {
2021-11-07 22:49:34 +00:00
nowUnixTime := time.Now()
2017-08-22 08:24:55 +00:00
_, s := that.urlSer(req.RequestURI)
2017-08-22 08:24:55 +00:00
//获取cookie
// 如果cookie存在直接将sessionId赋值为cookie.Value
// 如果cookie不存在就查找传入的参数中是否有token
// 如果token不存在就生成随机的sessionId
// 如果token存在就判断token是否在Session中有保存
// 如果有取出token并复制给cookie
// 没有保存就生成随机的session
cookie, err := req.Cookie(that.Config.GetString("sessionName"))
2017-08-22 08:24:55 +00:00
sessionId := Md5(strconv.Itoa(Rand(10)))
2021-12-28 01:26:26 +00:00
needSetCookie := ""
2021-12-11 09:59:02 +00:00
token := req.Header.Get("Authorization")
2021-12-09 03:16:15 +00:00
if len(token) != 32 {
2021-05-28 18:57:03 +00:00
2021-12-11 09:59:02 +00:00
token = req.FormValue("token")
}
//没有cookie或者cookie不等于token
//有token优先token
if len(token) == 32 {
2021-12-09 03:16:15 +00:00
sessionId = token
2021-12-11 09:59:02 +00:00
//没有token则查阅session
2022-11-14 02:38:15 +00:00
if cookie == nil || cookie.Value != sessionId {
needSetCookie = sessionId
}
2021-12-11 09:59:02 +00:00
} else if err == nil && cookie.Value != "" {
2021-12-09 03:16:15 +00:00
sessionId = cookie.Value
2021-12-11 09:59:02 +00:00
//session也没有则判断是否创建cookie
} else {
2021-12-28 01:26:26 +00:00
needSetCookie = sessionId
2017-08-22 08:24:55 +00:00
}
2017-08-17 02:14:59 +00:00
2019-05-19 15:33:01 +00:00
unescapeUrl, err := url.QueryUnescape(req.RequestURI)
if err != nil {
unescapeUrl = req.RequestURI
2018-11-06 14:57:53 +00:00
}
2017-08-22 08:24:55 +00:00
//访问实例
context := Context{SessionIns: SessionIns{SessionId: sessionId, HoTimeCache: that.HoTimeCache},
Resp: w, Req: req, Application: that, RouterString: s, Config: that.Config, Db: &that.Db,
HandlerStr: unescapeUrl}
2017-10-11 09:45:22 +00:00
//header默认设置
header := w.Header()
2017-10-12 02:07:51 +00:00
header.Set("Content-Type", "text/html; charset=utf-8")
2018-11-14 16:10:41 +00:00
//url去掉参数并序列化
context.HandlerStr, context.RouterString = that.urlSer(context.HandlerStr)
2018-11-14 16:10:41 +00:00
//跨域设置
2021-12-28 01:26:26 +00:00
that.crossDomain(&context, needSetCookie)
2021-11-07 22:49:34 +00:00
defer func() {
//是否展示日志
if that.WebConnectLog != nil {
2022-09-01 16:04:23 +00:00
2021-11-07 22:49:34 +00:00
//负载均衡优化
2022-09-01 16:04:23 +00:00
ipStr := ""
if req.Header.Get("X-Forwarded-For") != "" {
ipStr = req.Header.Get("X-Forwarded-For")
} else if req.Header.Get("X-Real-IP") != "" {
ipStr = req.Header.Get("X-Real-IP")
}
//负载均衡优化
if ipStr == "" {
//RemoteAddr := that.Req.RemoteAddr
ipStr = Substr(context.Req.RemoteAddr, 0, strings.Index(context.Req.RemoteAddr, ":"))
2021-11-07 22:49:34 +00:00
}
2021-12-28 01:26:26 +00:00
2021-11-07 22:49:34 +00:00
that.WebConnectLog.Infoln(ipStr, context.Req.Method,
"time cost:", ObjToFloat64(time.Now().UnixNano()-nowUnixTime.UnixNano())/1000000.00, "ms",
"data length:", ObjToFloat64(context.DataSize)/1000.00, "KB", context.HandlerStr)
}
}()
2020-02-20 07:06:39 +00:00
2017-08-22 08:24:55 +00:00
//访问拦截true继续false暂停
2022-08-25 05:06:26 +00:00
connectListenerLen := len(that.connectListener) - 1
2022-03-13 09:02:19 +00:00
2022-08-25 05:06:26 +00:00
for true {
if connectListenerLen < 0 {
break
}
if that.connectListener[connectListenerLen](&context) {
2022-03-13 09:02:19 +00:00
context.View()
return
2017-08-22 08:24:55 +00:00
}
2022-08-25 05:06:26 +00:00
connectListenerLen--
2017-08-22 08:24:55 +00:00
}
2018-11-14 16:10:41 +00:00
2017-08-17 02:14:59 +00:00
//接口服务
2018-11-15 03:44:50 +00:00
//验证接口严格模式
modeRouterStrict := that.Config.GetBool("modeRouterStrict")
2019-05-19 15:33:01 +00:00
tempHandlerStr := context.HandlerStr
if !modeRouterStrict {
tempHandlerStr = strings.ToLower(tempHandlerStr)
2018-11-15 03:44:50 +00:00
}
2017-08-17 02:14:59 +00:00
2018-11-15 03:44:50 +00:00
//执行接口
if that.MethodRouter[tempHandlerStr] != nil {
that.MethodRouter[tempHandlerStr](&context)
2019-05-19 15:33:01 +00:00
context.View()
return
2017-08-17 02:14:59 +00:00
}
//url赋值
path := that.Config.GetString("tpt") + tempHandlerStr
2017-08-17 02:14:59 +00:00
//判断是否为默认
if path[len(path)-1] == '/' {
defFile := that.Config.GetSlice("defFile")
2017-10-27 04:28:47 +00:00
2017-08-17 02:14:59 +00:00
for i := 0; i < len(defFile); i++ {
2017-10-27 04:28:47 +00:00
temp := path + defFile.GetString(i)
2017-08-17 02:14:59 +00:00
_, err := os.Stat(temp)
if err == nil {
path = temp
break
}
}
if path[len(path)-1] == '/' {
w.WriteHeader(404)
return
}
}
if strings.Contains(path, "/.") {
w.WriteHeader(404)
return
}
2017-10-12 02:07:51 +00:00
//设置header
2019-05-19 15:33:01 +00:00
delete(header, "Content-Type")
if that.Config.GetInt("mode") == 0 {
2018-05-29 17:39:37 +00:00
header.Set("Cache-Control", "public")
} else {
header.Set("Cache-Control", "no-cache")
2018-05-29 17:39:37 +00:00
}
2017-10-12 02:07:51 +00:00
2022-03-02 04:14:07 +00:00
t := strings.LastIndex(path, ".")
if t != -1 {
tt := path[t:]
if MimeMaps[tt] != "" {
header.Add("Content-Type", MimeMaps[tt])
}
2019-05-19 15:33:01 +00:00
}
2017-08-17 02:14:59 +00:00
//w.Write(data)
http.ServeFile(w, req, path)
}
2021-12-28 01:26:26 +00:00
func (that *Application) crossDomain(context *Context, sessionId string) {
//没有跨域设置
2020-02-21 13:44:53 +00:00
if context.Config.GetString("crossDomain") == "" {
2021-12-28 01:26:26 +00:00
if sessionId != "" {
http.SetCookie(context.Resp, &http.Cookie{Name: that.Config.GetString("sessionName"), Value: sessionId, Path: "/"})
}
return
}
2020-02-21 13:44:53 +00:00
header := context.Resp.Header()
2021-12-17 06:37:41 +00:00
//不跨域,则不设置
remoteHost := context.Req.Host
2021-12-27 06:00:08 +00:00
if context.Config.GetString("port") == "80" || context.Config.GetString("port") == "443" {
2021-12-17 06:37:41 +00:00
remoteHost = remoteHost + ":" + context.Config.GetString("port")
}
2021-05-22 19:35:49 +00:00
if context.Config.GetString("crossDomain") != "auto" {
2021-12-17 06:37:41 +00:00
//不跨域,则不设置
if strings.Contains(context.Config.GetString("crossDomain"), remoteHost) {
2021-12-28 01:26:26 +00:00
if sessionId != "" {
http.SetCookie(context.Resp, &http.Cookie{Name: that.Config.GetString("sessionName"), Value: sessionId, Path: "/"})
}
2021-12-17 06:37:41 +00:00
return
}
header.Set("Access-Control-Allow-Origin", that.Config.GetString("crossDomain"))
2021-07-04 18:20:10 +00:00
// 后端设置2592000单位秒这里是30天
header.Set("Access-Control-Max-Age", "2592000")
2021-12-17 06:37:41 +00:00
//header.Set("Access-Control-Allow-Origin", "*")
header.Set("Access-Control-Allow-Methods", "GET,POST,OPTIONS,PUT,DELETE")
header.Set("Access-Control-Allow-Credentials", "true")
header.Set("Access-Control-Expose-Headers", "*")
header.Set("Access-Control-Allow-Headers", "X-Requested-With,Content-Type,Access-Token")
2021-12-28 01:26:26 +00:00
if sessionId != "" {
//跨域允许需要设置cookie的允许跨域https才有效果
context.Resp.Header().Set("Set-Cookie", that.Config.GetString("sessionName")+"="+sessionId+"; Path=/; SameSite=None; Secure")
}
return
}
2020-02-21 13:44:53 +00:00
origin := context.Req.Header.Get("Origin")
2021-12-17 06:37:41 +00:00
refer := context.Req.Header.Get("Referer")
2021-12-28 01:26:26 +00:00
if (origin != "" && strings.Contains(origin, remoteHost)) || strings.Contains(refer, remoteHost) {
if sessionId != "" {
http.SetCookie(context.Resp, &http.Cookie{Name: that.Config.GetString("sessionName"), Value: sessionId, Path: "/"})
}
2021-12-17 06:37:41 +00:00
return
}
if origin != "" {
header.Set("Access-Control-Allow-Origin", origin)
2021-12-27 06:00:08 +00:00
//return
2021-12-28 01:26:26 +00:00
} else if refer != "" {
tempInt := 0
lastInt := strings.IndexFunc(refer, func(r rune) bool {
if r == '/' && tempInt > 8 {
return true
}
tempInt++
return false
})
if lastInt < 0 {
lastInt = len(refer)
}
refer = Substr(refer, 0, lastInt)
header.Set("Access-Control-Allow-Origin", refer)
2021-12-17 06:37:41 +00:00
//header.Set("Access-Control-Allow-Origin", "*")
2021-12-28 01:26:26 +00:00
}
header.Set("Access-Control-Allow-Methods", "GET,POST,OPTIONS,PUT,DELETE")
header.Set("Access-Control-Allow-Credentials", "true")
header.Set("Access-Control-Expose-Headers", "*")
header.Set("Access-Control-Allow-Headers", "X-Requested-With,Content-Type,Access-Token")
if sessionId != "" {
//跨域允许需要设置cookie的允许跨域https才有效果
context.Resp.Header().Set("Set-Cookie", that.Config.GetString("sessionName")+"="+sessionId+"; Path=/; SameSite=None; Secure")
}
2021-12-28 01:26:26 +00:00
}
2021-05-23 23:27:41 +00:00
//Init 初始化application
2022-04-20 14:47:58 +00:00
func Init(config string) *Application {
2021-05-23 21:47:56 +00:00
appIns := Application{}
//手动模式,
appIns.SetConfig(config)
2021-05-25 11:53:34 +00:00
2021-05-23 22:14:58 +00:00
SetDB(&appIns)
appIns.SetCache()
2022-03-13 09:02:19 +00:00
codeConfig := appIns.Config.GetSlice("codeConfig")
2022-03-12 21:06:28 +00:00
if codeConfig != nil {
2022-03-03 13:23:57 +00:00
for k, _ := range codeConfig {
2022-03-12 21:06:28 +00:00
codeMake := codeConfig.GetMap(k)
if codeMake == nil {
continue
}
2022-03-13 09:02:19 +00:00
//codeMake["table"] = k
2022-03-12 21:06:28 +00:00
if appIns.MakeCodeRouter == nil {
appIns.MakeCodeRouter = map[string]*code.MakeCode{}
}
2022-03-13 09:02:19 +00:00
if codeMake.GetString("name") == "" {
codeMake["name"] = codeMake.GetString("table")
}
appIns.MakeCodeRouter[codeMake.GetString("name")] = &code.MakeCode{Error: appIns.Error}
appIns.MakeCodeRouter[codeMake.GetString("name")].Db2JSON(&appIns.Db, codeMake)
2022-07-11 11:13:20 +00:00
2021-12-27 12:40:16 +00:00
//接入动态代码层
if appIns.Router == nil {
appIns.Router = Router{}
}
2022-03-12 21:06:28 +00:00
//appIns.Router[codeMake.GetString("name")] = TptProject
appIns.Router[codeMake.GetString("name")] = Proj{}
for k2, _ := range TptProject {
appIns.Router[codeMake.GetString("name")][k2] = Ctr{}
for k3, v3 := range TptProject[k2] {
appIns.Router[codeMake.GetString("name")][k2][k3] = v3
}
}
2022-03-12 21:06:28 +00:00
for k1, _ := range appIns.MakeCodeRouter[codeMake.GetString("name")].TableColumns {
appIns.Router[codeMake.GetString("name")][k1] = appIns.Router[codeMake.GetString("name")]["hotimeCommon"]
2021-09-11 21:35:14 +00:00
}
2021-12-27 12:40:16 +00:00
2022-08-25 05:02:44 +00:00
setMakeCodeListener(codeMake.GetString("name"), &appIns)
2021-12-27 12:40:16 +00:00
}
}
2022-04-20 14:47:58 +00:00
return &appIns
2021-05-23 21:47:56 +00:00
}
2021-05-23 23:27:41 +00:00
// SetDB 智能数据库设置
2021-05-23 23:27:41 +00:00
func SetDB(appIns *Application) {
db := appIns.Config.GetMap("db")
dbSqlite := db.GetMap("sqlite")
dbMysql := db.GetMap("mysql")
if db != nil && dbSqlite != nil {
SetSqliteDB(appIns, dbSqlite)
}
if db != nil && dbMysql != nil {
SetMysqlDB(appIns, dbMysql)
}
}
func SetMysqlDB(appIns *Application, config Map) {
2021-05-25 11:53:34 +00:00
appIns.Db.Type = "mysql"
2021-06-04 18:18:56 +00:00
appIns.Db.DBName = config.GetString("name")
2021-05-28 16:37:20 +00:00
appIns.Db.Prefix = config.GetString("prefix")
2022-07-11 03:07:17 +00:00
appIns.Db.Log = appIns.Log
appIns.Db.Mode = appIns.Config.GetCeilInt("mode")
2021-05-23 23:27:41 +00:00
appIns.SetConnectDB(func(err ...*Error) (master, slave *sql.DB) {
//master数据库配置
query := config.GetString("user") + ":" + config.GetString("password") +
"@tcp(" + config.GetString("host") + ":" + config.GetString("port") + ")/" + config.GetString("name") + "?charset=utf8"
DB, e := sql.Open("mysql", query)
if e != nil && len(err) != 0 {
err[0].SetError(e)
}
master = DB
//slave数据库配置
configSlave := config.GetMap("slave")
if configSlave != nil {
query := configSlave.GetString("user") + ":" + configSlave.GetString("password") +
"@tcp(" + config.GetString("host") + ":" + configSlave.GetString("port") + ")/" + configSlave.GetString("name") + "?charset=utf8"
DB1, e := sql.Open("mysql", query)
if e != nil && len(err) != 0 {
err[0].SetError(e)
}
slave = DB1
}
return master, slave
//return DB
})
}
func SetSqliteDB(appIns *Application, config Map) {
2021-05-25 11:53:34 +00:00
appIns.Db.Type = "sqlite"
2021-05-28 16:37:20 +00:00
appIns.Db.Prefix = config.GetString("prefix")
2022-07-11 03:07:17 +00:00
appIns.Db.Mode = appIns.Config.GetCeilInt("mode")
appIns.Db.Log = appIns.Log
2021-05-23 23:27:41 +00:00
appIns.SetConnectDB(func(err ...*Error) (master, slave *sql.DB) {
db, e := sql.Open("sqlite3", config.GetString("path"))
if e != nil && len(err) != 0 {
err[0].SetError(e)
}
master = db
return master, slave
})
}
2021-12-27 12:40:16 +00:00
2022-08-25 05:02:44 +00:00
func setMakeCodeListener(name string, appIns *Application) {
2022-03-13 09:02:19 +00:00
appIns.SetConnectListener(func(context *Context) (isFinished bool) {
2021-12-27 12:40:16 +00:00
2022-03-14 08:48:19 +00:00
codeIns := appIns.MakeCodeRouter[name]
2021-12-27 12:40:16 +00:00
2022-03-14 08:48:19 +00:00
if len(context.RouterString) < 2 || appIns.MakeCodeRouter[context.RouterString[0]] == nil {
return isFinished
}
if len(context.RouterString) > 1 && context.RouterString[0] == name {
if context.RouterString[1] == "hotime" && context.RouterString[2] == "login" {
return isFinished
}
if context.RouterString[1] == "hotime" && context.RouterString[2] == "logout" {
return isFinished
}
2022-07-20 16:24:39 +00:00
if context.RouterString[1] == "hotime" && context.RouterString[2] == "config" {
return isFinished
}
2022-10-08 08:52:42 +00:00
if context.RouterString[1] == "hotime" && context.RouterString[2] == "wallpaper" {
return isFinished
}
2022-03-14 08:48:19 +00:00
if context.Session(codeIns.FileConfig.GetString("table")+"_id").Data == nil {
context.Display(2, "你还没有登录")
return true
}
}
2021-12-27 12:40:16 +00:00
if len(context.RouterString) < 2 || len(context.RouterString) > 3 ||
!(context.Router[context.RouterString[0]] != nil &&
context.Router[context.RouterString[0]][context.RouterString[1]] != nil) {
2022-03-13 09:02:19 +00:00
return isFinished
2021-12-27 12:40:16 +00:00
}
//排除无效操作
if len(context.RouterString) == 2 &&
context.Req.Method != "GET" &&
context.Req.Method != "POST" {
2022-03-13 09:02:19 +00:00
return isFinished
2021-12-27 12:40:16 +00:00
}
2022-06-08 20:05:50 +00:00
//排除已有接口的无效操作
if len(context.RouterString) == 3 && context.Router[context.RouterString[0]] != nil && context.Router[context.RouterString[0]][context.RouterString[1]] != nil && context.Router[context.RouterString[0]][context.RouterString[1]][context.RouterString[2]] != nil {
return isFinished
}
2021-12-27 12:40:16 +00:00
//列表检索
if len(context.RouterString) == 2 &&
context.Req.Method == "GET" {
if context.Router[context.RouterString[0]][context.RouterString[1]]["search"] == nil {
2022-03-13 09:02:19 +00:00
return isFinished
2021-12-27 12:40:16 +00:00
}
context.Router[context.RouterString[0]][context.RouterString[1]]["search"](context)
}
//新建
if len(context.RouterString) == 2 &&
context.Req.Method == "POST" {
if context.Router[context.RouterString[0]][context.RouterString[1]]["add"] == nil {
return true
}
context.Router[context.RouterString[0]][context.RouterString[1]]["add"](context)
}
if len(context.RouterString) == 3 &&
context.Req.Method == "POST" {
2022-03-13 09:02:19 +00:00
return isFinished
2021-12-27 12:40:16 +00:00
}
//查询单条
if len(context.RouterString) == 3 &&
context.Req.Method == "GET" {
if context.Router[context.RouterString[0]][context.RouterString[1]]["info"] == nil {
2022-03-13 09:02:19 +00:00
return isFinished
2021-12-27 12:40:16 +00:00
}
context.Router[context.RouterString[0]][context.RouterString[1]]["info"](context)
}
//更新
if len(context.RouterString) == 3 &&
context.Req.Method == "PUT" {
if context.Router[context.RouterString[0]][context.RouterString[1]]["update"] == nil {
return true
}
context.Router[context.RouterString[0]][context.RouterString[1]]["update"](context)
}
//移除
if len(context.RouterString) == 3 &&
context.Req.Method == "DELETE" {
if context.Router[context.RouterString[0]][context.RouterString[1]]["remove"] == nil {
return true
}
context.Router[context.RouterString[0]][context.RouterString[1]]["remove"](context)
}
2022-03-13 09:02:19 +00:00
2022-08-25 06:06:31 +00:00
//context.View()
2022-03-13 09:02:19 +00:00
return true
2021-12-27 12:40:16 +00:00
})
}