cert.go 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. package api
  2. import (
  3. "github.com/0xJacky/Nginx-UI/server/tool"
  4. "github.com/0xJacky/Nginx-UI/server/tool/nginx"
  5. "github.com/gin-gonic/gin"
  6. "github.com/gorilla/websocket"
  7. "log"
  8. "net/http"
  9. "os"
  10. )
  11. func CertInfo(c *gin.Context) {
  12. domain := c.Param("domain")
  13. key, err := tool.GetCertInfo(domain)
  14. if err != nil {
  15. c.JSON(http.StatusOK, gin.H{
  16. "error": err,
  17. })
  18. return
  19. }
  20. c.JSON(http.StatusOK, gin.H{
  21. "subject_name": key.Subject.CommonName,
  22. "issuer_name": key.Issuer.CommonName,
  23. "not_after": key.NotAfter,
  24. "not_before": key.NotBefore,
  25. })
  26. }
  27. func IssueCert(c *gin.Context) {
  28. domain := c.Param("domain")
  29. var upGrader = websocket.Upgrader{
  30. CheckOrigin: func(r *http.Request) bool {
  31. return true
  32. },
  33. }
  34. // upgrade http to websocket
  35. ws, err := upGrader.Upgrade(c.Writer, c.Request, nil)
  36. if err != nil {
  37. log.Println(err)
  38. return
  39. }
  40. defer func(ws *websocket.Conn) {
  41. err := ws.Close()
  42. if err != nil {
  43. log.Println("defer websocket close err", err)
  44. }
  45. }(ws)
  46. // read
  47. mt, message, err := ws.ReadMessage()
  48. if err != nil {
  49. log.Println(err)
  50. return
  51. }
  52. if mt == websocket.TextMessage && string(message) == "go" {
  53. err = tool.IssueCert(domain)
  54. if err != nil {
  55. log.Println(err)
  56. err = ws.WriteJSON(gin.H{
  57. "status": "error",
  58. "message": err.Error(),
  59. })
  60. if err != nil {
  61. log.Println(err)
  62. return
  63. }
  64. return
  65. }
  66. sslCertificatePath := nginx.GetNginxConfPath("ssl/" + domain + "/fullchain.cer")
  67. _, err = os.Stat(sslCertificatePath)
  68. if err != nil {
  69. log.Println(err)
  70. return
  71. }
  72. log.Println("[found]", "fullchain.cer")
  73. err = ws.WriteJSON(gin.H{
  74. "status": "success",
  75. "message": "[found] fullchain.cer",
  76. })
  77. if err != nil {
  78. log.Println(err)
  79. return
  80. }
  81. sslCertificateKeyPath := nginx.GetNginxConfPath("ssl/" + domain + "/" + domain + ".key")
  82. _, err = os.Stat(sslCertificateKeyPath)
  83. if err != nil {
  84. log.Println(err)
  85. return
  86. }
  87. log.Println("[found]", "cert key")
  88. err = ws.WriteJSON(gin.H{
  89. "status": "success",
  90. "message": "[found] Certificate Key",
  91. })
  92. if err != nil {
  93. log.Println(err)
  94. return
  95. }
  96. err = ws.WriteJSON(gin.H{
  97. "status": "success",
  98. "message": "Issued certificate successfully",
  99. "ssl_certificate": sslCertificatePath,
  100. "ssl_certificate_key": sslCertificateKeyPath,
  101. })
  102. if err != nil {
  103. log.Println(err)
  104. return
  105. }
  106. }
  107. }