mirror of
https://github.com/ehang-io/nps.git
synced 2025-07-03 13:10:42 +00:00
Merge remote-tracking branch 'origin/dev' into dev
This commit is contained in:
commit
3fa7590400
32
build.sh
32
build.sh
@ -10,75 +10,75 @@ cp upx-3.95-amd64_linux/upx ./
|
|||||||
|
|
||||||
CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
||||||
|
|
||||||
tar -czvf linux_amd64_client.tar.gz npc conf/npc.conf
|
tar -czvf linux_amd64_client.tar.gz npc conf/npc.conf conf/multi_account.conf
|
||||||
|
|
||||||
CGO_ENABLED=0 GOOS=linux GOARCH=386 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
CGO_ENABLED=0 GOOS=linux GOARCH=386 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
||||||
|
|
||||||
tar -czvf linux_386_client.tar.gz npc conf/npc.conf
|
tar -czvf linux_386_client.tar.gz npc conf/npc.conf conf/multi_account.conf
|
||||||
|
|
||||||
CGO_ENABLED=0 GOOS=freebsd GOARCH=386 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
CGO_ENABLED=0 GOOS=freebsd GOARCH=386 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
||||||
|
|
||||||
tar -czvf freebsd_386_client.tar.gz npc conf/npc.conf
|
tar -czvf freebsd_386_client.tar.gz npc conf/npc.conf conf/multi_account.conf
|
||||||
|
|
||||||
CGO_ENABLED=0 GOOS=freebsd GOARCH=amd64 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
CGO_ENABLED=0 GOOS=freebsd GOARCH=amd64 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
||||||
|
|
||||||
tar -czvf freebsd_amd64_client.tar.gz npc conf/npc.conf
|
tar -czvf freebsd_amd64_client.tar.gz npc conf/npc.conf conf/multi_account.conf
|
||||||
|
|
||||||
CGO_ENABLED=0 GOOS=freebsd GOARCH=arm go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
CGO_ENABLED=0 GOOS=freebsd GOARCH=arm go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
||||||
|
|
||||||
tar -czvf freebsd_arm_client.tar.gz npc conf/npc.conf
|
tar -czvf freebsd_arm_client.tar.gz npc conf/npc.conf conf/multi_account.conf
|
||||||
|
|
||||||
CGO_ENABLED=0 GOOS=linux GOARCH=arm GOARM=7 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
CGO_ENABLED=0 GOOS=linux GOARCH=arm GOARM=7 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
||||||
|
|
||||||
tar -czvf linux_arm_v7_client.tar.gz npc conf/npc.conf
|
tar -czvf linux_arm_v7_client.tar.gz npc conf/npc.conf conf/multi_account.conf
|
||||||
|
|
||||||
CGO_ENABLED=0 GOOS=linux GOARCH=arm GOARM=6 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
CGO_ENABLED=0 GOOS=linux GOARCH=arm GOARM=6 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
||||||
|
|
||||||
tar -czvf linux_arm_v6_client.tar.gz npc conf/npc.conf
|
tar -czvf linux_arm_v6_client.tar.gz npc conf/npc.conf conf/multi_account.conf
|
||||||
|
|
||||||
CGO_ENABLED=0 GOOS=linux GOARCH=arm GOARM=5 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
CGO_ENABLED=0 GOOS=linux GOARCH=arm GOARM=5 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
||||||
|
|
||||||
tar -czvf linux_arm_v5_client.tar.gz npc conf/npc.conf
|
tar -czvf linux_arm_v5_client.tar.gz npc conf/npc.conf conf/multi_account.conf
|
||||||
|
|
||||||
|
|
||||||
CGO_ENABLED=0 GOOS=linux GOARCH=arm64 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
CGO_ENABLED=0 GOOS=linux GOARCH=arm64 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
||||||
|
|
||||||
tar -czvf linux_arm64_client.tar.gz npc conf/npc.conf
|
tar -czvf linux_arm64_client.tar.gz npc conf/npc.conf conf/multi_account.conf
|
||||||
|
|
||||||
|
|
||||||
CGO_ENABLED=0 GOOS=linux GOARCH=mips64 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
CGO_ENABLED=0 GOOS=linux GOARCH=mips64 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
||||||
|
|
||||||
tar -czvf linux_mips64_client.tar.gz npc conf/npc.conf
|
tar -czvf linux_mips64_client.tar.gz npc conf/npc.conf conf/multi_account.conf
|
||||||
|
|
||||||
|
|
||||||
CGO_ENABLED=0 GOOS=linux GOARCH=mips64le go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
CGO_ENABLED=0 GOOS=linux GOARCH=mips64le go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
||||||
|
|
||||||
tar -czvf linux_mips64le_client.tar.gz npc conf/npc.conf
|
tar -czvf linux_mips64le_client.tar.gz npc conf/npc.conf conf/multi_account.conf
|
||||||
|
|
||||||
|
|
||||||
CGO_ENABLED=0 GOOS=linux GOARCH=mipsle go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
CGO_ENABLED=0 GOOS=linux GOARCH=mipsle go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
||||||
|
|
||||||
tar -czvf linux_mipsle_client.tar.gz npc conf/npc.conf
|
tar -czvf linux_mipsle_client.tar.gz npc conf/npc.conf conf/multi_account.conf
|
||||||
|
|
||||||
|
|
||||||
CGO_ENABLED=0 GOOS=linux GOARCH=mips go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
CGO_ENABLED=0 GOOS=linux GOARCH=mips go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
||||||
|
|
||||||
tar -czvf linux_mips_client.tar.gz npc conf/npc.conf
|
tar -czvf linux_mips_client.tar.gz npc conf/npc.conf conf/multi_account.conf
|
||||||
|
|
||||||
|
|
||||||
CGO_ENABLED=0 GOOS=windows GOARCH=386 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
CGO_ENABLED=0 GOOS=windows GOARCH=386 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
||||||
|
|
||||||
tar -czvf win_386_client.tar.gz npc.exe conf/npc.conf
|
tar -czvf win_386_client.tar.gz npc.exe conf/npc.conf conf/multi_account.conf
|
||||||
|
|
||||||
|
|
||||||
CGO_ENABLED=0 GOOS=windows GOARCH=amd64 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
CGO_ENABLED=0 GOOS=windows GOARCH=amd64 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
||||||
|
|
||||||
tar -czvf win_amd64_client.tar.gz npc.exe conf/npc.conf
|
tar -czvf win_amd64_client.tar.gz npc.exe conf/npc.conf conf/multi_account.conf
|
||||||
|
|
||||||
|
|
||||||
CGO_ENABLED=0 GOOS=darwin GOARCH=amd64 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
CGO_ENABLED=0 GOOS=darwin GOARCH=amd64 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/npc/npc.go
|
||||||
|
|
||||||
tar -czvf macos_client.tar.gz npc conf/npc.conf
|
tar -czvf macos_client.tar.gz npc conf/npc.conf conf/multi_account.conf
|
||||||
|
|
||||||
CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/nps/nps.go
|
CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -ldflags "-s -w -extldflags -static -extldflags -static" ./cmd/nps/nps.go
|
||||||
|
|
||||||
|
@ -241,6 +241,7 @@ func dealTunnel(s string) *file.Tunnel {
|
|||||||
t.StripPre = item[1]
|
t.StripPre = item[1]
|
||||||
case "multi_account":
|
case "multi_account":
|
||||||
t.MultiAccount = &file.MultiAccount{}
|
t.MultiAccount = &file.MultiAccount{}
|
||||||
|
if common.FileExists(item[1]){
|
||||||
if b, err := common.ReadAllFromFile(item[1]); err != nil {
|
if b, err := common.ReadAllFromFile(item[1]); err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
} else {
|
} else {
|
||||||
@ -252,6 +253,7 @@ func dealTunnel(s string) *file.Tunnel {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return t
|
return t
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -8,13 +8,15 @@ import (
|
|||||||
type PortConn struct {
|
type PortConn struct {
|
||||||
Conn net.Conn
|
Conn net.Conn
|
||||||
rs []byte
|
rs []byte
|
||||||
|
readMore bool
|
||||||
start int
|
start int
|
||||||
}
|
}
|
||||||
|
|
||||||
func newPortConn(conn net.Conn, rs []byte) *PortConn {
|
func newPortConn(conn net.Conn, rs []byte, readMore bool) *PortConn {
|
||||||
return &PortConn{
|
return &PortConn{
|
||||||
Conn: conn,
|
Conn: conn,
|
||||||
rs: rs,
|
rs: rs,
|
||||||
|
readMore: readMore,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -29,9 +31,15 @@ func (pConn *PortConn) Read(b []byte) (n int, err error) {
|
|||||||
defer func() {
|
defer func() {
|
||||||
pConn.start = len(pConn.rs)
|
pConn.start = len(pConn.rs)
|
||||||
}()
|
}()
|
||||||
return copy(b, pConn.rs[pConn.start:]), nil
|
n = copy(b, pConn.rs[pConn.start:])
|
||||||
|
if !pConn.readMore {
|
||||||
|
return
|
||||||
}
|
}
|
||||||
return pConn.Conn.Read(b)
|
}
|
||||||
|
var n2 = 0
|
||||||
|
n2, err = pConn.Conn.Read(b[n:])
|
||||||
|
n = n + n2
|
||||||
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
func (pConn *PortConn) Write(b []byte) (n int, err error) {
|
func (pConn *PortConn) Write(b []byte) (n int, err error) {
|
||||||
|
@ -89,6 +89,7 @@ func (pMux *PortMux) process(conn net.Conn) {
|
|||||||
var ch chan *PortConn
|
var ch chan *PortConn
|
||||||
var rs []byte
|
var rs []byte
|
||||||
var buffer bytes.Buffer
|
var buffer bytes.Buffer
|
||||||
|
var readMore = false
|
||||||
switch common.BytesToNum(buf) {
|
switch common.BytesToNum(buf) {
|
||||||
case HTTP_CONNECT, HTTP_DELETE, HTTP_GET, HTTP_HEAD, HTTP_OPTIONS, HTTP_POST, HTTP_PUT, HTTP_TRACE: //http and manager
|
case HTTP_CONNECT, HTTP_DELETE, HTTP_GET, HTTP_HEAD, HTTP_OPTIONS, HTTP_POST, HTTP_PUT, HTTP_TRACE: //http and manager
|
||||||
buffer.Reset()
|
buffer.Reset()
|
||||||
@ -123,6 +124,7 @@ func (pMux *PortMux) process(conn net.Conn) {
|
|||||||
case CLIENT: // client connection
|
case CLIENT: // client connection
|
||||||
ch = pMux.clientConn
|
ch = pMux.clientConn
|
||||||
default: // https
|
default: // https
|
||||||
|
readMore = true
|
||||||
ch = pMux.httpsConn
|
ch = pMux.httpsConn
|
||||||
}
|
}
|
||||||
if len(rs) == 0 {
|
if len(rs) == 0 {
|
||||||
@ -131,7 +133,7 @@ func (pMux *PortMux) process(conn net.Conn) {
|
|||||||
timer := time.NewTimer(ACCEPT_TIME_OUT)
|
timer := time.NewTimer(ACCEPT_TIME_OUT)
|
||||||
select {
|
select {
|
||||||
case <-timer.C:
|
case <-timer.C:
|
||||||
case ch <- newPortConn(conn, rs):
|
case ch <- newPortConn(conn, rs, readMore):
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -342,7 +342,10 @@ func GetDashboardData() map[string]interface{} {
|
|||||||
data := make(map[string]interface{})
|
data := make(map[string]interface{})
|
||||||
data["version"] = version.VERSION
|
data["version"] = version.VERSION
|
||||||
data["hostCount"] = common.GeSynctMapLen(file.GetDb().JsonDb.Hosts)
|
data["hostCount"] = common.GeSynctMapLen(file.GetDb().JsonDb.Hosts)
|
||||||
data["clientCount"] = common.GeSynctMapLen(file.GetDb().JsonDb.Clients) - 1 //Remove the public key client
|
data["clientCount"] = common.GeSynctMapLen(file.GetDb().JsonDb.Clients)
|
||||||
|
if beego.AppConfig.String("public_vkey") != "" { //remove public vkey
|
||||||
|
data["clientCount"] = data["clientCount"].(int) - 1
|
||||||
|
}
|
||||||
dealClientData()
|
dealClientData()
|
||||||
c := 0
|
c := 0
|
||||||
var in, out int64
|
var in, out int64
|
||||||
|
@ -22,6 +22,8 @@ func (self *LoginController) Verify() {
|
|||||||
var auth bool
|
var auth bool
|
||||||
if self.GetString("password") == beego.AppConfig.String("web_password") && self.GetString("username") == beego.AppConfig.String("web_username") {
|
if self.GetString("password") == beego.AppConfig.String("web_password") && self.GetString("username") == beego.AppConfig.String("web_username") {
|
||||||
self.SetSession("isAdmin", true)
|
self.SetSession("isAdmin", true)
|
||||||
|
self.DelSession("clientId")
|
||||||
|
self.DelSession("username")
|
||||||
auth = true
|
auth = true
|
||||||
server.Bridge.Register.Store(common.GetIpByAddr(self.Ctx.Input.IP()), time.Now().Add(time.Hour*time.Duration(2)))
|
server.Bridge.Register.Store(common.GetIpByAddr(self.Ctx.Input.IP()), time.Now().Add(time.Hour*time.Duration(2)))
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user