obj.go 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. package file
  2. import (
  3. "github.com/cnlh/nps/lib/rate"
  4. "math"
  5. "strings"
  6. "sync"
  7. )
  8. type Flow struct {
  9. ExportFlow int64 //出口流量
  10. InletFlow int64 //入口流量
  11. FlowLimit int64 //流量限制,出口+入口 /M
  12. sync.RWMutex
  13. }
  14. func (s *Flow) Add(in, out int) {
  15. s.Lock()
  16. defer s.Unlock()
  17. s.InletFlow += int64(in)
  18. s.ExportFlow += int64(out)
  19. }
  20. type Client struct {
  21. Cnf *Config
  22. Id int //id
  23. VerifyKey string //验证密钥
  24. Addr string //客户端ip地址
  25. Remark string //备注
  26. Status bool //是否开启
  27. IsConnect bool //是否连接
  28. RateLimit int //速度限制 /kb
  29. Flow *Flow //流量
  30. Rate *rate.Rate //速度控制
  31. NoStore bool
  32. NoDisplay bool
  33. MaxConn int //客户端最大连接数
  34. NowConn int //当前连接数
  35. id int
  36. sync.RWMutex
  37. }
  38. func NewClient(vKey string, noStore bool, noDisplay bool) *Client {
  39. return &Client{
  40. Cnf: new(Config),
  41. Id: 0,
  42. VerifyKey: vKey,
  43. Addr: "",
  44. Remark: "",
  45. Status: true,
  46. IsConnect: false,
  47. RateLimit: 0,
  48. Flow: new(Flow),
  49. Rate: nil,
  50. NoStore: noStore,
  51. id: GetCsvDb().GetClientId(),
  52. RWMutex: sync.RWMutex{},
  53. NoDisplay: noDisplay,
  54. }
  55. }
  56. func (s *Client) GetId() int {
  57. s.Lock()
  58. defer s.Unlock()
  59. if s.id == math.MaxInt32 {
  60. s.id = 0
  61. }
  62. s.id++
  63. return s.id
  64. }
  65. func (s *Client) CutConn() {
  66. s.Lock()
  67. defer s.Unlock()
  68. s.NowConn++
  69. }
  70. func (s *Client) AddConn() {
  71. s.Lock()
  72. defer s.Unlock()
  73. s.NowConn--
  74. }
  75. func (s *Client) GetConn() bool {
  76. s.CutConn()
  77. if s.MaxConn == 0 || s.NowConn < s.MaxConn {
  78. return true
  79. }
  80. return false
  81. }
  82. type Tunnel struct {
  83. Id int //Id
  84. Port int //服务端监听端口
  85. Mode string //启动方式
  86. Target string //目标
  87. Status bool //设置是否开启
  88. RunStatus bool //当前运行状态
  89. Client *Client //所属客户端id
  90. Ports string //客户端与服务端传递
  91. Flow *Flow
  92. Password string //私密模式密码,唯一
  93. Remark string //备注
  94. TargetAddr string
  95. NoStore bool
  96. }
  97. type Config struct {
  98. U string //socks5验证用户名
  99. P string //socks5验证密码
  100. Compress string //压缩方式
  101. Crypt bool //是否加密
  102. CompressEncode int //加密方式
  103. CompressDecode int //解密方式
  104. }
  105. type Host struct {
  106. Id int
  107. Host string //启动方式
  108. Target string //目标
  109. HeaderChange string //host修改
  110. HostChange string //host修改
  111. Location string //url 路由
  112. Flow *Flow
  113. Client *Client
  114. Remark string //备注
  115. NowIndex int
  116. TargetArr []string
  117. NoStore bool
  118. sync.RWMutex
  119. }
  120. func (s *Host) GetRandomTarget() string {
  121. if s.TargetArr == nil {
  122. s.TargetArr = strings.Split(s.Target, "\n")
  123. }
  124. s.Lock()
  125. defer s.Unlock()
  126. if s.NowIndex >= len(s.TargetArr)-1 {
  127. s.NowIndex = 0
  128. } else {
  129. s.NowIndex++
  130. }
  131. return s.TargetArr[s.NowIndex]
  132. }