nps/lib/file/obj.go

129 lines
2.7 KiB
Go
Raw Normal View History

2019-02-09 01:07:47 -08:00
package file
import (
2019-02-09 01:07:47 -08:00
"github.com/cnlh/nps/lib/rate"
2019-02-02 08:54:43 -08:00
"strings"
"sync"
)
type Flow struct {
ExportFlow int64 //出口流量
InletFlow int64 //入口流量
FlowLimit int64 //流量限制,出口+入口 /M
sync.RWMutex
}
func (s *Flow) Add(in, out int) {
s.Lock()
defer s.Unlock()
s.InletFlow += int64(in)
s.ExportFlow += int64(out)
}
type Client struct {
Cnf *Config
2019-02-09 01:07:47 -08:00
Id int //id
VerifyKey string //验证密钥
Addr string //客户端ip地址
Remark string //备注
Status bool //是否开启
IsConnect bool //是否连接
RateLimit int //速度限制 /kb
Flow *Flow //流量
Rate *rate.Rate //速度控制
2019-02-12 11:54:00 -08:00
NoStore bool
NoDisplay bool
id int
sync.RWMutex
}
2019-02-12 11:54:00 -08:00
func NewClient(vKey string, noStore bool, noDisplay bool) *Client {
return &Client{
Cnf: new(Config),
Id: 0,
VerifyKey: vKey,
Addr: "",
Remark: "",
Status: true,
IsConnect: false,
RateLimit: 0,
Flow: new(Flow),
Rate: nil,
NoStore: noStore,
id: GetCsvDb().GetClientId(),
RWMutex: sync.RWMutex{},
NoDisplay: noDisplay,
}
}
func (s *Client) GetId() int {
s.Lock()
defer s.Unlock()
s.id++
return s.id
}
type Tunnel struct {
2019-02-12 11:54:00 -08:00
Id int //Id
2019-02-15 06:59:28 -08:00
Port int //服务端监听端口
2019-02-12 11:54:00 -08:00
Mode string //启动方式
Target string //目标
Status bool //设置是否开启
RunStatus bool //当前运行状态
Client *Client //所属客户端id
2019-02-15 06:59:28 -08:00
Ports string //客户端与服务端传递
2019-02-12 11:54:00 -08:00
Flow *Flow
Remark string //备注
NoStore bool
}
type Config struct {
U string //socks5验证用户名
P string //socks5验证密码
Compress string //压缩方式
Crypt bool //是否加密
CompressEncode int //加密方式
CompressDecode int //解密方式
}
type Host struct {
2019-02-15 06:59:28 -08:00
Id int
Host string //启动方式
Target string //目标
HeaderChange string //host修改
HostChange string //host修改
2019-02-15 06:59:28 -08:00
Location string //url 路由
Flow *Flow
Client *Client
Remark string //备注
2019-02-02 08:54:43 -08:00
NowIndex int
TargetArr []string
2019-02-12 11:54:00 -08:00
NoStore bool
2019-02-02 08:54:43 -08:00
sync.RWMutex
}
func (s *Host) GetRandomTarget() string {
if s.TargetArr == nil {
s.TargetArr = strings.Split(s.Target, "\n")
}
s.Lock()
defer s.Unlock()
if s.NowIndex >= len(s.TargetArr)-1 {
s.NowIndex = 0
} else {
s.NowIndex++
}
return s.TargetArr[s.NowIndex]
}
//深拷贝Config
func DeepCopyConfig(c *Config) *Config {
return &Config{
U: c.U,
P: c.P,
Compress: c.Compress,
Crypt: c.Crypt,
CompressEncode: c.CompressEncode,
CompressDecode: c.CompressDecode,
}
}