diff options
| author | Ho3ein <ho3ein.sanaei@gmail.com> | 2023-05-14 23:28:54 +0300 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2023-05-14 23:28:54 +0300 |
| commit | a0daf2fae2365aceec59ea362dfa35c0983f0191 (patch) | |
| tree | 0f75661e4d71f453a6a5d08db02f6732285f1e08 /web/service/inbound.go | |
| parent | 5487dc41ccdb7902e3ee06634bd1077e09625fed (diff) | |
| parent | a21bdc939615439548b47fb551236ea59ab8f177 (diff) | |
Merge pull request #438 from masoud-hidden/main
[tgbot] Some new changes in the bot
Diffstat (limited to 'web/service/inbound.go')
| -rw-r--r-- | web/service/inbound.go | 94 |
1 files changed, 94 insertions, 0 deletions
diff --git a/web/service/inbound.go b/web/service/inbound.go index 7e838b5f..57df0b9e 100644 --- a/web/service/inbound.go +++ b/web/service/inbound.go @@ -673,6 +673,21 @@ func (s *InboundService) DelClientIPs(tx *gorm.DB, email string) error { return tx.Where("client_email = ?", email).Delete(model.InboundClientIps{}).Error } +func (s *InboundService) GetClientInboundByTrafficID(trafficId int) (traffic *xray.ClientTraffic, inbound *model.Inbound, err error) { + db := database.GetDB() + var traffics []*xray.ClientTraffic + err = db.Model(xray.ClientTraffic{}).Where("id = ?", trafficId).Find(&traffics).Error + if err != nil { + logger.Warning(err) + return nil, nil, err + } + if len(traffics) > 0 { + inbound, err = s.GetInbound(traffics[0].InboundId) + return traffics[0], inbound, err + } + return nil, nil, nil +} + func (s *InboundService) GetClientInboundByEmail(email string) (traffic *xray.ClientTraffic, inbound *model.Inbound, err error) { db := database.GetDB() var traffics []*xray.ClientTraffic @@ -688,6 +703,85 @@ func (s *InboundService) GetClientInboundByEmail(email string) (traffic *xray.Cl return nil, nil, nil } +func (s *InboundService) GetClientByEmail(clientEmail string) (*xray.ClientTraffic, *model.Client, error) { + traffic, inbound, err := s.GetClientInboundByEmail(clientEmail) + if err != nil { + return nil, nil, err + } + if inbound == nil { + return nil, nil, common.NewError("Inbound Not Found For Email:", clientEmail) + } + + clients, err := s.getClients(inbound) + if err != nil { + return nil, nil, err + } + + for _, client := range clients { + if client.Email == clientEmail { + return traffic, &client, nil + } + } + + return nil, nil, common.NewError("Client Not Found In Inbound For Email:", clientEmail) +} + +func (s *InboundService) SetClientTelegramUserID(trafficId int, tgId string) error { + traffic, inbound, err := s.GetClientInboundByTrafficID(trafficId) + if err != nil { + return err + } + if inbound == nil { + return common.NewError("Inbound Not Found For Traffic ID:", trafficId) + } + + clientEmail := traffic.Email + + oldClients, err := s.getClients(inbound) + if err != nil { + return err + } + + clientId := "" + + for _, oldClient := range oldClients { + if oldClient.Email == clientEmail { + if inbound.Protocol == "trojan" { + clientId = oldClient.Password + } else { + clientId = oldClient.ID + } + break + } + } + + if len(clientId) == 0 { + return common.NewError("Client Not Found For Email:", clientEmail) + } + + var settings map[string]interface{} + err = json.Unmarshal([]byte(inbound.Settings), &settings) + if err != nil { + return 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["tgId"] = tgId + newClients = append(newClients, interface{}(c)) + } + } + settings["clients"] = newClients + modifiedSettings, err := json.MarshalIndent(settings, "", " ") + if err != nil { + return err + } + inbound.Settings = string(modifiedSettings) + return s.UpdateInboundClient(inbound, clientId) +} + func (s *InboundService) ToggleClientEnableByEmail(clientEmail string) (bool, error) { _, inbound, err := s.GetClientInboundByEmail(clientEmail) if err != nil { |
