mirror of
https://github.com/v2fly/v2ray-core.git
synced 2025-01-02 07:26:24 -05:00
refine shadowsocks ota settings
This commit is contained in:
parent
43dacc3936
commit
687e008c9a
@ -66,7 +66,7 @@ func (this *Client) Dispatch(destination v2net.Destination, payload *alloc.Buffe
|
|||||||
account := rawAccount.(*ShadowsocksAccount)
|
account := rawAccount.(*ShadowsocksAccount)
|
||||||
request.User = user
|
request.User = user
|
||||||
|
|
||||||
if account.OneTimeAuth {
|
if account.OneTimeAuth == Account_Auto || account.OneTimeAuth == Account_Enabled {
|
||||||
request.Option |= RequestOptionOneTimeAuth
|
request.Option |= RequestOptionOneTimeAuth
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -13,7 +13,7 @@ import (
|
|||||||
type ShadowsocksAccount struct {
|
type ShadowsocksAccount struct {
|
||||||
Cipher Cipher
|
Cipher Cipher
|
||||||
Key []byte
|
Key []byte
|
||||||
OneTimeAuth bool
|
OneTimeAuth Account_OneTimeAuth
|
||||||
}
|
}
|
||||||
|
|
||||||
func (this *ShadowsocksAccount) Equals(another protocol.Account) bool {
|
func (this *ShadowsocksAccount) Equals(another protocol.Account) bool {
|
||||||
@ -46,7 +46,7 @@ func (this *Account) AsAccount() (protocol.Account, error) {
|
|||||||
return &ShadowsocksAccount{
|
return &ShadowsocksAccount{
|
||||||
Cipher: cipher,
|
Cipher: cipher,
|
||||||
Key: this.GetCipherKey(),
|
Key: this.GetCipherKey(),
|
||||||
OneTimeAuth: this.Ota == Account_Auto || this.Ota == Account_Enabled,
|
OneTimeAuth: this.Ota,
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -21,6 +21,7 @@ type Server struct {
|
|||||||
packetDispatcher dispatcher.PacketDispatcher
|
packetDispatcher dispatcher.PacketDispatcher
|
||||||
config *ServerConfig
|
config *ServerConfig
|
||||||
user *protocol.User
|
user *protocol.User
|
||||||
|
account *ShadowsocksAccount
|
||||||
meta *proxy.InboundHandlerMeta
|
meta *proxy.InboundHandlerMeta
|
||||||
accepting bool
|
accepting bool
|
||||||
tcpHub *internet.TCPHub
|
tcpHub *internet.TCPHub
|
||||||
@ -33,10 +34,17 @@ func NewServer(config *ServerConfig, space app.Space, meta *proxy.InboundHandler
|
|||||||
return nil, protocol.ErrUserMissing
|
return nil, protocol.ErrUserMissing
|
||||||
}
|
}
|
||||||
|
|
||||||
|
rawAccount, err := user.GetTypedAccount()
|
||||||
|
if err != nil {
|
||||||
|
return nil, errors.New("Shadowsocks|Server: Failed to get user account: " + err.Error())
|
||||||
|
}
|
||||||
|
account := rawAccount.(*ShadowsocksAccount)
|
||||||
|
|
||||||
s := &Server{
|
s := &Server{
|
||||||
config: config,
|
config: config,
|
||||||
meta: meta,
|
meta: meta,
|
||||||
user: config.GetUser(),
|
user: config.GetUser(),
|
||||||
|
account: account,
|
||||||
}
|
}
|
||||||
|
|
||||||
space.InitializeApplication(func() error {
|
space.InitializeApplication(func() error {
|
||||||
@ -105,6 +113,18 @@ func (this *Server) handlerUDPPayload(payload *alloc.Buffer, session *proxy.Sess
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if request.Option.Has(RequestOptionOneTimeAuth) && this.account.OneTimeAuth == Account_Disabled {
|
||||||
|
log.Info("Shadowsocks|Server: Client payload enables OTA but server doesn't allow it.")
|
||||||
|
payload.Release()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if !request.Option.Has(RequestOptionOneTimeAuth) && this.account.OneTimeAuth == Account_Enabled {
|
||||||
|
log.Info("Shadowsocks|Server: Client payload disables OTA but server forces it.")
|
||||||
|
payload.Release()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
dest := request.Destination()
|
dest := request.Destination()
|
||||||
log.Access(source, dest, log.AccessAccepted, "")
|
log.Access(source, dest, log.AccessAccepted, "")
|
||||||
log.Info("Shadowsocks|Server: Tunnelling request to ", dest)
|
log.Info("Shadowsocks|Server: Tunnelling request to ", dest)
|
||||||
|
Loading…
Reference in New Issue
Block a user