|  | @@ -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)
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  
 |