2025-06-23 13:39:19 +08:00
|
|
|
package middleware
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"blazing/modules/base/config"
|
2025-07-02 23:01:54 +08:00
|
|
|
"fmt"
|
2025-06-23 13:39:19 +08:00
|
|
|
"net/http"
|
|
|
|
|
|
|
|
|
|
"github.com/gogf/gf/v2/frame/g"
|
|
|
|
|
"github.com/gogf/gf/v2/net/ghttp"
|
2025-07-02 23:01:54 +08:00
|
|
|
"github.com/lxzan/gws"
|
2025-06-23 13:39:19 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func MiddlewareCORS(r *ghttp.Request) {
|
|
|
|
|
r.Response.CORSDefault()
|
|
|
|
|
corsOptions := r.Response.DefaultCORSOptions()
|
|
|
|
|
corsOptions.AllowDomain = []string{"*"}
|
|
|
|
|
if !r.Response.CORSAllowedOrigin(corsOptions) {
|
|
|
|
|
r.Response.WriteStatus(http.StatusForbidden)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
r.Response.CORS(corsOptions)
|
|
|
|
|
if r.Response.Request.Method == "OPTIONS" {
|
|
|
|
|
r.Response.WriteStatus(http.StatusOK)
|
|
|
|
|
return
|
|
|
|
|
}
|
2025-06-24 22:09:05 +08:00
|
|
|
// fmt.Println(r.Response.Header())
|
2025-06-23 13:39:19 +08:00
|
|
|
//g.Dump(r.Response.Server.SetConfig(gtt))
|
|
|
|
|
//r.Response.Header().Del("Server") // 删除Server头
|
|
|
|
|
// r.Response.Header().Set("Server", "blazing")
|
|
|
|
|
r.Middleware.Next()
|
|
|
|
|
}
|
|
|
|
|
func init() {
|
|
|
|
|
if config.Config.Middleware.Authority.Enable {
|
|
|
|
|
g.Server().BindMiddleware("/admin/*/open/*", BaseAuthorityMiddlewareOpen)
|
|
|
|
|
g.Server().BindMiddleware("/admin/*/comm/*", BaseAuthorityMiddlewareComm)
|
|
|
|
|
g.Server().BindMiddleware("/admin/*", BaseAuthorityMiddleware)
|
|
|
|
|
g.Server().BindMiddleware("/*", AutoI18n)
|
|
|
|
|
g.Server().BindMiddleware("/*", MiddlewareCORS)
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
if config.Config.Middleware.Log.Enable {
|
|
|
|
|
g.Server().BindMiddleware("/admin/*", BaseLog)
|
|
|
|
|
}
|
2025-07-02 23:01:54 +08:00
|
|
|
g.Server().BindHandler("/ws", func(r *ghttp.Request) {
|
2025-06-23 13:39:19 +08:00
|
|
|
|
2025-07-02 23:01:54 +08:00
|
|
|
upgrader := gws.NewUpgrader(new(Handler), &gws.ServerOption{
|
|
|
|
|
//CompressEnabled: true,
|
|
|
|
|
|
|
|
|
|
// 在querystring里面传入用户名
|
|
|
|
|
// 把Sec-WebSocket-Key作为连接的key
|
|
|
|
|
|
|
|
|
|
// 刷新页面的时候, 会触发上一个连接的OnClose/OnError事件, 这时候需要对比key并删除map里存储的连接
|
|
|
|
|
Authorize: func(rt *http.Request, session gws.SessionStorage) bool {
|
|
|
|
|
//r.s\\\
|
|
|
|
|
// r.Get("t")
|
|
|
|
|
//admin := cool.GetAdmin(r.Context())
|
|
|
|
|
// var name = r.URL.Query().Get("name")
|
|
|
|
|
// if name == "" {
|
|
|
|
|
// return false
|
|
|
|
|
// }
|
|
|
|
|
// t, _ := service.NewBaseSysUserService().Person(admin.UserID)
|
|
|
|
|
|
|
|
|
|
//g.Log().Debug(context.TODO(), t.Mimi)
|
|
|
|
|
// session.Store("name", t.Mimi)
|
|
|
|
|
//session.Store("key", r.Header.Get("Sec-WebSocket-Key"))
|
|
|
|
|
return true
|
|
|
|
|
},
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
socket, err := upgrader.Upgrade(r.Response.Writer, r.Request)
|
|
|
|
|
if err != nil {
|
|
|
|
|
fmt.Println(err)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
// ants.Submit(func() {
|
|
|
|
|
// socket.ReadLoop()
|
|
|
|
|
// })
|
2025-07-02 23:29:30 +08:00
|
|
|
// ants.Submit(func() { socket.ReadLoop() })
|
2025-07-02 23:01:54 +08:00
|
|
|
go socket.ReadLoop()
|
|
|
|
|
|
|
|
|
|
})
|
2025-06-23 13:39:19 +08:00
|
|
|
}
|