diff options
| author | Masoud Hidden <masoud.hidden.user@gmail.com> | 2023-05-05 19:20:40 +0300 |
|---|---|---|
| committer | Masoud Hidden <masoud.hidden.user@gmail.com> | 2023-05-05 19:20:40 +0300 |
| commit | d349bffcd6ba547ed9e4cdf5b199c5100a99437f (patch) | |
| tree | 858f71484685380c62a8fcfb7a5f31ae2e88b690 /web/service/inbound.go | |
| parent | 5856160c30fb3f525b584fb25a35ec78c8fb0488 (diff) | |
Fix bot client enable button
Diffstat (limited to 'web/service/inbound.go')
| -rw-r--r-- | web/service/inbound.go | 34 |
1 files changed, 17 insertions, 17 deletions
diff --git a/web/service/inbound.go b/web/service/inbound.go index 2cd42b8e..dd633c4b 100644 --- a/web/service/inbound.go +++ b/web/service/inbound.go @@ -679,21 +679,22 @@ func (s *InboundService) GetClientInboundByEmail(email string) (traffic *xray.Cl return nil, nil, nil } -func (s *InboundService) ToggleClientEnableByEmail(clientEmail string) (*xray.ClientTraffic, error) { - traffic, inbound, err := s.GetClientInboundByEmail(clientEmail) +func (s *InboundService) ToggleClientEnableByEmail(clientEmail string) (bool, error) { + _, inbound, err := s.GetClientInboundByEmail(clientEmail) if err != nil { - return nil, err + return false, err } - if inbound == nil || traffic == nil { - return nil, common.NewError("Inbound Not Found For Email:", clientEmail) + if inbound == nil { + return false, common.NewError("Inbound Not Found For Email:", clientEmail) } oldClients, err := s.getClients(inbound) if err != nil { - return nil, err + return false, err } clientId := "" + clientOldEnabled := false for _, oldClient := range oldClients { if oldClient.Email == clientEmail { @@ -702,45 +703,44 @@ func (s *InboundService) ToggleClientEnableByEmail(clientEmail string) (*xray.Cl } else { clientId = oldClient.ID } + clientOldEnabled = oldClient.Enable break } } if len(clientId) == 0 { - return nil, common.NewError("Client Not Found For Email:", clientEmail) + return false, common.NewError("Client Not Found For Email:", clientEmail) } - traffic.Enable = !traffic.Enable - var settings map[string]interface{} err = json.Unmarshal([]byte(inbound.Settings), &settings) if err != nil { - return nil, err + return false, err } clients := settings["clients"].([]interface{}) var newClients []interface{} for client_index := range clients { c := clients[client_index].(map[string]interface{}) if c["email"] == clientEmail { - c["enable"] = traffic.Enable + c["enable"] = !clientOldEnabled newClients = append(newClients, interface{}(c)) } } settings["clients"] = newClients modifiedSettings, err := json.MarshalIndent(settings, "", " ") if err != nil { - return nil, err + return false, err } inbound.Settings = string(modifiedSettings) - return traffic, s.UpdateInboundClient(inbound, clientId) + return !clientOldEnabled, s.UpdateInboundClient(inbound, clientId) } func (s *InboundService) ResetClientIpLimitByEmail(clientEmail string, count int) error { - traffic, inbound, err := s.GetClientInboundByEmail(clientEmail) + _, inbound, err := s.GetClientInboundByEmail(clientEmail) if err != nil { return err } - if inbound == nil || traffic == nil { + if inbound == nil { return common.NewError("Inbound Not Found For Email:", clientEmail) } @@ -790,11 +790,11 @@ func (s *InboundService) ResetClientIpLimitByEmail(clientEmail string, count int } func (s *InboundService) ResetClientExpiryTimeByEmail(clientEmail string, expiry_time int64) error { - traffic, inbound, err := s.GetClientInboundByEmail(clientEmail) + _, inbound, err := s.GetClientInboundByEmail(clientEmail) if err != nil { return err } - if inbound == nil || traffic == nil { + if inbound == nil { return common.NewError("Inbound Not Found For Email:", clientEmail) } |
