代码拉取完成,页面将自动刷新
/*
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
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。