cert.go 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. package api
  2. import (
  3. "crypto/tls"
  4. "encoding/json"
  5. "github.com/0xJacky/Nginx-UI/server/tool"
  6. "github.com/gin-gonic/gin"
  7. "github.com/gorilla/websocket"
  8. "io"
  9. "log"
  10. "net/http"
  11. "os"
  12. )
  13. func CertInfo(c *gin.Context) {
  14. domain := c.Param("domain")
  15. /*sslCertificatePath := tool.GetNginxConfPath("ssl/" + domain +"/fullchain.cer")
  16. content, err := ioutil.ReadFile(sslCertificatePath)
  17. if err != nil {
  18. ErrorHandler(c, err)
  19. return
  20. }
  21. certDERBlock, _ := pem.Decode(content)
  22. if certDERBlock == nil {
  23. ErrorHandler(c, errors.New("pem decode error"))
  24. return
  25. }
  26. var key *x509.Certificate
  27. key, err = x509.ParseCertificate(certDERBlock.Bytes)
  28. if err != nil {
  29. ErrorHandler(c, err)
  30. return
  31. }*/
  32. ts := &http.Transport{
  33. TLSClientConfig: &tls.Config{InsecureSkipVerify: true},
  34. }
  35. client := &http.Client{Transport: ts}
  36. response, err := client.Get("https://" + domain)
  37. if err != nil {
  38. ErrorHandler(c, err)
  39. return
  40. }
  41. defer func(Body io.ReadCloser) {
  42. err = Body.Close()
  43. if err != nil {
  44. ErrorHandler(c, err)
  45. return
  46. }
  47. }(response.Body)
  48. key := response.TLS.PeerCertificates[0]
  49. c.JSON(http.StatusOK, gin.H{
  50. "subject_name": key.Subject.CommonName,
  51. "issuer_name": key.Issuer.CommonName,
  52. "not_after": key.NotAfter,
  53. "not_before": key.NotBefore,
  54. })
  55. }
  56. func IssueCert(c *gin.Context) {
  57. domain := c.Param("domain")
  58. var upGrader = websocket.Upgrader{
  59. CheckOrigin: func(r *http.Request) bool {
  60. return true
  61. },
  62. }
  63. // upgrade http to websocket
  64. ws, err := upGrader.Upgrade(c.Writer, c.Request, nil)
  65. if err != nil {
  66. return
  67. }
  68. defer ws.Close()
  69. for {
  70. // read
  71. mt, message, err := ws.ReadMessage()
  72. if err != nil {
  73. break
  74. }
  75. if string(message) == "go" {
  76. var m []byte
  77. err = tool.IssueCert(domain)
  78. if err != nil {
  79. m, err = json.Marshal(gin.H{
  80. "status": "error",
  81. "message": err.Error(),
  82. })
  83. if err != nil {
  84. log.Println(err)
  85. return
  86. }
  87. err = ws.WriteMessage(mt, m)
  88. if err != nil {
  89. log.Println(err)
  90. return
  91. }
  92. log.Println(err)
  93. return
  94. }
  95. sslCertificatePath := tool.GetNginxConfPath("ssl/" + domain + "/fullchain.cer")
  96. _, err = os.Stat(sslCertificatePath)
  97. if err != nil {
  98. log.Println(err)
  99. return
  100. }
  101. log.Println("[found]", "fullchain.cer")
  102. m, err = json.Marshal(gin.H{
  103. "status": "success",
  104. "message": "[found] fullchain.cer",
  105. })
  106. if err != nil {
  107. log.Println(err)
  108. return
  109. }
  110. err = ws.WriteMessage(mt, m)
  111. if err != nil {
  112. log.Println(err)
  113. return
  114. }
  115. sslCertificateKeyPath := tool.GetNginxConfPath("ssl/" + domain + "/" + domain + ".key")
  116. _, err = os.Stat(sslCertificateKeyPath)
  117. if err != nil {
  118. log.Println(err)
  119. return
  120. }
  121. log.Println("[found]", "cert key")
  122. m, err = json.Marshal(gin.H{
  123. "status": "success",
  124. "message": "[found] cert key",
  125. })
  126. if err != nil {
  127. log.Println(err)
  128. }
  129. err = ws.WriteMessage(mt, m)
  130. if err != nil {
  131. log.Println(err)
  132. }
  133. log.Println("申请成功")
  134. m, err = json.Marshal(gin.H{
  135. "status": "success",
  136. "message": "申请成功",
  137. "ssl_certificate": sslCertificatePath,
  138. "ssl_certificate_key": sslCertificateKeyPath,
  139. })
  140. if err != nil {
  141. log.Println(err)
  142. }
  143. err = ws.WriteMessage(mt, m)
  144. if err != nil {
  145. log.Println(err)
  146. }
  147. }
  148. }
  149. }