Ai
1 Star 0 Fork 43

cl5/rttys

forked from 赵建辉/rttys 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
http.go 4.15 KB
一键复制 编辑 原始数据 按行查看 历史
赵建辉 提交于 2021-01-22 21:40 +08:00 . refactor
package main
import (
"net"
"net/http"
"path"
"time"
"github.com/gin-gonic/gin"
jsoniter "github.com/json-iterator/go"
"github.com/rakyll/statik/fs"
"github.com/rs/zerolog/log"
"github.com/zhaojh329/rttys/cache"
"github.com/zhaojh329/rttys/config"
_ "github.com/zhaojh329/rttys/statik"
"github.com/zhaojh329/rttys/utils"
)
type credentials struct {
Password string `json:"password"`
Username string `json:"username"`
}
var httpSessions *cache.Cache
func allowOrigin(w http.ResponseWriter) {
w.Header().Set("Access-Control-Allow-Origin", "*")
w.Header().Add("Access-Control-Allow-Headers", "Content-Type")
w.Header().Set("content-type", "application/json")
}
func httpLogin(cfg *config.Config, creds *credentials) bool {
if cfg.HTTPUsername != creds.Username {
return false
}
if cfg.HTTPPassword != "" {
return cfg.HTTPPassword == creds.Password
}
return true
}
func authorizedDev(devid string, cfg *config.Config) bool {
if cfg.WhiteList == nil {
return true
}
_, ok := cfg.WhiteList[devid]
return ok
}
func httpAuth(c *gin.Context) bool {
addr, _ := net.ResolveTCPAddr("tcp", c.Request.RemoteAddr)
if addr.IP.IsLoopback() {
return true
}
cookie, err := c.Cookie("sid")
if err != nil || !httpSessions.Have(cookie) {
return false
}
httpSessions.Active(cookie, 0)
return true
}
func httpStart(br *broker) {
cfg := br.cfg
httpSessions = cache.New(30*time.Minute, 5*time.Second)
gin.SetMode(gin.ReleaseMode)
r := gin.New()
authorized := r.Group("/", func(c *gin.Context) {
devid := c.Param("devid")
if devid != "" && authorizedDev(devid, cfg) {
return
}
if !httpAuth(c) {
c.AbortWithStatus(http.StatusUnauthorized)
}
})
authorized.GET("/fontsize/:devid", func(c *gin.Context) {
c.JSON(http.StatusOK, gin.H{"size": cfg.FontSize})
})
authorized.POST("/fontsize/:devid", func(c *gin.Context) {
type Resp struct {
Size int `json:"size"`
}
var r Resp
err := c.BindJSON(&r)
if err != nil {
c.Status(http.StatusBadRequest)
return
}
cfg.FontSize = r.Size
c.String(http.StatusOK, "OK")
})
authorized.GET("/connect/:devid", func(c *gin.Context) {
if c.GetHeader("Upgrade") != "websocket" {
c.Redirect(http.StatusFound, "/rtty/"+c.Param("devid"))
return
}
serveUser(br, c)
})
authorized.GET("/devs", func(c *gin.Context) {
type DeviceInfo struct {
ID string `json:"id"`
Connected uint32 `json:"connected"`
Uptime uint32 `json:"uptime"`
Description string `json:"description"`
}
devs := make([]DeviceInfo, 0)
for id, dev := range br.devices {
dev := dev.(*device)
devs = append(devs, DeviceInfo{id, uint32(time.Now().Unix() - dev.timestamp), dev.uptime, dev.desc})
}
allowOrigin(c.Writer)
c.JSON(http.StatusOK, devs)
})
authorized.POST("/cmd/:devid", func(c *gin.Context) {
allowOrigin(c.Writer)
handleCmdReq(br, c)
})
r.Any("/web/:devid/:addr/*path", func(c *gin.Context) {
webReqRedirect(br, c)
})
r.GET("/authorized/:devid", func(c *gin.Context) {
authorized := authorizedDev(c.Param("devid"), cfg) || httpAuth(c)
c.JSON(http.StatusOK, gin.H{
"authorized": authorized,
})
})
r.POST("/signin", func(c *gin.Context) {
var creds credentials
err := jsoniter.NewDecoder(c.Request.Body).Decode(&creds)
if err != nil {
c.Status(http.StatusBadRequest)
return
}
if httpLogin(cfg, &creds) {
sid := utils.GenUniqueID("http")
httpSessions.Set(sid, true, 0)
c.SetCookie("sid", sid, 0, "", "", false, true)
c.String(http.StatusOK, sid)
return
}
c.Status(http.StatusForbidden)
})
statikFS, err := fs.New()
if err != nil {
log.Fatal().Msg(err.Error())
}
r.NoRoute(func(c *gin.Context) {
f, err := statikFS.Open(path.Clean(c.Request.URL.Path))
if err != nil {
c.Request.URL.Path = "/"
r.HandleContext(c)
return
}
f.Close()
http.FileServer(statikFS).ServeHTTP(c.Writer, c.Request)
})
go func() {
if cfg.SslCert != "" && cfg.SslKey != "" {
log.Info().Msgf("Listen user on: %s SSL on", cfg.AddrUser)
err = r.RunTLS(cfg.AddrUser, cfg.SslCert, cfg.SslKey)
} else {
log.Info().Msgf("Listen user on: %s SSL off", cfg.AddrUser)
err = r.Run(cfg.AddrUser)
}
log.Fatal().Err(err)
}()
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/dadba/rttys.git
git@gitee.com:dadba/rttys.git
dadba
rttys
rttys
master

搜索帮助