1
0

rpc.go 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  1. package api
  2. import (
  3. "os"
  4. "time"
  5. "github.com/Sirupsen/logrus"
  6. "github.com/cad/ovpm"
  7. "github.com/cad/ovpm/pb"
  8. "golang.org/x/net/context"
  9. )
  10. type UserService struct{}
  11. func (s *UserService) List(ctx context.Context, req *pb.UserListRequest) (*pb.UserResponse, error) {
  12. logrus.Debug("rpc call: user list")
  13. var ut []*pb.UserResponse_User
  14. users, err := ovpm.GetAllUsers()
  15. if err != nil {
  16. logrus.Errorf("users can not be fetched: %v", err)
  17. os.Exit(1)
  18. return nil, err
  19. }
  20. for _, user := range users {
  21. ut = append(ut, &pb.UserResponse_User{
  22. ServerSerialNumber: user.GetServerSerialNumber(),
  23. Username: user.GetUsername(),
  24. CreatedAt: user.GetCreatedAt(),
  25. IPNet: user.GetIPNet(),
  26. NoGW: user.IsNoGW(),
  27. HostID: user.GetHostID(),
  28. })
  29. }
  30. return &pb.UserResponse{Users: ut}, nil
  31. }
  32. func (s *UserService) Create(ctx context.Context, req *pb.UserCreateRequest) (*pb.UserResponse, error) {
  33. logrus.Debugf("rpc call: user create: %s", req.Username)
  34. var ut []*pb.UserResponse_User
  35. user, err := ovpm.CreateNewUser(req.Username, req.Password, req.NoGW, req.HostID)
  36. if err != nil {
  37. return nil, err
  38. }
  39. pbUser := pb.UserResponse_User{
  40. Username: user.GetUsername(),
  41. ServerSerialNumber: user.GetServerSerialNumber(),
  42. NoGW: user.IsNoGW(),
  43. HostID: user.GetHostID(),
  44. }
  45. ut = append(ut, &pbUser)
  46. return &pb.UserResponse{Users: ut}, nil
  47. }
  48. func (s *UserService) Update(ctx context.Context, req *pb.UserUpdateRequest) (*pb.UserResponse, error) {
  49. logrus.Debugf("rpc call: user update: %s", req.Username)
  50. var ut []*pb.UserResponse_User
  51. user, err := ovpm.GetUser(req.Username)
  52. if err != nil {
  53. return nil, err
  54. }
  55. var noGW bool
  56. switch req.Gwpref {
  57. case pb.UserUpdateRequest_NOGW:
  58. noGW = false
  59. case pb.UserUpdateRequest_GW:
  60. noGW = true
  61. default:
  62. noGW = user.NoGW
  63. }
  64. user.Update(req.Password, noGW, req.HostID)
  65. pbUser := pb.UserResponse_User{
  66. Username: user.GetUsername(),
  67. ServerSerialNumber: user.GetServerSerialNumber(),
  68. NoGW: user.IsNoGW(),
  69. HostID: user.GetHostID(),
  70. }
  71. ut = append(ut, &pbUser)
  72. return &pb.UserResponse{Users: ut}, nil
  73. }
  74. func (s *UserService) Delete(ctx context.Context, req *pb.UserDeleteRequest) (*pb.UserResponse, error) {
  75. logrus.Debugf("rpc call: user delete: %s", req.Username)
  76. var ut []*pb.UserResponse_User
  77. user, err := ovpm.GetUser(req.Username)
  78. if err != nil {
  79. return nil, err
  80. }
  81. pbUser := pb.UserResponse_User{
  82. Username: user.GetUsername(),
  83. ServerSerialNumber: user.GetServerSerialNumber(),
  84. HostID: user.GetHostID(),
  85. }
  86. ut = append(ut, &pbUser)
  87. err = user.Delete()
  88. if err != nil {
  89. return nil, err
  90. }
  91. return &pb.UserResponse{Users: ut}, nil
  92. }
  93. func (s *UserService) Renew(ctx context.Context, req *pb.UserRenewRequest) (*pb.UserResponse, error) {
  94. logrus.Debugf("rpc call: user renew cert: %s", req.Username)
  95. var ut []*pb.UserResponse_User
  96. user, err := ovpm.GetUser(req.Username)
  97. if err != nil {
  98. return nil, err
  99. }
  100. pbUser := pb.UserResponse_User{
  101. Username: user.GetUsername(),
  102. ServerSerialNumber: user.GetServerSerialNumber(),
  103. HostID: user.GetHostID(),
  104. }
  105. ut = append(ut, &pbUser)
  106. err = user.Renew()
  107. if err != nil {
  108. return nil, err
  109. }
  110. return &pb.UserResponse{Users: ut}, nil
  111. }
  112. func (s *UserService) GenConfig(ctx context.Context, req *pb.UserGenConfigRequest) (*pb.UserGenConfigResponse, error) {
  113. logrus.Debugf("rpc call: user genconfig: %s", req.Username)
  114. user, err := ovpm.GetUser(req.Username)
  115. if err != nil {
  116. return nil, err
  117. }
  118. configBlob, err := ovpm.DumpsClientConfig(user.GetUsername())
  119. if err != nil {
  120. return nil, err
  121. }
  122. return &pb.UserGenConfigResponse{ClientConfig: configBlob}, nil
  123. }
  124. type VPNService struct{}
  125. func (s *VPNService) Status(ctx context.Context, req *pb.VPNStatusRequest) (*pb.VPNStatusResponse, error) {
  126. logrus.Debugf("rpc call: vpn status")
  127. server, err := ovpm.GetServerInstance()
  128. if err != nil {
  129. return nil, err
  130. }
  131. response := pb.VPNStatusResponse{
  132. Name: server.Name,
  133. SerialNumber: server.SerialNumber,
  134. Hostname: server.Hostname,
  135. Port: server.Port,
  136. Cert: server.Cert,
  137. CACert: server.CACert,
  138. Net: server.Net,
  139. Mask: server.Mask,
  140. CreatedAt: server.CreatedAt.Format(time.UnixDate),
  141. }
  142. return &response, nil
  143. }
  144. func (s *VPNService) Init(ctx context.Context, req *pb.VPNInitRequest) (*pb.VPNInitResponse, error) {
  145. logrus.Debugf("rpc call: vpn init")
  146. if err := ovpm.Init(req.Hostname, req.Port); err != nil {
  147. logrus.Errorf("server can not be created: %v", err)
  148. }
  149. return &pb.VPNInitResponse{}, nil
  150. }