Compare commits
No commits in common. "196887fa8beeb76e2a0cf45d9b7a502bbbebb8b7" and "83552d12a24cee7217b801862325744760ac309e" have entirely different histories.
196887fa8b
...
83552d12a2
|
|
@ -11,7 +11,6 @@ import (
|
||||||
"time"
|
"time"
|
||||||
"videoplayer/dao"
|
"videoplayer/dao"
|
||||||
"videoplayer/proto"
|
"videoplayer/proto"
|
||||||
"videoplayer/service"
|
|
||||||
"videoplayer/worker"
|
"videoplayer/worker"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
@ -63,8 +62,7 @@ func RunCID(c *gin.Context) {
|
||||||
id, _ := c.Get("id")
|
id, _ := c.Get("id")
|
||||||
authID := int(id.(float64))
|
authID := int(id.(float64))
|
||||||
//获取权限
|
//获取权限
|
||||||
//user := dao.FindUserByUserID(authID)
|
user := dao.FindUserByUserID(authID)
|
||||||
user := service.GetUserByIDFromUserCenter(authID)
|
|
||||||
if user.Run == false {
|
if user.Run == false {
|
||||||
c.JSON(200, gin.H{"error": "no run Permissions", "code": proto.NoRunPermissions, "message": "no run Permissions"})
|
c.JSON(200, gin.H{"error": "no run Permissions", "code": proto.NoRunPermissions, "message": "no run Permissions"})
|
||||||
return
|
return
|
||||||
|
|
@ -199,8 +197,7 @@ func CIDCallback(c *gin.Context) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
//user := dao.FindUserByUserID(res.Auth_id)
|
user := dao.FindUserByUserID(res.Auth_id)
|
||||||
user := service.GetUserByIDFromUserCenter(res.Auth_id)
|
|
||||||
if user.Run == false {
|
if user.Run == false {
|
||||||
c.JSON(200, gin.H{"error": "no run Permissions", "code": proto.NoRunPermissions, "message": "the user has no run Permissions"})
|
c.JSON(200, gin.H{"error": "no run Permissions", "code": proto.NoRunPermissions, "message": "the user has no run Permissions"})
|
||||||
return
|
return
|
||||||
|
|
|
||||||
|
|
@ -4,7 +4,6 @@ import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"github.com/gin-gonic/gin"
|
"github.com/gin-gonic/gin"
|
||||||
"io"
|
"io"
|
||||||
"log"
|
|
||||||
"net/http"
|
"net/http"
|
||||||
"os"
|
"os"
|
||||||
"strconv"
|
"strconv"
|
||||||
|
|
@ -59,48 +58,40 @@ func SetUpToolGroup(router *gin.Engine) {
|
||||||
func SetDeviceStatusV2(c *gin.Context) {
|
func SetDeviceStatusV2(c *gin.Context) {
|
||||||
// TODO
|
// TODO
|
||||||
var req SetDeviceStatusReq
|
var req SetDeviceStatusReq
|
||||||
var resp proto.GeneralResp
|
|
||||||
if err := c.ShouldBind(&req); err != nil {
|
if err := c.ShouldBind(&req); err != nil {
|
||||||
resp.Code = proto.ParameterError
|
c.JSON(200, gin.H{"code": 400, "message": "参数错误"})
|
||||||
resp.Message = "参数解析失败:" + err.Error()
|
return
|
||||||
} else {
|
} else {
|
||||||
token := c.Request.Header.Get("token")
|
token := c.Request.Header.Get("token")
|
||||||
if token == "" {
|
if token == "" {
|
||||||
resp.Code = proto.TokenIsNull //token为空
|
c.JSON(200, gin.H{"code": 401, "message": "token为空"})
|
||||||
} else {
|
return
|
||||||
|
}
|
||||||
devices := worker.GetRedisSetMembers(token)
|
devices := worker.GetRedisSetMembers(token)
|
||||||
if len(devices) == 0 {
|
if len(devices) == 0 {
|
||||||
resp.Code = proto.MonitorServerIDIsNull
|
c.JSON(200, gin.H{"code": 402, "message": "设备为空"})
|
||||||
resp.Message = "服务器设备监控为空!"
|
return
|
||||||
} else {
|
}
|
||||||
isExit := false
|
|
||||||
for _, v := range devices {
|
for _, v := range devices {
|
||||||
if v == req.ID {
|
if v == req.ID {
|
||||||
// 继续处理请求
|
// 继续处理请求
|
||||||
//是否是暂停之后第一次上线,如果是则发送邮件通知
|
//是否是暂停之后第一次上线,如果是则发送邮件通知
|
||||||
deviceStatus := worker.GetRedis("monitor_" + req.ID)
|
device_status := worker.GetRedis("monitor_" + req.ID)
|
||||||
isExist := worker.IsContainKey("monitor_" + req.ID)
|
isExist := worker.IsContainKey("monitor_" + req.ID)
|
||||||
if deviceStatus == "2" || !isExist {
|
if device_status == "2" || !isExist {
|
||||||
//发送邮件通知
|
//发送邮件通知
|
||||||
title := "设备上线"
|
title := "设备上线"
|
||||||
content := "设备上线\n设备:" + req.ID + "\t状态:" + req.Status + "\t时间:" + time.Now().String()
|
content := "设备上线\n设备:" + req.ID + "\t状态:" + req.Status + "\t时间:" + time.Now().String()
|
||||||
go SendMail(title, content)
|
go SendMail(title, content)
|
||||||
}
|
}
|
||||||
worker.SetRedisWithExpire("monitor_"+req.ID, "1", time.Second*300)
|
worker.SetRedisWithExpire("monitor_"+req.ID, "1", time.Second*300)
|
||||||
resp.Code = proto.SuccessCode
|
c.JSON(200, gin.H{"code": 0, "message": "success"})
|
||||||
resp.Message = "success"
|
return
|
||||||
isExit = true
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if isExit == false {
|
c.JSON(200, gin.H{"code": 402, "message": "设备不存在"})
|
||||||
resp.Code = proto.MonitorServerIDNotFound
|
|
||||||
resp.Message = "设备不存在!"
|
|
||||||
log.Println("设备不存在,id:", req.ID, "\ttoken:", token, "\tdevices:", devices)
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
c.JSON(http.StatusOK, resp)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func GetFileList(c *gin.Context) {
|
func GetFileList(c *gin.Context) {
|
||||||
|
|
|
||||||
24
main.go
24
main.go
|
|
@ -33,7 +33,7 @@ func main() {
|
||||||
r.Use(handler.CrosHandler())
|
r.Use(handler.CrosHandler())
|
||||||
r.Use(JWTAuthMiddleware()) // 使用 JWT 认证中间件
|
r.Use(JWTAuthMiddleware()) // 使用 JWT 认证中间件
|
||||||
handler.SetUpVideoGroup(r) // Video
|
handler.SetUpVideoGroup(r) // Video
|
||||||
//handler.SetUpUserGroup(r) // User
|
handler.SetUpUserGroup(r) // User
|
||||||
handler.SetUpDeviceGroup(r) // Device
|
handler.SetUpDeviceGroup(r) // Device
|
||||||
handler.SetUpIMGroup(r) // IM
|
handler.SetUpIMGroup(r) // IM
|
||||||
handler.SetUpCIDGroup(r) // CID,持续集成、部署
|
handler.SetUpCIDGroup(r) // CID,持续集成、部署
|
||||||
|
|
@ -124,7 +124,12 @@ func JWTAuthMiddleware() gin.HandlerFunc {
|
||||||
if proto.Config.TOKEN_USE_REDIS {
|
if proto.Config.TOKEN_USE_REDIS {
|
||||||
redisToken := worker.GetRedis(tokenString)
|
redisToken := worker.GetRedis(tokenString)
|
||||||
if redisToken == "" {
|
if redisToken == "" {
|
||||||
c.AbortWithStatusJSON(http.StatusOK, gin.H{"message": "NOT_LOGIN", "error": "server token is empty", "code": proto.TokenIsNull})
|
c.AbortWithStatus(200)
|
||||||
|
c.JSON(200, gin.H{
|
||||||
|
"message": "NOT_LOGIN",
|
||||||
|
"error": "server token is empty",
|
||||||
|
"code": proto.TokenIsNull,
|
||||||
|
})
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -136,7 +141,12 @@ func JWTAuthMiddleware() gin.HandlerFunc {
|
||||||
sId = c.Query("super_id")
|
sId = c.Query("super_id")
|
||||||
}
|
}
|
||||||
if sId == "" {
|
if sId == "" {
|
||||||
c.AbortWithStatusJSON(http.StatusOK, gin.H{"message": "unauthorized", "error": "super_id is empty", "code": proto.TokenIsNull})
|
c.AbortWithStatus(200)
|
||||||
|
c.JSON(200, gin.H{
|
||||||
|
"message": "NOT_LOGIN",
|
||||||
|
"error": "super_id is empty",
|
||||||
|
"code": proto.TokenIsNull,
|
||||||
|
})
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
id, _ := strconv.Atoi(sId)
|
id, _ := strconv.Atoi(sId)
|
||||||
|
|
@ -154,7 +164,8 @@ func JWTAuthMiddleware() gin.HandlerFunc {
|
||||||
|
|
||||||
// 验证令牌
|
// 验证令牌
|
||||||
if err != nil || !token.Valid {
|
if err != nil || !token.Valid {
|
||||||
c.AbortWithStatusJSON(http.StatusOK, gin.H{
|
c.AbortWithStatus(200)
|
||||||
|
c.JSON(200, gin.H{
|
||||||
"message": "NOT_LOGIN",
|
"message": "NOT_LOGIN",
|
||||||
"error": "Invalid token",
|
"error": "Invalid token",
|
||||||
"code": proto.TokenExpired,
|
"code": proto.TokenExpired,
|
||||||
|
|
@ -167,7 +178,8 @@ func JWTAuthMiddleware() gin.HandlerFunc {
|
||||||
c.Set("username", token.Claims.(jwt.MapClaims)["username"])
|
c.Set("username", token.Claims.(jwt.MapClaims)["username"])
|
||||||
|
|
||||||
if UserFuncIntercept(int(token.Claims.(jwt.MapClaims)["id"].(float64)), c.Request.URL.Path) {
|
if UserFuncIntercept(int(token.Claims.(jwt.MapClaims)["id"].(float64)), c.Request.URL.Path) {
|
||||||
c.AbortWithStatusJSON(http.StatusOK, gin.H{
|
c.AbortWithStatus(200)
|
||||||
|
c.JSON(http.StatusOK, gin.H{
|
||||||
"message": "no function permission",
|
"message": "no function permission",
|
||||||
"error": "no permission",
|
"error": "no permission",
|
||||||
"code": proto.NoPermission,
|
"code": proto.NoPermission,
|
||||||
|
|
@ -339,7 +351,7 @@ func RunGeneralCron() {
|
||||||
// 用户功能拦截,返回true表示拦截,false表示不拦截
|
// 用户功能拦截,返回true表示拦截,false表示不拦截
|
||||||
func UserFuncIntercept(id int, url string) bool {
|
func UserFuncIntercept(id int, url string) bool {
|
||||||
//先查看是否有权限
|
//先查看是否有权限
|
||||||
user := service.GetUserByIDFromUserCenter(id)
|
user := dao.FindUserByUserID(id)
|
||||||
//如果用户有权限,则不拦截
|
//如果用户有权限,则不拦截
|
||||||
for k, v := range proto.Per_menu_map {
|
for k, v := range proto.Per_menu_map {
|
||||||
if strings.Contains(url, k) {
|
if strings.Contains(url, k) {
|
||||||
|
|
|
||||||
|
|
@ -1,7 +0,0 @@
|
||||||
package proto
|
|
||||||
|
|
||||||
type GeneralResp struct {
|
|
||||||
Code int `json:"code"`
|
|
||||||
Message string `json:"message"`
|
|
||||||
Data any `json:"data"`
|
|
||||||
}
|
|
||||||
|
|
@ -73,9 +73,4 @@ const (
|
||||||
ShellUpdateFailed = 101 // 更新shell失败
|
ShellUpdateFailed = 101 // 更新shell失败
|
||||||
ShellDeleteFailed = 102 // 删除shell失败
|
ShellDeleteFailed = 102 // 删除shell失败
|
||||||
ShellSearchFailed = 103 // 获取shell失败
|
ShellSearchFailed = 103 // 获取shell失败
|
||||||
|
|
||||||
//monitor部分错误码
|
|
||||||
MonitorServerIDIsNull = 110 // 监控服务器ID为空
|
|
||||||
MonitorServerIDNotFound = 111 // 监控服务器ID不存在
|
|
||||||
|
|
||||||
)
|
)
|
||||||
|
|
|
||||||
|
|
@ -5,7 +5,6 @@ import (
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"github.com/golang-jwt/jwt"
|
"github.com/golang-jwt/jwt"
|
||||||
"log"
|
|
||||||
"regexp"
|
"regexp"
|
||||||
"strconv"
|
"strconv"
|
||||||
"time"
|
"time"
|
||||||
|
|
@ -125,8 +124,8 @@ func UpdateUser(user_id int, req proto.UpdateUserInfoReq) (int, error) {
|
||||||
func UpdateUserCache(id int) {
|
func UpdateUserCache(id int) {
|
||||||
key := "user_info_" + strconv.Itoa(id)
|
key := "user_info_" + strconv.Itoa(id)
|
||||||
if worker.IsContainKey(key) {
|
if worker.IsContainKey(key) {
|
||||||
users := GetUserByID(id)
|
user := GetUserByID(id)
|
||||||
userJson, err := json.Marshal(users[0]) //统一使用User不使用数组
|
userJson, err := json.Marshal(user)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println("get user info , json marshal error:", err)
|
fmt.Println("get user info , json marshal error:", err)
|
||||||
}
|
}
|
||||||
|
|
@ -401,77 +400,3 @@ func CreateTokenAndSave(user dao.User) (string, error) {
|
||||||
// 返回令牌
|
// 返回令牌
|
||||||
return tokenString, err
|
return tokenString, err
|
||||||
}
|
}
|
||||||
|
|
||||||
// 获取用户信息,有redis缓存
|
|
||||||
func GetUserByIDFromUserCenter(id int) dao.User {
|
|
||||||
if id <= 0 {
|
|
||||||
return dao.User{}
|
|
||||||
}
|
|
||||||
var user dao.User
|
|
||||||
//先从redis获取
|
|
||||||
key := "user_info_" + strconv.Itoa(id)
|
|
||||||
userStr := worker.GetRedis(key)
|
|
||||||
//log.Println("user_str:", userStr)
|
|
||||||
if userStr != "" {
|
|
||||||
err := json.Unmarshal([]byte(userStr), &user)
|
|
||||||
if err != nil {
|
|
||||||
fmt.Println("get user info , json unmarshal error:", err, "\tuser_str:", userStr)
|
|
||||||
return dao.User{}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
user = GetUserInfoByIDFromUserCenterHttp(id)
|
|
||||||
if user.ID != 0 {
|
|
||||||
userJson, err := json.Marshal(user)
|
|
||||||
if err != nil {
|
|
||||||
fmt.Println("get user info , json marshal error:", err)
|
|
||||||
return dao.User{}
|
|
||||||
}
|
|
||||||
userStr = string(userJson)
|
|
||||||
success := worker.SetRedisWithExpire(key, userStr, time.Second*10)
|
|
||||||
if !success {
|
|
||||||
fmt.Println("set redis error,user json:", userStr)
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
log.Println("GetUserByIDFromUserCenter user not found, id:", id)
|
|
||||||
log.Println("response user:", user)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return user
|
|
||||||
}
|
|
||||||
|
|
||||||
type UserInfoResponse struct {
|
|
||||||
Code int `json:"code"`
|
|
||||||
Message string `json:"message"`
|
|
||||||
Data dao.User `json:"data"`
|
|
||||||
}
|
|
||||||
|
|
||||||
func GetUserInfoByIDFromUserCenterHttp(id int) dao.User {
|
|
||||||
var resp UserInfoResponse
|
|
||||||
url := "https://uc.ljsea.top/user/info?super_id=1"
|
|
||||||
tokens := worker.GetRedisSetMembers("super_permission_tokens")
|
|
||||||
if len(tokens) == 0 {
|
|
||||||
return resp.Data
|
|
||||||
}
|
|
||||||
token := tokens[0]
|
|
||||||
//请求参数
|
|
||||||
req := map[string]int{
|
|
||||||
"id": id,
|
|
||||||
}
|
|
||||||
headers := map[string]string{
|
|
||||||
"token": token,
|
|
||||||
}
|
|
||||||
reqByte, _ := json.Marshal(req)
|
|
||||||
err, respBytes := worker.DoPostRequestJSON(url, reqByte, headers)
|
|
||||||
if err != nil {
|
|
||||||
log.Println("GetUserInfoByIDFromUserCenterHttp error:", err)
|
|
||||||
return resp.Data
|
|
||||||
}
|
|
||||||
if err2 := json.Unmarshal(respBytes, &resp); err2 != nil {
|
|
||||||
log.Println("GetUserInfoByIDFromUserCenterHttp json unmarshal error:", err2)
|
|
||||||
}
|
|
||||||
if resp.Data.ID == 0 {
|
|
||||||
log.Println("GetUserInfoByIDFromUserCenterHttp user not found, resp:", string(respBytes))
|
|
||||||
return resp.Data
|
|
||||||
}
|
|
||||||
return resp.Data
|
|
||||||
}
|
|
||||||
|
|
|
||||||
|
|
@ -50,7 +50,7 @@ func IsContainKey(key string) bool {
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
val, err := RedisClient.Exists(ctx, key).Result() // 检查键是否存在, 如果存在则返回 1, 否则返回 0
|
val, err := RedisClient.Exists(ctx, key).Result() // 检查键是否存在, 如果存在则返回 1, 否则返回 0
|
||||||
if err != nil {
|
if err != nil {
|
||||||
//fmt.Println("Error getting key: %v", err)
|
fmt.Println("Error getting key: %v", err)
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
if val == 0 {
|
if val == 0 {
|
||||||
|
|
@ -170,7 +170,7 @@ func GetRedis(key string) string {
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
val, err := RedisClient.Get(ctx, key).Result() // 从 Redis 读取键值, 如果键不存在则返回空字符串, 如果出现错误则返回错误
|
val, err := RedisClient.Get(ctx, key).Result() // 从 Redis 读取键值, 如果键不存在则返回空字符串, 如果出现错误则返回错误
|
||||||
if err != nil {
|
if err != nil {
|
||||||
//fmt.Println(key, " Error getting key: %v", err)
|
fmt.Println(key, " Error getting key: %v", err)
|
||||||
return ""
|
return ""
|
||||||
}
|
}
|
||||||
return val
|
return val
|
||||||
|
|
@ -220,7 +220,7 @@ func GetRedisListLen(key string) int64 {
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
val, err := RedisClient.LLen(ctx, key).Result()
|
val, err := RedisClient.LLen(ctx, key).Result()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
//fmt.Println("Error getting key: %v", err)
|
fmt.Println("Error getting key: %v", err)
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
return val
|
return val
|
||||||
|
|
@ -281,7 +281,7 @@ func hGetRedis(key string, field string) string {
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
val, err := RedisClient.HGet(ctx, key, field).Result()
|
val, err := RedisClient.HGet(ctx, key, field).Result()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
//fmt.Println("Error getting key: %v", err)
|
fmt.Println("Error getting key: %v", err)
|
||||||
}
|
}
|
||||||
return val
|
return val
|
||||||
}
|
}
|
||||||
|
|
@ -362,7 +362,7 @@ func GetRedisSetIntersect(key1 string, key2 string) []string {
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
val, err := RedisClient.SInter(ctx, key1, key2).Result()
|
val, err := RedisClient.SInter(ctx, key1, key2).Result()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
//fmt.Println("Error getting key: %v", err)
|
fmt.Println("Error getting key: %v", err)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
return val
|
return val
|
||||||
|
|
@ -373,7 +373,7 @@ func IsContainSet(key string, value string) bool {
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
val, err := RedisClient.SIsMember(ctx, key, value).Result()
|
val, err := RedisClient.SIsMember(ctx, key, value).Result()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
//fmt.Println("Error getting key: %v", err)
|
fmt.Println("Error getting key: %v", err)
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
return val
|
return val
|
||||||
|
|
@ -384,7 +384,7 @@ func GetRedisSetMembers(key string) []string {
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
val, err := RedisClient.SMembers(ctx, key).Result()
|
val, err := RedisClient.SMembers(ctx, key).Result()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
//fmt.Println("Error getting key: %v", err)
|
fmt.Println("Error getting key: %v", err)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
return val
|
return val
|
||||||
|
|
@ -395,7 +395,7 @@ func SetRedisBitmap(key string, offset int64, value int) bool {
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
err := RedisClient.SetBit(ctx, key, offset, value).Err()
|
err := RedisClient.SetBit(ctx, key, offset, value).Err()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
//fmt.Println("Error setting key: %v", err)
|
fmt.Println("Error setting key: %v", err)
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
return true
|
return true
|
||||||
|
|
@ -406,7 +406,7 @@ func GetRedisBitmap(key string, offset int64) int {
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
val, err := RedisClient.GetBit(ctx, key, offset).Result()
|
val, err := RedisClient.GetBit(ctx, key, offset).Result()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
//fmt.Println("Error getting key: %v", err)
|
fmt.Println("Error getting key: %v", err)
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
return int(val)
|
return int(val)
|
||||||
|
|
@ -476,7 +476,7 @@ func GetRedisSetUnion(key1 string, key2 string) []string {
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
val, err := RedisClient.SUnion(ctx, key1, key2).Result()
|
val, err := RedisClient.SUnion(ctx, key1, key2).Result()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
//fmt.Println("Error getting key: %v", err)
|
fmt.Println("Error getting key: %v", err)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
return val
|
return val
|
||||||
|
|
@ -494,7 +494,7 @@ func GetAllRedisInfo() ([]RedisInfo, error) {
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
keys, err := RedisClient.Keys(ctx, "*").Result()
|
keys, err := RedisClient.Keys(ctx, "*").Result()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
//fmt.Println("Error getting key: %v", err)
|
fmt.Println("Error getting key: %v", err)
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
var redisInfos []RedisInfo
|
var redisInfos []RedisInfo
|
||||||
|
|
@ -502,12 +502,12 @@ func GetAllRedisInfo() ([]RedisInfo, error) {
|
||||||
//先查看key类型,再根据类型获取value
|
//先查看key类型,再根据类型获取value
|
||||||
key_type, val, err := getKeyTypeAndData(key)
|
key_type, val, err := getKeyTypeAndData(key)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
//fmt.Println("Error getting key: %v", err)
|
fmt.Println("Error getting key: %v", err)
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
expire, err := RedisClient.TTL(ctx, key).Result()
|
expire, err := RedisClient.TTL(ctx, key).Result()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
//fmt.Println("Error getting key: %v", err)
|
fmt.Println("Error getting key: %v", err)
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
redisInfo := RedisInfo{
|
redisInfo := RedisInfo{
|
||||||
|
|
|
||||||
220
worker/req.go
220
worker/req.go
|
|
@ -6,11 +6,7 @@ import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"log"
|
|
||||||
"mime/multipart"
|
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/url"
|
|
||||||
"strconv"
|
|
||||||
"strings"
|
"strings"
|
||||||
"videoplayer/dao"
|
"videoplayer/dao"
|
||||||
"videoplayer/proto"
|
"videoplayer/proto"
|
||||||
|
|
@ -283,219 +279,3 @@ func SyncDataFromMasterShellReq3(url string, data proto.SyncUserShellResp) ([]pr
|
||||||
res = response.Data
|
res = response.Data
|
||||||
return res, nil
|
return res, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func DoPostRequestJSON(url string, jsonData []byte, headers map[string]string) (error, []byte) {
|
|
||||||
httpClient := &http.Client{}
|
|
||||||
defer func() {
|
|
||||||
if r := recover(); r != nil {
|
|
||||||
fmt.Println("SyncDataFromMasterReq2 error:", r)
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
|
|
||||||
//从接口获取数据
|
|
||||||
req, err := http.NewRequest("POST", url, bytes.NewBuffer(jsonData))
|
|
||||||
if err != nil {
|
|
||||||
return err, nil
|
|
||||||
}
|
|
||||||
req.Header.Set("Content-Type", "application/json")
|
|
||||||
req.Header.Set("User-Agent", "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36 Edg/136.0.0.0")
|
|
||||||
//设置header
|
|
||||||
for k, v := range headers {
|
|
||||||
req.Header.Set(k, v)
|
|
||||||
}
|
|
||||||
//传输数据
|
|
||||||
if httpClient == nil {
|
|
||||||
httpClient = &http.Client{}
|
|
||||||
}
|
|
||||||
//获取数据
|
|
||||||
resp, err := httpClient.Do(req)
|
|
||||||
if err != nil {
|
|
||||||
return err, nil
|
|
||||||
}
|
|
||||||
defer resp.Body.Close()
|
|
||||||
//解析数据
|
|
||||||
responseBod, err := io.ReadAll(resp.Body)
|
|
||||||
if err != nil {
|
|
||||||
return err, nil
|
|
||||||
}
|
|
||||||
return err, responseBod
|
|
||||||
}
|
|
||||||
|
|
||||||
func DoPostRequestForm(url string, jsonData []byte, headers map[string]string) (error, []byte) {
|
|
||||||
httpClient := &http.Client{}
|
|
||||||
defer func() {
|
|
||||||
if r := recover(); r != nil {
|
|
||||||
fmt.Println("SyncDataFromMasterReq2 error:", r)
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
|
|
||||||
// 创建一个新的 buffer 用于存储 multipart/form-data 请求体
|
|
||||||
body := &bytes.Buffer{}
|
|
||||||
writer := multipart.NewWriter(body)
|
|
||||||
// 修改 data 类型为 map[string]interface{} 以支持不同类型的值
|
|
||||||
var data map[string]interface{}
|
|
||||||
err2 := json.Unmarshal(jsonData, &data)
|
|
||||||
if err2 != nil {
|
|
||||||
log.Println("do post json unmarshal error:", err2)
|
|
||||||
return err2, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
var err error
|
|
||||||
for k, v := range data {
|
|
||||||
switch val := v.(type) {
|
|
||||||
case bool:
|
|
||||||
// 处理布尔类型的值
|
|
||||||
err = writer.WriteField(k, strconv.FormatBool(val))
|
|
||||||
case string:
|
|
||||||
// 处理字符串类型的值
|
|
||||||
err = writer.WriteField(k, val)
|
|
||||||
default:
|
|
||||||
// 其他类型可以根据需要扩展处理逻辑
|
|
||||||
log.Printf("Unsupported type for field %s: %T\n", k, v)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
if err != nil {
|
|
||||||
log.Println("write field error:", err)
|
|
||||||
return err, nil
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// 关闭 writer 以完成请求体的构建
|
|
||||||
err = writer.Close()
|
|
||||||
if err != nil {
|
|
||||||
return err, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// 创建 POST 请求
|
|
||||||
req, err := http.NewRequest("POST", url, body)
|
|
||||||
req.Header.Set("User-Agent", "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36 Edg/136.0.0.0")
|
|
||||||
if err != nil {
|
|
||||||
return err, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// 设置 Content-Type 为 multipart/form-data,并带上 boundary
|
|
||||||
req.Header.Set("Content-Type", writer.FormDataContentType())
|
|
||||||
|
|
||||||
// 设置其他自定义请求头
|
|
||||||
for k, v := range headers {
|
|
||||||
req.Header.Set(k, v)
|
|
||||||
}
|
|
||||||
|
|
||||||
// 发送请求
|
|
||||||
resp, err := httpClient.Do(req)
|
|
||||||
if err != nil {
|
|
||||||
return err, nil
|
|
||||||
}
|
|
||||||
defer resp.Body.Close()
|
|
||||||
|
|
||||||
// 读取响应体
|
|
||||||
responseBod, err := io.ReadAll(resp.Body)
|
|
||||||
if err != nil {
|
|
||||||
return err, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil, responseBod
|
|
||||||
}
|
|
||||||
|
|
||||||
func DoPostRequestFormUrlEncoded(url_ string, jsonData []byte, headers map[string]string) (error, []byte) {
|
|
||||||
httpClient := &http.Client{}
|
|
||||||
defer func() {
|
|
||||||
if r := recover(); r != nil {
|
|
||||||
log.Println("SyncDataFromMasterReq2 error:", r)
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
|
|
||||||
// 解析 JSON 数据
|
|
||||||
var data map[string]interface{}
|
|
||||||
err := json.Unmarshal(jsonData, &data)
|
|
||||||
if err != nil {
|
|
||||||
log.Println("do post json unmarshal error:", err)
|
|
||||||
return err, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// 创建 url.Values 来存储请求参数
|
|
||||||
reqData := url.Values{}
|
|
||||||
for k, v := range data {
|
|
||||||
switch val := v.(type) {
|
|
||||||
case bool:
|
|
||||||
// 处理布尔类型的值
|
|
||||||
reqData.Set(k, strconv.FormatBool(val))
|
|
||||||
case string:
|
|
||||||
// 处理字符串类型的值
|
|
||||||
reqData.Set(k, val)
|
|
||||||
default:
|
|
||||||
// 其他类型可以根据需要扩展处理逻辑
|
|
||||||
log.Printf("Unsupported type for field %s: %T\n", k, v)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// 将 url.Values 编码为 URL 编码的格式
|
|
||||||
encodedData := reqData.Encode()
|
|
||||||
|
|
||||||
// 创建 POST 请求
|
|
||||||
req, err := http.NewRequest("POST", url_, bytes.NewBufferString(encodedData))
|
|
||||||
if err != nil {
|
|
||||||
return err, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// 设置请求头
|
|
||||||
req.Header.Set("User-Agent", "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36 Edg/136.0.0.0")
|
|
||||||
req.Header.Set("Content-Type", "application/x-www-form-urlencoded")
|
|
||||||
|
|
||||||
// 设置其他自定义请求头
|
|
||||||
for k, v := range headers {
|
|
||||||
req.Header.Set(k, v)
|
|
||||||
}
|
|
||||||
|
|
||||||
// 发送请求
|
|
||||||
resp, err := httpClient.Do(req)
|
|
||||||
if err != nil {
|
|
||||||
return err, nil
|
|
||||||
}
|
|
||||||
defer resp.Body.Close()
|
|
||||||
|
|
||||||
// 读取响应体
|
|
||||||
responseBod, err := io.ReadAll(resp.Body)
|
|
||||||
if err != nil {
|
|
||||||
return err, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil, responseBod
|
|
||||||
}
|
|
||||||
|
|
||||||
func DoGetRequest(url string, headers map[string]string) (error, []byte) {
|
|
||||||
httpClient := &http.Client{}
|
|
||||||
defer func() {
|
|
||||||
if r := recover(); r != nil {
|
|
||||||
fmt.Println("SyncDataFromMasterReq2 error:", r)
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
|
|
||||||
//从接口获取数据
|
|
||||||
req, err := http.NewRequest("GET", url, nil)
|
|
||||||
req.Header.Set("User-Agent", "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36 Edg/136.0.0.0")
|
|
||||||
if err != nil {
|
|
||||||
return err, nil
|
|
||||||
}
|
|
||||||
//设置header
|
|
||||||
for k, v := range headers {
|
|
||||||
req.Header.Set(k, v)
|
|
||||||
}
|
|
||||||
//传输数据
|
|
||||||
if httpClient == nil {
|
|
||||||
httpClient = &http.Client{}
|
|
||||||
}
|
|
||||||
//获取数据
|
|
||||||
resp, err := httpClient.Do(req)
|
|
||||||
if err != nil {
|
|
||||||
return err, nil
|
|
||||||
}
|
|
||||||
defer resp.Body.Close()
|
|
||||||
//解析数据
|
|
||||||
responseBod, err := io.ReadAll(resp.Body)
|
|
||||||
if err != nil {
|
|
||||||
return err, nil
|
|
||||||
}
|
|
||||||
return err, responseBod
|
|
||||||
}
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue