func generator(t time.Duration) { for { var s conn.Setting s.GetSetting() if s.Isconnected { var k ftprotocol.KeepAlive k.SessionKey = []byte(s.Sessionkey) k.Sequence = byte(s.Sequence[0]) // log.Printf("session key : %X, sequence : %X\n", k.SessionKey, k.Sequence) // log.Printf("send keepalive : %X", k.Message()) var m conn.Message m.Messagetype = conn.REQUEST m.Info = hex.EncodeToString(k.Message()) m.Status = conn.NONE m.InsertMessage() // sequence = IncreaseSeq(sequence) } time.Sleep(time.Millisecond * time.Duration(t)) // time.Sleep(time.Millisecond * time.Duration(s.Writeinterval)) } }
func (c *SerialController) SendMessage() { input := c.GetString("input") var m conn.Message m.Messagetype = conn.REQUEST m.Info = input m.Status = conn.NONE m.InsertMessage() c.Ctx.WriteString("ok") }
func writer(t time.Duration) { // get one request for { var s conn.Setting s.GetSetting() // time.Sleep(time.Millisecond * time.Duration(s.Writeinterval)) time.Sleep(time.Millisecond * time.Duration(t)) if s.Isconnected { var m conn.Message err := m.GetOneRequest() if err != nil { // log.Println("writer:", err.Error()) continue } // log.Printf("get one request :%v", m) b, _ := hex.DecodeString(m.Info) err = comm.Writer(b) if err != nil { log.Println(err.Error()) continue } log.Printf("Send:%X", b) IncreaseOneSequence() if bSoftDelete { m.Status = conn.DELETED m.UpdateStatus() } else { m.DeleteMessage() // log.Println("the request is deleted.") } } } }
func reader(t time.Duration) { for { var m conn.Message b, _ := comm.Reader() if len(b) > 0 { m.Messagetype = conn.RESPONSE m.Info = hex.EncodeToString(b) m.Status = conn.NONE log.Printf("Received : %X", b) m.InsertMessage() } time.Sleep(time.Millisecond * t) } }
func (c *MesssageController) SendPwdKey() { messageid := ftprotocol.SCREENPRESS var setting conn.Setting setting.GetSetting() switch messageid { case ftprotocol.SCREENPRESS: var g ftprotocol.ScreenPress g.SessionKey = []byte(strings.ToUpper(setting.Sessionkey)) g.MessageID = []byte(strings.ToUpper(c.GetString("messageid"))) g.Sequence = byte(setting.Sequence[0]) screenid, _ := c.GetInt32("screenid") g.ScreenID = uint32(screenid) coorx, _ := c.GetInt32("coorx") g.X = uint32(coorx) coory, _ := c.GetInt32("coory") g.Y = uint32(coory) // log.Println(g) out := g.Message() // log.Println(out) var m conn.Message m.Messagetype = conn.REQUEST m.Info = hex.EncodeToString(out) m.Status = conn.NONE log.Println(m.Info) m.InsertMessage() c.Ctx.WriteString("ok") default: c.Ctx.WriteString("Invalid Message") } }
func worker(t time.Duration) { for { time.Sleep(time.Millisecond * t) // log.Println("working....") var m conn.Message err := m.GetOneResponse() if err != nil { // log.Println("worker:", err.Error()) continue // log.Printf("get one response :%v", m) } // log.Println(m.Info) b, err := hex.DecodeString(m.Info) if err != nil { log.Println(err.Error()) m.Status = conn.INVALID m.UpdateStatus() continue } var f ftprotocol.Frame // log.Printf("%X", b) s, err := f.Parse(b) if err != nil { log.Printf("%X:%s\n", b, err.Error()) // m.DeleteMessage() m.Status = conn.INVALID m.UpdateStatus() continue } msgid, _ := strconv.ParseInt(string(f.MessageID), 16, 32) switch msgid { case ftprotocol.REQUESTSESSIONRESPONSE: var sessionres ftprotocol.RequestSessionResponse sessionres.Frame = f err := sessionres.ParseMessageData(f.MessageData) if err != nil { log.Println(err.Error()) m.Status = conn.INVALID m.UpdateStatus() continue } var s conn.Setting s.Sessionstatus = sessionres.SessionStatus s.UpdateSessionStatus() s.Sessiontimeout = sessionres.SessionTimeout s.UpdateSessiontimeout() s.Deviceid = conn.DeviceID(sessionres.DeviceID) s.UpdateDeviceid() s.Protocolver = strconv.FormatUint(uint64(sessionres.ProtocolVersion), 10) s.UpdateProtocolVer() s.Sessionkey = string(sessionres.SessionKey) s.UpdateSessionKey() s.Sequence = string(sessionres.Sequence) s.UpdateSequence() s.Messagetimeout = sessionres.MessageTimeout s.UpdateMessagetimeout() s.Maxretrycount = sessionres.MaxRetryCount s.UpdateMaxretrycount() case ftprotocol.DEVICENAMERESPONSE: var res ftprotocol.DeviceNameResponse res.Frame = f err := res.ParseMessageData(f.MessageData) if err != nil { log.Println(err.Error()) m.Status = conn.INVALID m.UpdateStatus() continue } var s conn.Setting // log.Println("device name : ", res.StringName) s.Devicename = res.StringName err = s.UpdateDevicename() if err != nil { log.Println("UpdateDevicename:", err.Error()) } case ftprotocol.GETSENSORRESPONSE: var res ftprotocol.GetSensorResponse res.Frame = f err := res.ParseMessageData(f.MessageData) if err != nil { log.Println("GETSENSORRESPONSE:", err.Error()) m.Status = conn.INVALID m.UpdateStatus() continue } var s conn.Setting s.Sensorbroadcastperiod = res.BroadcastPeriod err = s.UpdateSensorbroadcastperiod() if err != nil { log.Println("UpdateSensorbroadcastperiod :", err.Error()) } case ftprotocol.DSP1SENSORDATA: var res ftprotocol.Dsp1SensorData res.Frame = f err := res.ParseMessageData(f.MessageData) if err != nil { log.Println("DSP1SENSORDATA:", err.Error()) m.Status = conn.INVALID m.UpdateStatus() continue } var s conn.Sensordata s.Isvaliddata = res.IsValidData s.Sequencenumber = res.SequenceNumber s.Isactivatingflag = res.IsActivatingFlag s.Vavg = res.Vavg s.Iavg = res.Iavg s.Pavg = res.Pavg s.Vrms = res.Vrms s.Irms = res.Irms s.Viphase = res.Viphase s.Vpk = res.Vpk s.Ipk = res.Ipk s.Vcf = res.Vcf s.Icf = res.Icf s.Zload = res.Zload s.T1 = res.T1 s.T2 = res.T2 s.Leakage = res.Leakage s.Stimpos = res.Stimpos s.Stimneg = res.Stimneg s.Oltarget = res.Oltarget s.Createtime = time.Now() s.InsertSensordata() case ftprotocol.EMPTY: var s conn.Setting s.Sequence = string(f.Sequence) // log.Printf("sequence : %X", s.Sequence) s.UpdateSequence() default: log.Printf("unsupported message : %X", msgid) } if len(s) > 0 { m.Info = s m.UpdateInfo() } else { // log.Println(m) if bSoftDelete { m.Status = conn.DELETED m.UpdateStatus() } else { m.DeleteMessage() // log.Println("the request is deleted.") } } } }