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)
|
||||
request.User = user
|
||||
|
||||
if account.OneTimeAuth {
|
||||
if account.OneTimeAuth == Account_Auto || account.OneTimeAuth == Account_Enabled {
|
||||
request.Option |= RequestOptionOneTimeAuth
|
||||
}
|
||||
|
||||
|
@ -13,7 +13,7 @@ import (
|
||||
type ShadowsocksAccount struct {
|
||||
Cipher Cipher
|
||||
Key []byte
|
||||
OneTimeAuth bool
|
||||
OneTimeAuth Account_OneTimeAuth
|
||||
}
|
||||
|
||||
func (this *ShadowsocksAccount) Equals(another protocol.Account) bool {
|
||||
@ -46,7 +46,7 @@ func (this *Account) AsAccount() (protocol.Account, error) {
|
||||
return &ShadowsocksAccount{
|
||||
Cipher: cipher,
|
||||
Key: this.GetCipherKey(),
|
||||
OneTimeAuth: this.Ota == Account_Auto || this.Ota == Account_Enabled,
|
||||
OneTimeAuth: this.Ota,
|
||||
}, nil
|
||||
}
|
||||
|
||||
|
@ -21,6 +21,7 @@ type Server struct {
|
||||
packetDispatcher dispatcher.PacketDispatcher
|
||||
config *ServerConfig
|
||||
user *protocol.User
|
||||
account *ShadowsocksAccount
|
||||
meta *proxy.InboundHandlerMeta
|
||||
accepting bool
|
||||
tcpHub *internet.TCPHub
|
||||
@ -33,10 +34,17 @@ func NewServer(config *ServerConfig, space app.Space, meta *proxy.InboundHandler
|
||||
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{
|
||||
config: config,
|
||||
meta: meta,
|
||||
user: config.GetUser(),
|
||||
account: account,
|
||||
}
|
||||
|
||||
space.InitializeApplication(func() error {
|
||||
@ -105,6 +113,18 @@ func (this *Server) handlerUDPPayload(payload *alloc.Buffer, session *proxy.Sess
|
||||
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()
|
||||
log.Access(source, dest, log.AccessAccepted, "")
|
||||
log.Info("Shadowsocks|Server: Tunnelling request to ", dest)
|
||||
|
Loading…
Reference in New Issue
Block a user