123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327 |
- package gateway
- import (
- "confrontation-training/common"
- "confrontation-training/constant"
- errors "confrontation-training/err"
- "confrontation-training/global"
- "confrontation-training/http"
- "confrontation-training/models"
- "confrontation-training/models/gateway"
- "confrontation-training/response"
- "encoding/hex"
- "encoding/json"
- "fmt"
- "github.com/gin-gonic/gin"
- "io/ioutil"
- "strings"
- )
- func ScanDevice(c *gin.Context) {
- var param gateway.DeviceScanParam
- err := c.ShouldBindJSON(¶m)
- if err != nil {
- fmt.Printf("参数格式化异常:%s", err.Error())
- response.Failed(errors.ParamInvalid, c)
- return
- }
- paramMap := make(map[string]string)
- if param.Chip != "" {
- paramMap["chip"] = param.Chip
- }
- if param.FilterName != "" {
-
- filterMac := ""
- deviceInfos, count := GetDeviceService().DeviceService.FindDeviceByType(param.FilterName)
- if count > 0 {
- for i := range deviceInfos {
- filterMac += deviceInfos[i].Mac + ","
- }
- }
- if len(filterMac) > 0 {
- if strings.HasSuffix(filterMac, ",") {
- filterMac = filterMac[0 : len(filterMac)-1]
- }
- paramMap["filter_mac"] = filterMac
- }
- if param.FilterName == "0" {
- paramMap["filter_name"] = constant.FilterNameEEG
- } else if param.FilterName == "1" {
- paramMap["filter_name"] = constant.FilterNameECG
- } else {
- response.Failed(errors.ParamInvalid+":过滤类型-"+param.FilterName+"无效", c)
- return
- }
- } else {
- paramMap["filter_name"] = constant.FilterNameALL
- }
- if param.FilterRssi != "" {
- paramMap["filter_rssi"] = param.FilterRssi
- }
- if param.FilterMac != "" {
- paramMap["filter_mac"] = param.FilterMac
- }
- paramMap["active"] = "1"
- paramMap["event"] = "1"
- SseScanDevice(paramMap, param.FilterType)
-
- response.Success("扫描完成", "", c)
- return
- }
- func ConnectDevice(c *gin.Context) {
- var param gateway.DeviceConnParam
- err := c.ShouldBindJSON(¶m)
- if err != nil {
- fmt.Printf("参数格式化异常:%s", err.Error())
- response.Failed(errors.ParamInvalid, c)
- return
- }
- jsonParam, err := json.Marshal(param)
- if err != nil {
- fmt.Printf("参数转换异常:%s", err.Error())
- response.Failed("参数转换异常:%s"+err.Error(), c)
- return
- }
- url := global.Config.Gateway.BaseUrl + global.Config.Gateway.ConnUrl
- url = strings.Replace(url, "MAC", param.Mac, -1)
- url = strings.Replace(url, "chip", "chip="+param.Chip, -1)
- httpResponse := http.PostReqJson(url, jsonParam)
- status := httpResponse.StatusCode
- fmt.Println("status", status)
- fmt.Println("response:", httpResponse.Header)
- body, _ := ioutil.ReadAll(httpResponse.Body)
- fmt.Println("response Body:", string(body))
- if status != 200 {
- response.Failed(errors.DeviceConnectError+string(body), c)
- return
- }
- if param.FilterName == "1" {
- openChannelUrl := global.Config.Gateway.BaseUrl + global.Config.Gateway.OpenChannel
- openChannelUrl = strings.Replace(openChannelUrl, "MAC", param.Mac, -1)
- fmt.Println("openChannelUrl===" + openChannelUrl)
- httpResponse = http.GetReq(openChannelUrl)
- if httpResponse.StatusCode != 200 {
- fmt.Printf("%s:%s", errors.OpenChannelError, httpResponse.Body)
- response.Failed(errors.OpenChannelError, c)
- return
- }
- }
- response.Success(errors.DeviceConnectSuccess, param.Mac, c)
- return
- }
- func WriteData(c *gin.Context) {
- var param models.WriteData
- err := c.ShouldBindJSON(¶m)
- if err != nil {
- fmt.Printf("参数格式化异常:%s", err.Error())
- response.Failed(errors.ParamInvalid, c)
- return
- }
- userNameHex := hex.EncodeToString([]byte(param.UserName))
-
-
- var stringBuild strings.Builder
- stringBuild.WriteString(constant.BindUserInfoCmdPrefix)
- length := len(userNameHex) / 2
- bytes := common.Int2Bytes(length)
- result := common.Bytes2HexStr(bytes)
- result = common.Int2Byte(int64(length))
- if result == "" {
- response.Failed("用户名处理异常", c)
- return
- }
- result = result[len(result)-2:]
- stringBuild.WriteString(result)
- stringBuild.WriteString(userNameHex)
- placeHolder := common.GenerateHexStringCmdPlaceHolder(constant.MaxNameByteLength - length)
- stringBuild.WriteString(placeHolder)
- hexGender := common.Int2Byte(param.Gender)
- stringBuild.WriteString(hexGender[len(hexGender)-2:])
- if param.Age == 0 {
- param.Age = constant.EcgDefaultAge
- }
- hexAge := common.Int2Byte(param.Age)
- stringBuild.WriteString(hexAge[len(hexAge)-2:])
- if param.Height == 0 {
- param.Height = constant.EcgDefaultHeight
- }
- hexHeight := common.Int2Byte(param.Height)
- stringBuild.WriteString(hexHeight[len(hexHeight)-2:])
- if param.Weight == 0 {
- param.Weight = constant.EcgDefaultWeight
- }
- hexWeight := common.Int2Byte(param.Weight)
- stringBuild.WriteString(hexWeight[len(hexWeight)-2:])
- bindUserCmdByte := []byte(stringBuild.String())
- bindUserCmd := string(bindUserCmdByte)
- fmt.Println(bindUserCmd)
-
-
- timeCmd := common.GetHexTimeStr()
-
- setTimeCmd := fmt.Sprintf("%s%s", constant.SetTimeCmdPrefix, timeCmd)
- fmt.Println(setTimeCmd)
-
- startCollectCmd := fmt.Sprintf("%s%s", constant.StartCollectCmdPrefix, timeCmd)
- fmt.Println(startCollectCmd)
-
-
- bindUserUrl := fmt.Sprintf("%s%s", global.Config.Gateway.BaseUrl, global.Config.Gateway.WriteDataUrl)
- bindUserUrl = strings.Replace(bindUserUrl, "MAC", param.Mac, -1)
- bindUserUrl = strings.Replace(bindUserUrl, "DATA", bindUserCmd, -1)
- fmt.Println("bindUserUrl====" + bindUserUrl)
- httpResponse := http.GetReq(bindUserUrl)
- if httpResponse.StatusCode != 200 {
- fmt.Printf("%s:%s", errors.SetDeviceTimeFailed, httpResponse.Body)
- response.Failed(errors.SetDeviceTimeFailed, c)
- return
- }
-
- setTimeUrl := fmt.Sprintf("%s%s", global.Config.Gateway.BaseUrl, global.Config.Gateway.WriteDataUrl)
- setTimeUrl = strings.Replace(setTimeUrl, "MAC", param.Mac, -1)
- setTimeUrl = strings.Replace(setTimeUrl, "DATA", setTimeCmd, -1)
- httpResponse = http.GetReq(setTimeUrl)
- if httpResponse.StatusCode != 200 {
- fmt.Printf("%s:%s", errors.BindUserFailed, httpResponse.Body)
- response.Failed(errors.BindUserFailed, c)
- return
- }
- fmt.Println("setTimeUrl=====" + setTimeUrl)
-
- startCollectUrl := fmt.Sprintf("%s%s", global.Config.Gateway.BaseUrl, global.Config.Gateway.WriteDataUrl)
- startCollectUrl = strings.Replace(startCollectUrl, "MAC", param.Mac, -1)
- startCollectUrl = strings.Replace(startCollectUrl, "DATA", startCollectCmd, -1)
- fmt.Println("startCollectUrl=====" + startCollectUrl)
- httpResponse = http.GetReq(startCollectUrl)
- if httpResponse.StatusCode != 200 {
- fmt.Printf("%s:%s", errors.StartCollocateFailed, httpResponse.Body)
- response.Failed(errors.StartCollocateFailed, c)
- return
- }
-
- startTransUrl := fmt.Sprintf("%s%s", global.Config.Gateway.BaseUrl, global.Config.Gateway.WriteDataUrl)
- startTransUrl = strings.Replace(startTransUrl, "MAC", param.Mac, -1)
- startTransUrl = strings.Replace(startTransUrl, "DATA", constant.StartTransCmd, -1)
- fmt.Println("startTransUrl====" + startTransUrl)
- httpResponse = http.GetReq(startTransUrl)
- if httpResponse.StatusCode != 200 {
- fmt.Printf("%s:%s", errors.StartTransFailed, httpResponse.Body)
- response.Failed(errors.StartTransFailed, c)
- return
- }
- response.Success(errors.WriteDataSuccess, nil, c)
- return
- }
- func OpenNotify(c *gin.Context) {
- SseOpenNotify()
- response.Success("开启通知", "", c)
- return
- }
- func StopTrans(c *gin.Context) {
- mac := c.Param("mac")
- stopTransUrl := global.Config.Gateway.BaseUrl + global.Config.Gateway.WriteDataUrl
- stopTransUrl = strings.Replace(stopTransUrl, "MAC", mac, -1)
- stopTransUrl = strings.Replace(stopTransUrl, "DATA", constant.StopTransCmd, -1)
- response.Success("停止传输", "", c)
- return
- }
- func StopCollect(c *gin.Context) {
- mac := c.Param("mac")
- stopTransUrl := global.Config.Gateway.BaseUrl + global.Config.Gateway.WriteDataUrl
- stopTransUrl = strings.Replace(stopTransUrl, "MAC", mac, -1)
- stopTransUrl = strings.Replace(stopTransUrl, "DATA", constant.StopCollectCmd, -1)
- response.Success("停止采集", "", c)
- return
- }
- func Disconnect(c *gin.Context) {
- mac := c.Param("mac")
- disconnectUrl := global.Config.Gateway.BaseUrl + global.Config.Gateway.DisconnectUrl
- disconnectUrl = strings.Replace(disconnectUrl, "MAC", mac, -1)
- response.Success("断开连接", mac, c)
- return
- }
|