install.go 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. package api
  2. import (
  3. model2 "github.com/0xJacky/Nginx-UI/server/model"
  4. "github.com/0xJacky/Nginx-UI/server/settings"
  5. "github.com/gin-gonic/gin"
  6. "github.com/google/uuid"
  7. "golang.org/x/crypto/bcrypt"
  8. "net/http"
  9. "os"
  10. )
  11. func installLockStatus() bool {
  12. lockPath := settings.ConfPath
  13. _, err := os.Stat(lockPath)
  14. return !os.IsNotExist(err)
  15. }
  16. func InstallLockCheck(c *gin.Context) {
  17. c.JSON(http.StatusOK, gin.H{
  18. "lock": installLockStatus(),
  19. })
  20. }
  21. type InstallJson struct {
  22. Email string `json:"email" binding:"required,email"`
  23. Username string `json:"username" binding:"required,max=255"`
  24. Password string `json:"password" binding:"required,max=255"`
  25. }
  26. func InstallNginxUI(c *gin.Context) {
  27. // 安装过就别访问了
  28. if installLockStatus() {
  29. c.JSON(http.StatusForbidden, gin.H{
  30. "message": "installed",
  31. })
  32. return
  33. }
  34. var json InstallJson
  35. ok := BindAndValid(c, &json)
  36. if !ok {
  37. return
  38. }
  39. serverSettings := settings.Conf.Section("server")
  40. serverSettings.Key("JwtSecret").SetValue(uuid.New().String())
  41. serverSettings.Key("Email").SetValue(json.Email)
  42. err := settings.Save()
  43. if err != nil {
  44. ErrHandler(c, err)
  45. return
  46. }
  47. curd := model2.NewCurd(&model2.Auth{})
  48. pwd, _ := bcrypt.GenerateFromPassword([]byte(json.Password), bcrypt.DefaultCost)
  49. err = curd.Add(&model2.Auth{
  50. Name: json.Username,
  51. Password: string(pwd),
  52. })
  53. if err != nil {
  54. ErrHandler(c, err)
  55. return
  56. }
  57. c.JSON(http.StatusOK, gin.H{
  58. "message": "ok",
  59. })
  60. }