feat: 系统初始引导使用重置接口
This commit is contained in:
@@ -19,3 +19,6 @@ const STATUS_NO = "0"
|
||||
|
||||
// 上下文信息-登录用户
|
||||
const CTX_LOGIN_USER = "loginuser"
|
||||
|
||||
// 启动-引导系统初始
|
||||
const LAUNCH_BOOTLOADER = "bootloader"
|
||||
|
||||
@@ -8,6 +8,7 @@ import (
|
||||
"runtime"
|
||||
"time"
|
||||
|
||||
"be.ems/src/framework/constants/common"
|
||||
"be.ems/src/framework/logger"
|
||||
"be.ems/src/framework/utils/crypto"
|
||||
"be.ems/src/framework/utils/parse"
|
||||
@@ -98,11 +99,11 @@ func Launch() {
|
||||
// 检查文件是否存在
|
||||
if _, err := os.Stat(filePath()); err != nil {
|
||||
LaunchInfo = map[string]any{
|
||||
"code": Code, // 机器码
|
||||
"firstTime": time.Now().UnixMilli(), // 首次启动使用时间
|
||||
"code": Code, // 机器码
|
||||
"useTime": time.Now().UnixMilli(), // 首次使用时间
|
||||
|
||||
"sysGuide": true, // 首次引导
|
||||
"sysGuideTime": 0, // 引导完成时间
|
||||
common.LAUNCH_BOOTLOADER: true, // 启动引导
|
||||
common.LAUNCH_BOOTLOADER + "Time": 0, // 引导完成时间
|
||||
}
|
||||
codeFileWrite(LaunchInfo)
|
||||
} else {
|
||||
@@ -125,7 +126,7 @@ func SetLaunchInfo(info map[string]any) error {
|
||||
}
|
||||
|
||||
// 固定值禁止变更
|
||||
constKeys := []string{"code", "firstTime"}
|
||||
constKeys := []string{"code", "useTime"}
|
||||
for k, v := range info {
|
||||
constKey := false
|
||||
for _, ck := range constKeys {
|
||||
|
||||
@@ -25,11 +25,12 @@ func Setup(router *gin.Engine) {
|
||||
|
||||
// 系统可暴露的配置信息
|
||||
indexGroup.GET("/sys-conf", controller.NewCommont.SysConfig)
|
||||
// 首次引导安装
|
||||
guideGroup := router.Group("/guide")
|
||||
// 系统引导初始化
|
||||
guideGroup := router.Group("/bootloader")
|
||||
{
|
||||
guideGroup.POST("", controller.NewLaunch.GuideStart)
|
||||
guideGroup.PUT("", middleware.PreAuthorize(nil), controller.NewLaunch.GuideDone)
|
||||
guideGroup.POST("", controller.NewBootloader.BootloaderStart)
|
||||
guideGroup.PUT("", middleware.PreAuthorize(nil), controller.NewBootloader.BootloaderDone)
|
||||
guideGroup.DELETE("", middleware.PreAuthorize(nil), controller.NewBootloader.BootloaderReset)
|
||||
}
|
||||
|
||||
// 验证码操作处理
|
||||
|
||||
@@ -1,10 +1,13 @@
|
||||
package controller
|
||||
|
||||
import (
|
||||
"runtime"
|
||||
"time"
|
||||
|
||||
adminConstants "be.ems/src/framework/constants/admin"
|
||||
"be.ems/src/framework/constants/common"
|
||||
tokenConstants "be.ems/src/framework/constants/token"
|
||||
"be.ems/src/framework/utils/cmd"
|
||||
"be.ems/src/framework/utils/ctx"
|
||||
"be.ems/src/framework/utils/machine"
|
||||
tokenUtils "be.ems/src/framework/utils/token"
|
||||
@@ -15,34 +18,34 @@ import (
|
||||
"github.com/gin-gonic/gin"
|
||||
)
|
||||
|
||||
// 实例化控制层 LaunchController 结构体
|
||||
var NewLaunch = &LaunchController{
|
||||
// 实例化控制层 BootloaderController 结构体
|
||||
var NewBootloader = &BootloaderController{
|
||||
accountService: commonService.NewAccountImpl,
|
||||
sysUserService: systemService.NewSysUserImpl,
|
||||
}
|
||||
|
||||
// 首次启动安装
|
||||
// 系统引导初始化
|
||||
//
|
||||
// PATH /launch
|
||||
type LaunchController struct {
|
||||
// PATH /bootloader
|
||||
type BootloaderController struct {
|
||||
// 账号身份操作服务
|
||||
accountService commonService.IAccount
|
||||
// 用户信息服务
|
||||
sysUserService systemService.ISysUser
|
||||
}
|
||||
|
||||
// 首次引导安装开始
|
||||
// 首次引导开始
|
||||
//
|
||||
// POST /guide
|
||||
func (s *LaunchController) GuideStart(c *gin.Context) {
|
||||
// POST /
|
||||
func (s *BootloaderController) BootloaderStart(c *gin.Context) {
|
||||
// 是否完成引导
|
||||
launchInfo := machine.LaunchInfo
|
||||
if launchInfo == nil {
|
||||
c.JSON(200, result.Err(nil))
|
||||
return
|
||||
}
|
||||
if v, ok := launchInfo["sysGuide"]; ok && !v.(bool) {
|
||||
c.JSON(200, result.ErrMsg("guide done"))
|
||||
if v, ok := launchInfo[common.LAUNCH_BOOTLOADER]; ok && !v.(bool) {
|
||||
c.JSON(200, result.ErrMsg("bootloader done"))
|
||||
return
|
||||
}
|
||||
|
||||
@@ -79,25 +82,67 @@ func (s *LaunchController) GuideStart(c *gin.Context) {
|
||||
}))
|
||||
}
|
||||
|
||||
// 首次引导安装完成
|
||||
// 首次引导完成
|
||||
//
|
||||
// PUT /guide
|
||||
func (s *LaunchController) GuideDone(c *gin.Context) {
|
||||
// PUT /
|
||||
func (s *BootloaderController) BootloaderDone(c *gin.Context) {
|
||||
// 是否完成引导
|
||||
launchInfo := machine.LaunchInfo
|
||||
if launchInfo == nil {
|
||||
c.JSON(200, result.Err(nil))
|
||||
return
|
||||
}
|
||||
if v, ok := launchInfo["sysGuide"]; ok && !v.(bool) {
|
||||
c.JSON(200, result.ErrMsg("guide done"))
|
||||
if v, ok := launchInfo[common.LAUNCH_BOOTLOADER]; ok && !v.(bool) {
|
||||
c.JSON(200, result.ErrMsg("bootloader done"))
|
||||
return
|
||||
}
|
||||
|
||||
// 记录完成时间
|
||||
err := machine.SetLaunchInfo(map[string]any{
|
||||
"sysGuide": false, // 首次引导
|
||||
"sysGuideTime": time.Now().UnixMilli(), // 引导完成时间
|
||||
common.LAUNCH_BOOTLOADER: false, // 启动引导
|
||||
common.LAUNCH_BOOTLOADER + "Time": time.Now().UnixMilli(), // 引导完成时间
|
||||
})
|
||||
if err != nil {
|
||||
c.JSON(200, result.ErrMsg(err.Error()))
|
||||
return
|
||||
}
|
||||
|
||||
// 清除授权信息
|
||||
tokenUtils.Remove(ctx.Authorization(c))
|
||||
c.JSON(200, result.Ok(nil))
|
||||
}
|
||||
|
||||
// 引导系统数据重置
|
||||
//
|
||||
// DELETE /
|
||||
func (s *BootloaderController) BootloaderReset(c *gin.Context) {
|
||||
// 是否完成引导
|
||||
launchInfo := machine.LaunchInfo
|
||||
if launchInfo == nil {
|
||||
c.JSON(200, result.Err(nil))
|
||||
return
|
||||
}
|
||||
if v, ok := launchInfo[common.LAUNCH_BOOTLOADER]; ok && v.(bool) {
|
||||
c.JSON(200, result.ErrMsg("bootloader not done"))
|
||||
return
|
||||
}
|
||||
|
||||
// 重置数据库
|
||||
if runtime.GOOS == "windows" {
|
||||
c.JSON(200, result.ErrMsg("Does not support window operations"))
|
||||
return
|
||||
} else {
|
||||
_, err := cmd.ExecWithCheck("sudo", "/usr/local/omc/bin/setomc.sh", "-m", "install")
|
||||
if err != nil {
|
||||
c.JSON(200, result.ErrMsg(err.Error()))
|
||||
return
|
||||
}
|
||||
}
|
||||
|
||||
// 重置引导标记
|
||||
err := machine.SetLaunchInfo(map[string]any{
|
||||
"bootloader": true, // 启动引导
|
||||
"bootloaderTime": 0, // 引导完成时间
|
||||
})
|
||||
if err != nil {
|
||||
c.JSON(200, result.ErrMsg(err.Error()))
|
||||
@@ -5,6 +5,7 @@ import (
|
||||
|
||||
"be.ems/lib/global"
|
||||
"be.ems/src/framework/config"
|
||||
"be.ems/src/framework/constants/common"
|
||||
"be.ems/src/framework/utils/machine"
|
||||
systemService "be.ems/src/modules/system/service"
|
||||
)
|
||||
@@ -33,13 +34,13 @@ func (s *CommontImpl) SystemConfigInfo() map[string]string {
|
||||
// 系统首次使用标记
|
||||
launchInfo := machine.LaunchInfo
|
||||
if launchInfo != nil {
|
||||
if v, ok := launchInfo["sysGuide"]; ok {
|
||||
infoMap["sysGuide"] = fmt.Sprint(v)
|
||||
if v, ok := launchInfo[common.LAUNCH_BOOTLOADER]; ok {
|
||||
infoMap[common.LAUNCH_BOOTLOADER] = fmt.Sprint(v)
|
||||
} else {
|
||||
infoMap["sysGuide"] = "true"
|
||||
infoMap[common.LAUNCH_BOOTLOADER] = "true"
|
||||
}
|
||||
} else {
|
||||
infoMap["sysGuide"] = "true"
|
||||
infoMap[common.LAUNCH_BOOTLOADER] = "true"
|
||||
}
|
||||
// 序列号
|
||||
infoMap["serialNum"] = fmt.Sprint(config.Get("omc.sn"))
|
||||
|
||||
Reference in New Issue
Block a user