From ca10e9d776509f54cb0251b7eae44cee74d94b2c Mon Sep 17 00:00:00 2001 From: liuxiaolong <liuxiaolong@aiotlink.com> Date: 星期二, 01 九月 2020 20:09:50 +0800 Subject: [PATCH] findHikSpaceUser add state=1 --- service/carService.go | 192 ++++++++++++++++++++++++++++++++++++++++++++++-- 1 files changed, 184 insertions(+), 8 deletions(-) diff --git a/service/carService.go b/service/carService.go index 3fdff76..5d79f47 100644 --- a/service/carService.go +++ b/service/carService.go @@ -7,7 +7,9 @@ "encoding/json" "fmt" "github.com/astaxie/beego" + "sort" "strconv" + "strings" ) type CarService struct { hikUtil *reqUtil.HikHttpUtil @@ -142,6 +144,121 @@ SpaceType string `json:"spaceType"` } +func (sv *CarService) FindHikSpaceInfo() []SpaceNo { + url := "/artemis/api/pms/v1/parkingSpace/spaceNo" + + reqBody := map[string]interface{} { + "pageNo": 1, + "pageSize": 1000, + } + pageResult := sv.getHikPageResult(url, reqBody) + if pageResult != nil { + rb, err := json.Marshal(pageResult.List) + if err != nil { + fmt.Println("marshal pageResult.List err:", err) + return nil + } + var spaceList []SpaceNo + err = json.Unmarshal(rb, &spaceList) + if err != nil { + fmt.Println("unmarshal spaceNos err:", err) + return nil + } else { + var resultArr []SpaceNo + for _,si := range spaceList { + if si.State == 1 { //鏈夎溅 + resultArr = append(resultArr, si) + } + } + return resultArr + } + } + return nil +} + + +type SpaceUser struct { + SpaceNo string `json:"spaceNo"` + PlateNo string `json:"plateNo"` + Username string `json:"username"` + PhoneNum string `json:"phoneNum"` + CarType string `json:"carType"` +} + +type SpaceUserArr []SpaceUser +func (arr SpaceUserArr) Len()int { + return len(arr) +} +func (arr SpaceUserArr) Swap(i,j int) { + arr[i],arr[j] = arr[j],arr[i] +} +func (arr SpaceUserArr) Less(i,j int) bool { + sn1,_ := strconv.Atoi(arr[i].SpaceNo) + sn2,_ := strconv.Atoi(arr[j].SpaceNo) + return sn1 < sn2 +} + +func (sv *CarService) FindHikSpaceUser() SpaceUserArr { + resultList := make(SpaceUserArr, 0) + url := "/artemis/api/pms/v1/parkingSpace/spaceNo" + reqBody := map[string]interface{} { + "pageNo": 1, + "pageSize": 1000, + } + pageResult := sv.getHikPageResult(url, reqBody) + if pageResult != nil { + rb, err := json.Marshal(pageResult.List) + if err != nil { + fmt.Println("marshal pageResult.List err:", err) + } else { + var spaceList []SpaceNo + err = json.Unmarshal(rb, &spaceList) + if err != nil { + fmt.Println("unmarshal spaceNos err:", err) + } else { + if len(spaceList) > 0 { //褰撳墠鏈夊仠鐣欒溅 + personMap := sv.GetHikPersonMap() + vehicleMap := sv.GetHikVehicleMap() + for _,sp := range spaceList { + if sp.State == 1 { + su := SpaceUser{ + SpaceNo: sp.SpaceNo, + PlateNo: sp.PlateNo, + } + if sp.PlateNo != "" { + r := []rune(sp.PlateNo) + ncStr := string(r[1:]) //鎶婄涓�浣嶆眽瀛楀墧闄ゆ帀 + newK := strings.ReplaceAll(ncStr, "D", "*") + newK = strings.ReplaceAll(newK, "0", "*") + personId := "" + if v,exist := vehicleMap[newK]; exist { + personId = v.PersonId + } + + if personId != "" { + su.CarType = "澶囨杞�" + if person, in := personMap[personId]; in { + su.Username = person.PersonName + su.PhoneNum = person.PhoneNo + } + } else { + su.CarType = "涓存椂杞�" + } + } else { + su.PlateNo = "鏃犺溅鐗�" + } + resultList = append(resultList, su) + } + } + } + } + } + } + + sort.Sort(resultList) + return resultList +} + func (sv *CarService) FindSpaceNo(userId string) models.PosResult { resultList := make(models.PosResult,0) var myPlateNosMap = make(map[string]string) @@ -149,8 +266,12 @@ vehicles := sv.GetVehicleListByPerson(userId) if vehicles != nil { for _,veh := range vehicles { - myPlateNosMap[veh.PlateNo] = veh.PlateNo - //myPlateNos = append(myPlateNos, veh.PlateNo) + if veh.PlateNo != "" { + r := []rune(veh.PlateNo) + ncStr := string(r[1:]) //鎶婄涓�浣嶆眽瀛楀墧闄ゆ帀 + myPlateNosMap[ncStr] = ncStr + } + //myPlateNosMap[veh.PlateNo] = veh.PlateNo } } } @@ -179,7 +300,6 @@ return nil } for _,s := range spaceList { - pi := models.PosInfo { SpaceNo: s.SpaceNo, PosNo: "", @@ -190,11 +310,7 @@ } else if s.PlateNos != "" { pi.PlateNo = s.PlateNos } - isMine := false - if _,exist := myPlateNosMap[pi.PlateNo]; exist { - isMine = true - } - pi.IsMine = isMine + pi.IsMine = isMyPlateNo(myPlateNosMap, pi.PlateNo) if v,ok := models.SpaceNo2Pos[s.SpaceNo];ok { pi.PosNo = v } @@ -215,6 +331,35 @@ } return resultList +} + +//鍒ゆ柇鏄笉鏄嚜宸辩殑杞︾墝鍙� +//1.鐩墠鏈夎璇嗗埆鐨勯棶棰橈紝浼氭妸D璇嗗埆鎴�0,D鍜�0涓嶅垎 +//2.姹夊瓧璇瘑鍒殑鍑犵巼姣旇緝楂� +func isMyPlateNo(plateNoM map[string]string, targetPlateNo string) bool { + if targetPlateNo != "" { + r := []rune(targetPlateNo) + nctPlateNo := string(r[1:]) + + if _,exist := plateNoM[nctPlateNo];exist { + return true + } else { + match := false + for k,_ := range plateNoM { + newK := strings.ReplaceAll(k, "D", "*") + newK = strings.ReplaceAll(newK, "0", "*") + + tt := strings.ReplaceAll(nctPlateNo,"D", "*") + tt = strings.ReplaceAll(tt,"0", "*") + if newK == tt { + match = true + break + } + } + return match + } + } + return false } func (sv *CarService) BindCarSpace() bool { @@ -251,6 +396,37 @@ PersonId string `json:"personId"` } +//浠ヤ汉鍛榠d涓簁ey +func (sv *CarService) GetHikPersonMap() map[string]HikPerson { + m := make(map[string]HikPerson) + personList := sv.GetHikPersonList() + if personList != nil { + for _,p := range personList { + m[p.PersonId] = p + } + } + return m +} + +//浠ヨ溅鐗屽彿涓篕ey +func (sv *CarService) GetHikVehicleMap() map[string] HikVehicle { + m := make(map[string]HikVehicle) + carPersons := sv.GetVehicleListByPerson("") + if carPersons != nil { + for _,veh := range carPersons { + if veh.PlateNo != "" { + r := []rune(veh.PlateNo) + ncStr := string(r[1:]) //鎶婄涓�浣嶆眽瀛楀墧闄ゆ帀 + newK := strings.ReplaceAll(ncStr, "D", "*") + newK = strings.ReplaceAll(newK, "0", "*") + m[newK] = veh + } + } + } + + return m +} + func (sv *CarService) GetHikPersonList() []HikPerson { url := "/artemis/api/resource/v2/person/personList" pageSize := 1000 -- Gitblit v1.8.0