server.go 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. package server
  2. import (
  3. "be-vpn/internal/dto"
  4. "be-vpn/internal/model"
  5. "be-vpn/internal/util"
  6. "github.com/gin-gonic/gin"
  7. "log"
  8. "net/http"
  9. "sync"
  10. "time"
  11. )
  12. var nodes = make([]*model.Node, 0)
  13. var locker = sync.RWMutex{}
  14. func Register(c *gin.Context) {
  15. locker.Lock()
  16. defer locker.Unlock()
  17. var request dto.RegisterRequest
  18. if err := c.ShouldBindJSON(&request); err != nil {
  19. dto.BadRequest(c, err)
  20. return
  21. }
  22. for _, node := range nodes {
  23. if node.Ip == request.Ip {
  24. node.Ip = request.Ip
  25. node.Secret = request.Secret
  26. node.CountryCode = request.CountryCode
  27. node.LastUpdateTime = time.Now()
  28. c.JSON(http.StatusOK, dto.RegisterResponse{
  29. Response: dto.NewOkResponse(),
  30. Data: dto.RegisterResult{
  31. Success: true,
  32. },
  33. })
  34. return
  35. }
  36. }
  37. node := &model.Node{
  38. Ip: request.Ip,
  39. Secret: request.Secret,
  40. LastUpdateTime: time.Now(),
  41. }
  42. nodes = append(nodes, node)
  43. log.Printf("update nodes: %+v", nodes)
  44. }
  45. func List(c *gin.Context) {
  46. locker.RLock()
  47. defer locker.RUnlock()
  48. dtoNodes := make(map[string][]dto.Node)
  49. for _, node := range nodes {
  50. if _, ok := dtoNodes[node.CountryCode]; !ok {
  51. dtoNodes[node.CountryCode] = make([]dto.Node, 0)
  52. }
  53. if node.LastUpdateTime.Add(10 * time.Second).After(time.Now()) {
  54. dtoNodes[node.CountryCode] = append(dtoNodes[node.CountryCode], dto.Node{
  55. Ip: node.Ip,
  56. })
  57. }
  58. }
  59. listResult := make([]dto.ListResult, len(dtoNodes))
  60. i := 0
  61. for countryCode, itemNodes := range dtoNodes {
  62. listResult[i] = dto.ListResult{
  63. CountryCode: countryCode,
  64. Nodes: itemNodes,
  65. }
  66. i++
  67. }
  68. c.JSON(http.StatusOK, dto.ListResponse{
  69. Response: dto.NewOkResponse(),
  70. Data: listResult,
  71. })
  72. }
  73. func Secret(c *gin.Context) {
  74. locker.RLock()
  75. defer locker.RUnlock()
  76. var request dto.DetailRequest
  77. if err := c.ShouldBindQuery(&request); err != nil {
  78. dto.BadRequest(c, err)
  79. return
  80. }
  81. for _, node := range nodes {
  82. if node.Ip == request.Ip {
  83. secret, err := util.RsaEncrypt([]byte(node.Secret))
  84. if err != nil {
  85. dto.Error(c, err)
  86. return
  87. }
  88. c.Data(http.StatusOK, "application/octet-stream", secret)
  89. return
  90. }
  91. }
  92. c.JSON(http.StatusNotFound, gin.H{
  93. "message": "not found ip",
  94. })
  95. }
  96. func Health(c *gin.Context) {
  97. c.JSON(http.StatusOK, gin.H{"status": "up"})
  98. }