65 Star 396 Fork 128

admpub/nging

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
notice.go 2.81 KB
一键复制 编辑 原始数据 按行查看 历史
admpub 提交于 2019-05-10 23:35 . v2.0.0
/*
Nging is a toolbox for webmasters
Copyright (C) 2018-present Wenhui Shen <swh@admpub.com>
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as published
by the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
package user
import (
"encoding/json"
"github.com/admpub/log"
"github.com/admpub/nging/application/dbschema"
"github.com/admpub/nging/application/handler"
"github.com/admpub/nging/application/library/notice"
"github.com/admpub/websocket"
"github.com/webx-top/echo"
)
func init() {
notice.OnOpen(func(user string) {
userM := &dbschema.User{}
err := userM.SetField(nil, `online`, `Y`, `username`, user)
if err != nil {
log.Error(err)
}
})
notice.OnClose(func(user string) {
userM := &dbschema.User{}
err := userM.SetField(nil, `online`, `N`, `username`, user)
if err != nil {
log.Error(err)
}
})
}
func Notice(c *websocket.Conn, ctx echo.Context) error {
user := handler.User(ctx)
if user == nil {
return ctx.E(`登录信息获取失败,请重新登录`)
}
clientID := notice.OpenClient(user.Username)
defer notice.CloseClient(user.Username, clientID)
//push(writer)
go func() {
message, err := json.Marshal(notice.NewMessage().SetMode(`-`).SetType(`clientID`).SetClientID(clientID))
if err != nil {
handler.WebSocketLogger.Error(`Push error: `, err.Error())
}
handler.WebSocketLogger.Debug(`Push message: `, string(message))
if err = c.WriteMessage(websocket.TextMessage, message); err != nil {
handler.WebSocketLogger.Error(`Push error: `, err.Error())
return
}
for {
//message := []byte(echo.Dump(notice.NewMessageWithValue(`type`, `title`, `content:`+time.Now().Format(time.RFC1123)), false))
//time.Sleep(time.Second)
message = notice.RecvJSON(user.Username, clientID)
handler.WebSocketLogger.Debug(`Push message: `, string(message))
if err = c.WriteMessage(websocket.TextMessage, message); err != nil {
handler.WebSocketLogger.Error(`Push error: `, err.Error())
return
}
}
}()
//echo
var execute = func(conn *websocket.Conn) error {
for {
mt, message, err := conn.ReadMessage()
if err != nil {
return err
}
if err = conn.WriteMessage(mt, message); err != nil {
return err
}
}
}
err := execute(c)
if err != nil {
handler.WebSocketLogger.Error(err)
}
return nil
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/admpub/nging.git
git@gitee.com:admpub/nging.git
admpub
nging
nging
v2.0.3

搜索帮助

0d507c66 1850385 C8b1a773 1850385