From 2bd2068c999cda5bda8c0787ed0dcaac6cb7afdb Mon Sep 17 00:00:00 2001
From: zhangzengfei <zhangzengfei@iotlink.com>
Date: 星期四, 31 十月 2019 13:27:46 +0800
Subject: [PATCH] feat: add system reboot api

---
 middlewares/auth/auth.go |   66 ++++++++++++++++++++------------
 1 files changed, 41 insertions(+), 25 deletions(-)

diff --git a/middlewares/auth/auth.go b/middlewares/auth/auth.go
index 98d4836..2de927d 100644
--- a/middlewares/auth/auth.go
+++ b/middlewares/auth/auth.go
@@ -1,12 +1,12 @@
 package auth
 
 import (
+	"fmt"
 	"github.com/gin-gonic/gin"
 	"net/http"
 	"strings"
+	"sync"
 	"webserver/extend/code"
-	"webserver/extend/config"
-	"basic.com/valib/logger.git"
 	"webserver/extend/util"
 )
 
@@ -27,6 +27,32 @@
 	return &authDriver
 }
 
+var outUserM = make(map[string]string,0)
+var lock sync.RWMutex
+
+func SetOutUser(userId string) {
+	lock.Lock()
+	defer lock.Unlock()
+	outUserM[userId] = userId
+}
+
+func OutUser(userId string) bool {
+	lock.Lock()
+	defer lock.Unlock()
+	if _,ok := outUserM[userId];ok{
+		return true
+	}
+	return false
+}
+
+func RemoveOutUser(userId string) {
+	lock.Lock()
+	defer lock.Unlock()
+	if _,ok := outUserM[userId];ok{
+		delete(outUserM,userId)
+	}
+}
+
 func AuthHandler() gin.HandlerFunc {
 	return func(c *gin.Context) {
 		urlPath := c.Request.URL.Path
@@ -37,30 +63,20 @@
 				util.ResponseFormat(c,code.TokenNotFound,"灏氭湭鐧诲綍锛岃鐧诲綍")
 				c.Abort()
 			}
+			user := (*jwtDriver).User(c)
+			fmt.Println("AuthHandler user:",user)
+			if user == nil {
+				util.ResponseFormat(c,code.TokenNotFound,"灏氭湭鐧诲綍锛岃鐧诲綍")
+				c.Abort()
+				return
+			}
+			loginM := user.(map[string]interface{})
+			userId := loginM["id"].(string)
+			if OutUser(userId) {
+				util.ResponseFormat(c,code.TokenNotFound,"灏氭湭鐧诲綍锛岃鐧诲綍")
+				c.Abort()
+			}
 			c.Next()
-		} else if strings.Contains(urlPath,"/httpImage") {
-			domain := config.Server.PublicDomain
-			//domainReg := regexp.MustCompile(``+domain+``)
-			//if domainReg.MatchString(host) {//鍩熷悕璁块棶
-			//   imgUrl = domain
-			//}
-
-			urlPath = strings.Replace(urlPath, "/httpImage", "", -1)
-			if strings.Contains(urlPath,domain) {
-				urlPath = strings.Replace(urlPath,"/"+domain,"",-1)
-			}
-			logger.Debug("urlPath:",urlPath)
-			idx := strings.LastIndex(urlPath, ":")
-			tmpPath := ""
-			if idx >-1 {//璺緞涓寘鍚湁绔彛,鍙栫鍙d互鍚庤矾寰�
-				tmpPath = urlPath[idx:]
-			} else {
-				tmpPath = ":6080"+tmpPath
-			}
-			c.Header("Access-Control-Allow-Origin","*")
-			logger.Debug("domain+tmpPath:",domain+tmpPath)
-			c.Redirect(http.StatusMovedPermanently, domain+tmpPath)
-			return
 		} else {
 			c.Next()
 		}

--
Gitblit v1.8.0