common.go 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. package scenarios
  2. import (
  3. "net"
  4. "time"
  5. "github.com/golang/protobuf/proto"
  6. "v2ray.com/core"
  7. "v2ray.com/core/common"
  8. v2net "v2ray.com/core/common/net"
  9. )
  10. func pickPort() v2net.Port {
  11. listener, err := net.Listen("tcp4", ":0")
  12. common.Must(err)
  13. defer listener.Close()
  14. addr := listener.Addr().(*net.TCPAddr)
  15. return v2net.Port(addr.Port)
  16. }
  17. func xor(b []byte) []byte {
  18. r := make([]byte, len(b))
  19. for i, v := range b {
  20. r[i] = v ^ 'c'
  21. }
  22. return r
  23. }
  24. func readFrom(conn net.Conn, timeout time.Duration, length int) []byte {
  25. b := make([]byte, 2048)
  26. totalBytes := 0
  27. deadline := time.Now().Add(timeout)
  28. conn.SetReadDeadline(deadline)
  29. for totalBytes < length {
  30. if time.Now().After(deadline) {
  31. break
  32. }
  33. n, err := conn.Read(b[totalBytes:])
  34. if err != nil {
  35. break
  36. }
  37. totalBytes += n
  38. }
  39. return b[:totalBytes]
  40. }
  41. func InitializeServerConfig(config *core.Config) error {
  42. err := BuildV2Ray()
  43. if err != nil {
  44. return err
  45. }
  46. configBytes, err := proto.Marshal(config)
  47. if err != nil {
  48. return err
  49. }
  50. proc := RunV2RayProtobuf(configBytes)
  51. err = proc.Start()
  52. if err != nil {
  53. return err
  54. }
  55. time.Sleep(time.Second)
  56. runningServers = append(runningServers, proc)
  57. return nil
  58. }