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