From 263c7b18ce7f18f1222318f6e0e499e907895a52 Mon Sep 17 00:00:00 2001 From: liuxiaolong <736321739@qq.com> Date: 星期三, 13 十一月 2019 19:33:39 +0800 Subject: [PATCH] fix --- controllers/syssetcont.go | 424 +++++++++++++++++++++++++++++++++++++++------------- 1 files changed, 317 insertions(+), 107 deletions(-) diff --git a/controllers/syssetcont.go b/controllers/syssetcont.go index 1a08f8e..810a8aa 100644 --- a/controllers/syssetcont.go +++ b/controllers/syssetcont.go @@ -1,20 +1,60 @@ package controllers import ( + "basic.com/dbapi.git" "github.com/gin-gonic/gin" + "regexp" "webserver/extend/code" + "webserver/extend/config" + "webserver/extend/sys" "webserver/extend/util" - "webserver/models" - "github.com/satori/go.uuid" - "strconv" ) type SysSetController struct { } -// @Summary 瀛樺偍淇℃伅鏌ヨ -// @Description 瀛樺偍淇℃伅鏌ヨ +type LocalConfigVo struct { + Id string `json:"id"` + AlarmIp string `json:"alarm_ip,omitempty" example:"192.168.1.182"` + AlarmPort int `json:"alarm_port,omitempty" example:"22122"` + AlarmThresholdType int `json:"alarm_threshold_type"`//鎶ヨ闃堝�肩被鍨嬭缃細1:鎸夋渶楂樺垎,2:鎸夐槇鍊间互涓� + AlarmThreshold int `json:"alarm_threshold"`//鎶ヨ闃堝�� + WebPicIp string `json:"web_pic_ip,omitempty" example:""` + WebPicPort int `json:"web_pic_port,omitempty" example:"22122"` + EsPicIp string `json:"es_pic_ip,omitempty" example:""` + EsPicPort int `json:"es_pic_port,omitempty" example:"22122"` + CutMaxDuration int `json:"cut_max_duration,omitempty" example:"20"` + CutMinDuration int `json:"cut_min_duration,omitempty" example:"5"` + ServerId string `json:"server_id,omitempty" example:"鍒嗘瀽璁惧id"` + ServerName string `json:"server_name,omitempty" example:"鍒嗘瀽璁惧鍚嶇О"` + ServerType int `json:"server_type,omitempty" example:"1"` + Reserved string `json:"reserved,omitempty" example:"1"` + RealMax int `json:"real_max"`//瀹炴椂澶勭悊鐨勬渶澶ц矾鏁� +} + +type Gb28181ConfigVo struct { + Id string `json:"Id"` + ServerIp string `json:"ServerIp" example:"鍥芥爣鏈嶅姟鍣↖P"` + ServerPort int `json:"ServerPort" example:"鏈嶅姟鍣ㄧ鍙�:8060"` + PublicId string `json:"PublicId" example:"鍥芥爣鏈嶅姟鍣↖d"` + GbServerPort int `json:"GbServerPort" example:"鍥芥爣鏈嶅姟绔彛:7060"` + IsAuth bool `json:"IsAuth" example:"鏄惁寮�鍚壌鏉�:true"` + Password string `json:"Password" example:"瀵嗙爜"` + UpdateTime string `json:"UpdateTime"` +} + +type SysClockConfigVo struct { + TimeZone string `json:"timeZone" example:"鏃跺尯"` + NTP bool `json:"ntp" example:"NTP鏍℃椂"` + NTPServer string `json:"ntpServer" example:"NTP鏈嶅姟鍣ㄥ湴鍧�"` + Interval int `json:"interval" example:"鑷姩鏍℃椂闂撮殧"` + NewTime string `json:"newTime" example:"鎵嬪姩鎸囧畾鏃堕棿"` +} + +// @Security ApiKeyAuth +// @Summary 鍩虹璁剧疆鏌ヨ +// @Description 鍩虹璁剧疆鏌ヨ // @Accept json // @Produce json // @Tags sysset @@ -22,53 +62,45 @@ // @Failure 500 {string} json "{"code":500, msg:"杩斿洖閿欒淇℃伅", success:false}" // @Router /data/api-v/sysset/alarmServerShow [GET] func (sset SysSetController) AlarmServerShow(c *gin.Context){ - config := new(models.LocalConfig) - if err := config.Select(); err != nil { - util.ResponseFormat(c, code.ServiceInsideError, config) + var api dbapi.SysSetApi + b, sysconf := api.GetServerInfo() + if b{ + util.ResponseFormat(c,code.Success,sysconf) } else { - util.ResponseFormat(c, code.Success, config) + util.ResponseFormat(c,code.ComError,"鏌ヨ澶辫触") } } -// @Summary 瀛樺偍淇℃伅淇敼 -// @Description 瀛樺偍淇℃伅淇敼 +// @Security ApiKeyAuth +// @Summary 鎶ヨ璁剧疆淇敼 +// @Description 鎶ヨ璁剧疆淇敼 // @Accept json // @Produce json // @Tags sysset -// @Param config body models.LocalConfig true "鎶ヨ鍜屽瓨鍌ㄤ俊鎭暟鎹�" +// @Param config body controllers.LocalConfigVo true "鎶ヨ鍜屽瓨鍌ㄤ俊鎭暟鎹�" // @Success 200 {string} json "{"code":200, msg:"鐩綍缁撴瀯鏁版嵁", success:true}" // @Failure 500 {string} json "{"code":500, msg:"杩斿洖閿欒淇℃伅", success:false}" // @Router /data/api-v/sysset/alarmEdit [POST] func (sset SysSetController) AlarmEdit(c *gin.Context) { - config := new(models.LocalConfig) // 鏌ヨ缁戝畾 - reqCon := new(models.LocalConfig) // 鍓嶅彴鏁版嵁缁戝畾 - c.BindJSON(reqCon) - if err := config.Select(); err != nil { // 鏌ヨ鏄惁瀛樺湪 - util.ResponseFormat(c, code.ServiceInsideError, config) - } else { - copyColumnValueForAlarm(reqCon ,config) // 涓嶅嵃璞″叾浠栧�� - reqCon.ID = config.ID // 淇敼蹇呴』鏈� id - if e := reqCon.Update(); e != nil { - util.ResponseFormat(c, code.ServiceInsideError, e.Error()) - } else { - util.ResponseFormat(c, code.Success,reqCon) - } + var args LocalConfigVo + err := c.BindJSON(&args) + if err !=nil { + util.ResponseFormat(c,code.RequestParamError,"鍙傛暟鏈夎") + return + } + var api dbapi.SysSetApi + paramBody := util.Struct2Map(args) + b,data := api.AlarmEdit(paramBody) + if b { + util.ResponseFormat(c,code.Success,data) + }else { + util.ResponseFormat(c,code.ComError,"淇濆瓨澶辫触") } } - -// 鏈湴 閰嶇疆淇℃伅 澶嶅埗 -func copyColumnValueForAlarm(reqCon *models.LocalConfig,config *models.LocalConfig) { - reqCon.Dev_id = config.Dev_id - reqCon.Dev_name = config.Dev_name - reqCon.Cut_min_duration = config.Cut_min_duration - reqCon.Cut_max_duration = config.Cut_max_duration - reqCon.Dev_type = config.Dev_type - reqCon.Reserved = config.Reserved -} - -// @Summary 瀛樺偍淇℃伅淇敼 -// @Description 瀛樺偍淇℃伅淇敼 +// @Security ApiKeyAuth +// @Summary 鎶ヨ鏃堕暱淇敼 +// @Description 鎶ヨ鏃堕暱淇敼 // @Accept json // @Produce json // @Tags sysset @@ -76,18 +108,20 @@ // @Failure 500 {string} json "{"code":500, msg:"杩斿洖閿欒淇℃伅", success:false}" // @Router /data/api-v/sysset/videoLenShow [GET] func (sset SysSetController) VideoLenShow(c *gin.Context){ - config := new(models.LocalConfig) // 鍓嶅彴鏁版嵁缁戝畾 - if err := config.Select(); err != nil { // 鏌ヨ鏄惁瀛樺湪 - util.ResponseFormat(c, code.ServiceInsideError, config) + var api dbapi.SysSetApi + b, sysconf := api.GetServerInfo() + if b { + resData := make(map[string]int32, 0) + resData["max_video_len"] = sysconf.CutMaxDuration + resData["min_video_len"] = sysconf.CutMinDuration + // 瀛樺湪鍒欎慨鏀� + util.ResponseFormat(c, code.Success, resData) } else { - resData := make(map[string]int, 0) - resData["max_video_len"] = config.Cut_max_duration - resData["min_video_len"] = config.Cut_min_duration - // 瀛樺湪鍒欎慨鏀� - util.ResponseFormat(c, code.Success, resData) + util.ResponseFormat(c,code.ComError,"鏌ヨ澶辫触") } } +// @Security ApiKeyAuth // @Summary 瑙嗛鎴彇鏃堕暱淇敼 // @Description 瑙嗛鎴彇鏃堕暱淇℃伅 // @Accept x-www-form-urlencoded @@ -99,28 +133,21 @@ // @Failure 500 {string} json "{"code":500, msg:"杩斿洖閿欒淇℃伅", success:false}" // @Router /data/api-v/sysset/videoLenEdit [POST] func (sset SysSetController) VideoLenEdit(c *gin.Context) { - config := new(models.LocalConfig) // 鍓嶅彴鏁版嵁缁戝畾 - /*min_video_len := c.Query("min_video_len") //鏌ヨ璇锋眰URL鍚庨潰鐨勫弬鏁� max_video_len := c.PostForm("max_video_len") //浠庤〃鍗曚腑鏌ヨ鍙傛暟*/ //POST鍜孭UT涓讳綋鍙傛暟浼樺厛浜嶶RL鏌ヨ瀛楃涓插�笺�� max_video_len := c.Request.FormValue("max_video_len") min_video_len := c.Request.FormValue("min_video_len") - if err := config.Select(); err != nil { // 鏌ヨ鏄惁瀛樺湪 - util.ResponseFormat(c, code.ServiceInsideError, config) + var api dbapi.SysSetApi + b,data := api.VideoLenEdit(max_video_len,min_video_len) + if b{ + util.ResponseFormat(c,code.UpdateSuccess,data) } else { - max, _ := strconv.Atoi(max_video_len) // 鏁版嵁 string 杞� int8 - min, _ := strconv.Atoi(min_video_len) - config.Cut_max_duration = max - config.Cut_min_duration = min - if e := config.Update(); e != nil { - util.ResponseFormat(c, code.ServiceInsideError, e.Error()) - } else { - util.ResponseFormat(c, code.Success, config) - } + util.ResponseFormat(c,code.ComError,"淇濆瓨澶辫触") } } +// @Security ApiKeyAuth // @Summary 鑾峰彇鍒嗘瀽璁惧淇℃伅 // @Description 鍒嗘瀽璁惧淇℃伅 // @Accept json @@ -130,18 +157,25 @@ // @Failure 500 {string} json "{"code":500, msg:"杩斿洖閿欒淇℃伅", success:false}" // @Router /data/api-v/sysset/getDevInfo [GET] func (sset SysSetController) GetDevInfo(c *gin.Context) { - config := new(models.LocalConfig) // 鍓嶅彴鏁版嵁缁戝畾 - resData := make(map[string]string, 0) - if err := config.Select(); err != nil { // 鏌ヨ鏄惁瀛樺湪 - util.ResponseFormat(c, code.ServiceInsideError,err.Error()) + var api dbapi.SysSetApi + b, sysconf := api.GetServerInfo() + resData := make(map[string]string, 0) + if !b { // 鏌ヨ鏄惁瀛樺湪 + util.ResponseFormat(c, code.ServiceInsideError,"鏌ヨ澶辫触") }else { - resData["dev_id"] = config.Dev_id - resData["dev_name"] = config.Dev_name - // 瀛樺湪 - util.ResponseFormat(c, code.Success, resData) + resData["server_id"] = sysconf.GetServerId() + resData["server_name"] = sysconf.GetServerName() + ipv4, mask, _ := util.GetLocalIP(config.Server.NetworkAdapter) + gateway, _ := util.GetDefaultRoute(config.Server.NetworkAdapter) + resData["ip"] = ipv4 + resData["subMask"] = mask + resData["gateway"] = gateway + // 瀛樺湪 + util.ResponseFormat(c, code.Success, resData) } } +// @Security ApiKeyAuth // saveDevInfo dev_id dev_name // @Summary 淇濆瓨瑙嗛鍒嗘瀽璁惧淇℃伅 // @Description 鍒嗘瀽璁惧淇℃伅 @@ -153,25 +187,20 @@ // @Failure 500 {string} json "{"code":500, msg:"杩斿洖閿欒淇℃伅", success:false}" // @Router /data/api-v/sysset/saveDevInfo [POST] func (sset SysSetController) SaveDevInfo(c *gin.Context){ - config := new(models.LocalConfig) // 鍓嶅彴鏁版嵁缁戝畾 - dev_name := c.Request.FormValue("dev_name") - if err := config.Select(); err != nil { // 鏌ヨ鏄惁瀛樺湪 - util.ResponseFormat(c, code.ServiceInsideError,err.Error()) - } else { // 瀛樺湪鍙婁慨鏀� 涓嶅瓨鍦� 鍗虫坊鍔� - config.Dev_name = dev_name - if config.Dev_id == "" { - config.Dev_id = uuid.NewV4().String() - } - if e := config.Update(); e != nil { - util.ResponseFormat(c, code.ServiceInsideError, e.Error()) - } else { - util.ResponseFormat(c, code.Success, config) - } + dev_name := c.PostForm("server_name") + var api dbapi.SysSetApi + paramBody :=make(map[string]interface{},0) + paramBody["serverName"] = dev_name + b,data := api.SaveServerInfo(paramBody) + if b { // 鏌ヨ鏄惁瀛樺湪 + util.ResponseFormat(c,code.Success,data) + } else { // 瀛樺湪鍙婁慨鏀� 涓嶅瓨鍦� 鍗虫坊鍔� + util.ResponseFormat(c,code.ComError,"淇濆瓨澶辫触") } } - +// @Security ApiKeyAuth // @Summary GB28181璁剧疆鏌ヨ // @Description GB28181璁剧疆淇℃伅鏌ヨ // @Accept json @@ -179,43 +208,224 @@ // @Tags sysset // @Success 200 {string} json "{"code":200, msg:"鐩綍缁撴瀯鏁版嵁", success:true}" // @Failure 500 {string} json "{"code":500, msg:"杩斿洖閿欒淇℃伅", success:false}" -// @Router /data/api-v/sysset/vSSLocalSettingShow [GET] -func (sset SysSetController) VSSLocalSettingShow(c *gin.Context) { - config := new(models.VSSLocalSettingTbl) - if err := config.Select(); err != nil { - util.ResponseFormat(c, code.ServiceInsideError, config) +// @Router /data/api-v/sysset/gb28181ConfigShow [GET] +func (sset SysSetController) Gb28181ConfigShow(c *gin.Context) { + var api dbapi.SysSetApi + b, data := api.Gb28181ConfigShow() + if b { + util.ResponseFormat(c,code.Success,data) } else { - if config == nil { - util.ResponseFormat(c, code.DdSelectNotFindError, config) - } else { - util.ResponseFormat(c, code.Success, config) - } + util.ResponseFormat(c,code.ComError,"鏌ヨ澶辫触") } } +// @Security ApiKeyAuth // @Summary GB28181璁剧疆淇℃伅淇敼 // @Description GB28181璁剧疆淇敼 // @Accept json // @Produce json // @Tags sysset -// @Param config body models.VSSLocalSettingTbl true "GB28181璁剧疆鏁版嵁" +// @Param config body controllers.Gb28181ConfigVo true "GB28181璁剧疆鏁版嵁" // @Success 200 {string} json "{"code":200, msg:"鐩綍缁撴瀯鏁版嵁", success:true}" // @Failure 500 {string} json "{"code":500, msg:"杩斿洖閿欒淇℃伅", success:false}" -// @Router /data/api-v/sysset/vSSLocalSettingEdit [POST] -func (sset SysSetController) VSSLocalSettingEdit(c *gin.Context) { - config := new(models.VSSLocalSettingTbl) // 鏌ヨ缁戝畾 - reqCon := new(models.VSSLocalSettingTbl) // 鍓嶅彴鏁版嵁缁戝畾 - c.BindJSON(reqCon) - if err := config.Select(); err != nil { // 鏌ヨ鏄惁瀛樺湪 - util.ResponseFormat(c, code.ServiceInsideError, config) +// @Router /data/api-v/sysset/gb28181ConfigEdit [POST] +func (sset SysSetController) Gb28181ConfigEdit(c *gin.Context) { + var args Gb28181ConfigVo + err := c.BindJSON(&args) + if err !=nil { + util.ResponseFormat(c,code.RequestParamError,"鍙傛暟鏈夎") + return + } + var api dbapi.SysSetApi + paramBody := util.Struct2Map(args) + b, data := api.Gb28181ConfigEdit(paramBody) + if b { + util.ResponseFormat(c,code.UpdateSuccess,data) } else { - { // 瀛樺湪鍒欎慨鏀� - reqCon.ID = config.ID - if e := reqCon.Update(); e != nil { - util.ResponseFormat(c, code.ServiceInsideError, e.Error()) - } else { - util.ResponseFormat(c, code.Success, reqCon) - } + util.ResponseFormat(c,code.ComError,"鏇存柊澶辫触") + } +} + +/* +// @Security ApiKeyAuth +// @Summary 鑾峰彇鏃堕棿閰嶇疆 +// @Description 绯荤粺鏃堕棿閰嶇疆淇℃伅 +// @Accept json +// @Produce json +// @Tags sysset +// @Success 200 {string} json "{"code":200, msg:"鐩綍缁撴瀯鏁版嵁", success:true}" +// @Failure 500 {string} json "{"code":500, msg:"杩斿洖閿欒淇℃伅", success:false}" +// @Router /data/api-v/sysset/clockInfo [GET] +*/ +func (sset SysSetController) GetClockinfo(c *gin.Context) { + resData := make(map[string]interface{}, 0) + resData["time_zone"], resData["local_time"] = sys.TimeZone() + resData["ntp"], resData["ntp_server"], resData["interval"] = sys.NTPConfig() + + util.ResponseFormat(c, code.Success, resData) +} + +/* +// @Security ApiKeyAuth +// @Summary 娴嬭瘯鍚屾鏃堕棿 +// @Description 娴嬭瘯鍚屾鏃堕棿鏈嶅姟鍣ㄦ槸鍚﹀彲鐢� +// @Produce json +// @Tags sysset +// @Param server query string true "鏃堕棿鏈嶅姟鍣╥p" +// @Success 200 {string} json "{"code":200, msg:"鐩綍缁撴瀯鏁版嵁", success:true}" +// @Failure 500 {string} json "{"code":500, msg:"杩斿洖閿欒淇℃伅", success:false}" +// @Router /data/api-v/sysset/ntpTest [GET] +*/ +func (sset SysSetController) TestNTPServer(c *gin.Context) { + ntpServer := c.Query("server") + + if root := sys.CheckRootPermissions(); !root { + util.ResponseFormat(c, code.ServiceInsideError, "鏈嶅姟鍣ㄦ病鏈変慨鏀规椂闂寸殑鏉冮檺") + return + } + + isConn := sys.RunNTPDate(ntpServer) + if !isConn { + util.ResponseFormat(c, code.RequestParamError, "NTP鏈嶅姟鍣ㄤ笉鍙敤") + return + } + + util.ResponseFormat(c, code.Success, "") + +} + +/* +// @Security ApiKeyAuth +// @Summary 璁剧疆绯荤粺鏃堕棿 +// @Description 鏍℃绯荤粺鏃堕棿 +// @Accept json +// @Produce json +// @Tags sysset +// @Param config body controllers.SysClockConfigVo true "鏍℃椂淇℃伅" +// @Success 200 {string} json "{"code":200, msg:"鐩綍缁撴瀯鏁版嵁", success:true}" +// @Failure 500 {string} json "{"code":500, msg:"杩斿洖閿欒淇℃伅", success:false}" +// @Router /data/api-v/sysset/updateClock [POST] +*/ +func (sset SysSetController) SetSysClock(c *gin.Context) { + var args SysClockConfigVo + err := c.BindJSON(&args) + if err != nil { + util.ResponseFormat(c, code.RequestParamError, "鍙傛暟鏈夎") + return + } + + if args.TimeZone != "CST" && args.TimeZone != "UTC" { + if r := sys.SetTimeZone(args.TimeZone); !r { + util.ResponseFormat(c, code.RequestParamError, "鏃跺尯鍙傛暟閿欒") + return } } + + if !args.NTP { + if r := sys.SetLocalTime(args.NewTime); !r { + util.ResponseFormat(c, code.RequestParamError, "鎸囧畾鐨勬椂闂村弬鏁伴敊璇�") + return + } + } else { + if r := sys.EnableNTPCron(args.NTPServer, args.Interval); !r { + util.ResponseFormat(c, code.RequestParamError, "鎸囧畾鐨勬湇鍔″櫒鍦板潃閿欒") + return + } + } + + util.ResponseFormat(c, code.UpdateSuccess, "閰嶇疆鎴愬姛") +} + +/* +// @Security ApiKeyAuth +// @Summary 鏌ヨ绯荤粺杩愯淇℃伅 +// @Description 鑾峰彇褰撳墠绯荤粺鐨勮繍琛岀姸鎬侊紝CPU, GPU, 鍐呭瓨绛� +// @Produce json +// @Tags sysset +// @Success 200 {string} json "{"code":200, msg:"鐩綍缁撴瀯鏁版嵁", success:true}" +// @Failure 500 {string} json "{"code":500, msg:"杩斿洖閿欒淇℃伅", success:false}" +// @Router /data/api-v/sysset/sysinfo [GET] +*/ +func (sset SysSetController) GetSysInfo(c *gin.Context) { + info := sys.GetSysInfo() + util.ResponseFormat(c, code.UpdateSuccess, info) +} + +/* +// @Security ApiKeyAuth +// @Summary 鏌ヨ绯荤粺鐘舵�侀槇鍊艰缃� +// @Description 鑾峰彇褰撳墠绯荤粺鐨勮繍琛岀姸鎬侊紝CPU, GPU, 鍐呭瓨鐨勯槇鍊奸厤缃� +// @Produce json +// @Tags sysset +// @Success 200 {string} json "{"code":200, msg:"鐩綍缁撴瀯鏁版嵁", success:true}" +// @Failure 500 {string} json "{"code":500, msg:"杩斿洖閿欒淇℃伅", success:false}" +// @Router /data/api-v/sysset/sysThresholds [GET] +*/ +func (sset SysSetController) GetSysThresholds(c *gin.Context) { + util.ResponseFormat(c, code.UpdateSuccess, config.Server.SysThresholds) +} + +/* +// @Security ApiKeyAuth +// @Summary 閲嶅惎绯荤粺 +// @Description 閲嶅惎鎿嶄綔绯荤粺 +// @Produce json +// @Tags sysset +// @Success 200 {string} json "{"code":200, msg:"鐩綍缁撴瀯鏁版嵁", success:true}" +// @Failure 500 {string} json "{"code":500, msg:"杩斿洖閿欒淇℃伅", success:false}" +// @Router /data/api-v/sysset/reboot [GET] +*/ +func (sset SysSetController) RebootOS(c *gin.Context) { + if isOk, msg := sys.Reboot(); !isOk { + util.ResponseFormat(c, code.UpdateFail, msg) + return + } + + util.ResponseFormat(c, code.Success, "姝e湪閲嶅惎") +} + +/* +// @Summary 鑾峰彇瀹氭椂閲嶅惎 +// @Description 鑾峰彇瀹氭椂閲嶅惎浠诲姟鐨勯厤缃鍒� +// @Produce json +// @Tags sysset +// @Success 200 {string} json "{"code":200, msg:"鐩綍缁撴瀯鏁版嵁", success:true}" +// @Failure 500 {string} json "{"code":500, msg:"杩斿洖閿欒淇℃伅", success:false}" +// @Router /data/api-v/sysset/rebootTask [GET] +*/ +func (sset SysSetController) GetRebootTask(c *gin.Context) { + _, msg := sys.ReadRebootTaskInCrontab() + util.ResponseFormat(c, code.Success, msg) +} + +/* +// @Summary 璁剧疆瀹氭椂閲嶅惎 +// @Description 璁剧疆瀹氭椂閲嶅惎浠诲姟鐨勯厤缃鍒� +// @Accept x-www-form-urlencoded +// @Produce json +// @Tags sysset +// @Success 200 {string} json "{"code":200, msg:"鐩綍缁撴瀯鏁版嵁", success:true}" +// @Failure 500 {string} json "{"code":500, msg:"杩斿洖閿欒淇℃伅", success:false}" +// @Router /data/api-v/sysset/rebootTask [POST] +*/ +func (sset SysSetController) SetRebootTask(c *gin.Context) { + task := c.PostForm("task") + if len(task) < 1 { + sys.CleanRebootTask() + util.ResponseFormat(c, code.Success, "閰嶇疆鎴愬姛") + return + } + + regEx := `^([0-9*]+\s){4}[0-9*]+$` + if r, _ := regexp.MatchString(regEx, task); !r { + util.ResponseFormat(c, code.RequestParamError, "鍙傛暟閿欒") + return + } + + if r := sys.UpdateRebootTask(task); !r { + util.ResponseFormat(c, code.UpdateFail, "閰嶇疆澶辫触") + return + } + + util.ResponseFormat(c, code.Success, "閰嶇疆鎴愬姛") } -- Gitblit v1.8.0