obj.go 2.9 KB

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