|
@@ -1,21 +1,17 @@
|
|
|
package api
|
|
|
|
|
|
import (
|
|
|
- model2 "github.com/0xJacky/Nginx-UI/server/model"
|
|
|
+ "github.com/0xJacky/Nginx-UI/server/model"
|
|
|
"github.com/0xJacky/Nginx-UI/server/settings"
|
|
|
+ "github.com/0xJacky/Nginx-UI/server/tool"
|
|
|
"github.com/gin-gonic/gin"
|
|
|
"github.com/google/uuid"
|
|
|
"golang.org/x/crypto/bcrypt"
|
|
|
"net/http"
|
|
|
- "os"
|
|
|
)
|
|
|
|
|
|
func installLockStatus() bool {
|
|
|
- lockPath := settings.ConfPath
|
|
|
- _, err := os.Stat(lockPath)
|
|
|
-
|
|
|
- return !os.IsNotExist(err)
|
|
|
-
|
|
|
+ return "" != settings.ServerSettings.JwtSecret
|
|
|
}
|
|
|
|
|
|
func InstallLockCheck(c *gin.Context) {
|
|
@@ -28,6 +24,7 @@ type InstallJson struct {
|
|
|
Email string `json:"email" binding:"required,email"`
|
|
|
Username string `json:"username" binding:"required,max=255"`
|
|
|
Password string `json:"password" binding:"required,max=255"`
|
|
|
+ Database string `json:"database"`
|
|
|
}
|
|
|
|
|
|
func InstallNginxUI(c *gin.Context) {
|
|
@@ -44,18 +41,26 @@ func InstallNginxUI(c *gin.Context) {
|
|
|
return
|
|
|
}
|
|
|
|
|
|
- serverSettings := settings.Conf.Section("server")
|
|
|
- serverSettings.Key("JwtSecret").SetValue(uuid.New().String())
|
|
|
- serverSettings.Key("Email").SetValue(json.Email)
|
|
|
+ settings.ServerSettings.JwtSecret = uuid.New().String()
|
|
|
+ settings.ServerSettings.Email = json.Email
|
|
|
+ if "" != json.Database {
|
|
|
+ settings.ServerSettings.Database = json.Database
|
|
|
+ }
|
|
|
+ settings.ReflectFrom()
|
|
|
+
|
|
|
err := settings.Save()
|
|
|
if err != nil {
|
|
|
ErrHandler(c, err)
|
|
|
return
|
|
|
}
|
|
|
|
|
|
- curd := model2.NewCurd(&model2.Auth{})
|
|
|
+ // Init model and auto cert
|
|
|
+ model.Init()
|
|
|
+ go tool.AutoCert()
|
|
|
+
|
|
|
+ curd := model.NewCurd(&model.Auth{})
|
|
|
pwd, _ := bcrypt.GenerateFromPassword([]byte(json.Password), bcrypt.DefaultCost)
|
|
|
- err = curd.Add(&model2.Auth{
|
|
|
+ err = curd.Add(&model.Auth{
|
|
|
Name: json.Username,
|
|
|
Password: string(pwd),
|
|
|
})
|