func PassengerFindDriver(hs *routing.HTTPSession) routing.HResult { var uid int64 var startTime int64 var sLat float64 var sLng float64 var eLat float64 var eLng float64 var sCity string var eCity string t := time.Now() err := hs.ValidCheckVal(` uid,R|I,R:0; startTime,R|I,R:0; sLat,R|F,R:0; sLng,R|F,R:0; eLat,R|F,R:0; eLng,R|F,R:0; sCity,R|S,L:0; eCity,R|S,L:0; `, &uid, &startTime, &sLat, &sLng, &eLat, &eLng, &sCity, &eCity) if err != nil { return hs.MsgResErr(100, "config error", err) } else if t.Unix()-startTime < 1800 { return hs.MsgResE(1, "invalid startTime , need > 30min from now") } else { s, err := db.FindDriverRoute(uid, startTime, sLat, sLng, eLat, eLng, sCity, eCity) if err != nil { return hs.MsgResErr2(1, "", err) } else { return hs.MsgRes(s) } } }
func ListChapter(hs *routing.HTTPSession) routing.HResult { var id int64 = 0 err := hs.ValidRVal(` id,R|I,R:-1~10 `, &id) if err != nil { return hs.MsgResE(1, err.Error()) } is := []Item{} for i := 0; i < 10; i++ { it := Item{} it.Id = i it.Name = fmt.Sprintf("ch-%d-%d", id, i) is = append(is, it) } return hs.MsgRes(is) }
func GetAnswerRecord(hs *routing.HTTPSession) routing.HResult { var aId int64 err := hs.ValidCheckVal(` aId,R|I,R:0; `, &aId) if err != nil { log.E("GetAnswerRecord arg error:%v", err) return hs.MsgResE(1, fmt.Sprintf("%s:%s", common_.ARG_ERROR, err.Error())) } conn := dbMgr.DbConn() var content sql.NullString if err := conn.QueryRow("select content from ebs_answer where tid=?", aId).Scan(&content); err != nil { if err != sql.ErrNoRows { return hs.MsgResE(2, err.Error()) } } return hs.MsgRes(content.String) }
func SaveAnswer(hs *routing.HTTPSession) routing.HResult { var aId int64 var a string err := hs.ValidCheckVal(` aId,R|I,R:0; a,R|S,L:0; `, &aId, &a) if err != nil { log.E("SaveAnswer arg error:%v", err) return hs.MsgResE(1, fmt.Sprintf("%s:%s", common_.ARG_ERROR, err.Error())) } aParse := []ANSWER2{} if err := json.Unmarshal([]byte(a), &aParse); err != nil { log.E("%v", err) return hs.MsgResE(1, fmt.Sprintf("%s:作答内容格式错误,%s", common_.ARG_ERROR, err.Error())) } sql_ := `update ebs_answer set content=? where tid=?` conn := dbMgr.DbConn() if _, err := conn.Exec(sql_, a, aId); err != nil { log.E("SaveAnswer db error:%v,sql:%s,args:%v", err, sql_, a) return hs.MsgResE(2, fmt.Sprintf("%s:%s", common_.DB_ERROR, err.Error())) } return hs.MsgRes("success") }