inbound.go 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592
  1. package service
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "time"
  6. "x-ui/database"
  7. "x-ui/database/model"
  8. "x-ui/logger"
  9. "x-ui/util/common"
  10. "x-ui/xray"
  11. "gorm.io/gorm"
  12. )
  13. type InboundService struct {
  14. }
  15. func (s *InboundService) GetInbounds(userId int) ([]*model.Inbound, error) {
  16. db := database.GetDB()
  17. var inbounds []*model.Inbound
  18. err := db.Model(model.Inbound{}).Preload("ClientStats").Where("user_id = ?", userId).Find(&inbounds).Error
  19. if err != nil && err != gorm.ErrRecordNotFound {
  20. return nil, err
  21. }
  22. return inbounds, nil
  23. }
  24. func (s *InboundService) GetAllInbounds() ([]*model.Inbound, error) {
  25. db := database.GetDB()
  26. var inbounds []*model.Inbound
  27. err := db.Model(model.Inbound{}).Preload("ClientStats").Find(&inbounds).Error
  28. if err != nil && err != gorm.ErrRecordNotFound {
  29. return nil, err
  30. }
  31. return inbounds, nil
  32. }
  33. func (s *InboundService) checkPortExist(port int, ignoreId int) (bool, error) {
  34. db := database.GetDB()
  35. db = db.Model(model.Inbound{}).Where("port = ?", port)
  36. if ignoreId > 0 {
  37. db = db.Where("id != ?", ignoreId)
  38. }
  39. var count int64
  40. err := db.Count(&count).Error
  41. if err != nil {
  42. return false, err
  43. }
  44. return count > 0, nil
  45. }
  46. func (s *InboundService) getClients(inbound *model.Inbound) ([]model.Client, error) {
  47. settings := map[string][]model.Client{}
  48. json.Unmarshal([]byte(inbound.Settings), &settings)
  49. if settings == nil {
  50. return nil, fmt.Errorf("setting is null")
  51. }
  52. clients := settings["clients"]
  53. if clients == nil {
  54. return nil, nil
  55. }
  56. return clients, nil
  57. }
  58. func (s *InboundService) checkEmailsExist(emails map[string]bool, ignoreId int) (string, error) {
  59. db := database.GetDB()
  60. var inbounds []*model.Inbound
  61. db = db.Model(model.Inbound{}).Where("Protocol in ?", []model.Protocol{model.VMess, model.VLESS, model.Trojan})
  62. if ignoreId > 0 {
  63. db = db.Where("id != ?", ignoreId)
  64. }
  65. db = db.Find(&inbounds)
  66. if db.Error != nil {
  67. return "", db.Error
  68. }
  69. for _, inbound := range inbounds {
  70. clients, err := s.getClients(inbound)
  71. if err != nil {
  72. return "", err
  73. }
  74. for _, client := range clients {
  75. if emails[client.Email] {
  76. return client.Email, nil
  77. }
  78. }
  79. }
  80. return "", nil
  81. }
  82. func (s *InboundService) checkEmailExistForInbound(inbound *model.Inbound) (string, error) {
  83. clients, err := s.getClients(inbound)
  84. if err != nil {
  85. return "", err
  86. }
  87. emails := make(map[string]bool)
  88. for _, client := range clients {
  89. if client.Email != "" {
  90. if emails[client.Email] {
  91. return client.Email, nil
  92. }
  93. emails[client.Email] = true
  94. }
  95. }
  96. return s.checkEmailsExist(emails, inbound.Id)
  97. }
  98. func (s *InboundService) AddInbound(inbound *model.Inbound) (*model.Inbound, error) {
  99. exist, err := s.checkPortExist(inbound.Port, 0)
  100. if err != nil {
  101. return inbound, err
  102. }
  103. if exist {
  104. return inbound, common.NewError("Port already exists:", inbound.Port)
  105. }
  106. existEmail, err := s.checkEmailExistForInbound(inbound)
  107. if err != nil {
  108. return inbound, err
  109. }
  110. if existEmail != "" {
  111. return inbound, common.NewError("Duplicate email:", existEmail)
  112. }
  113. clients, err := s.getClients(inbound)
  114. if err != nil {
  115. return inbound, err
  116. }
  117. db := database.GetDB()
  118. err = db.Save(inbound).Error
  119. if err == nil {
  120. for _, client := range clients {
  121. s.AddClientStat(inbound.Id, &client)
  122. }
  123. }
  124. return inbound, err
  125. }
  126. func (s *InboundService) AddInbounds(inbounds []*model.Inbound) error {
  127. for _, inbound := range inbounds {
  128. exist, err := s.checkPortExist(inbound.Port, 0)
  129. if err != nil {
  130. return err
  131. }
  132. if exist {
  133. return common.NewError("Port already exists:", inbound.Port)
  134. }
  135. }
  136. db := database.GetDB()
  137. tx := db.Begin()
  138. var err error
  139. defer func() {
  140. if err == nil {
  141. tx.Commit()
  142. } else {
  143. tx.Rollback()
  144. }
  145. }()
  146. for _, inbound := range inbounds {
  147. err = tx.Save(inbound).Error
  148. if err != nil {
  149. return err
  150. }
  151. }
  152. return nil
  153. }
  154. func (s *InboundService) DelInbound(id int) error {
  155. db := database.GetDB()
  156. err := db.Where("inbound_id = ?", id).Delete(xray.ClientTraffic{}).Error
  157. if err != nil {
  158. return err
  159. }
  160. return db.Delete(model.Inbound{}, id).Error
  161. }
  162. func (s *InboundService) GetInbound(id int) (*model.Inbound, error) {
  163. db := database.GetDB()
  164. inbound := &model.Inbound{}
  165. err := db.Model(model.Inbound{}).First(inbound, id).Error
  166. if err != nil {
  167. return nil, err
  168. }
  169. return inbound, nil
  170. }
  171. func (s *InboundService) UpdateInbound(inbound *model.Inbound) (*model.Inbound, error) {
  172. exist, err := s.checkPortExist(inbound.Port, inbound.Id)
  173. if err != nil {
  174. return inbound, err
  175. }
  176. if exist {
  177. return inbound, common.NewError("Port already exists:", inbound.Port)
  178. }
  179. existEmail, err := s.checkEmailExistForInbound(inbound)
  180. if err != nil {
  181. return inbound, err
  182. }
  183. if existEmail != "" {
  184. return inbound, common.NewError("Duplicate email:", existEmail)
  185. }
  186. oldInbound, err := s.GetInbound(inbound.Id)
  187. if err != nil {
  188. return inbound, err
  189. }
  190. oldInbound.Up = inbound.Up
  191. oldInbound.Down = inbound.Down
  192. oldInbound.Total = inbound.Total
  193. oldInbound.Remark = inbound.Remark
  194. oldInbound.Enable = inbound.Enable
  195. oldInbound.ExpiryTime = inbound.ExpiryTime
  196. oldInbound.Listen = inbound.Listen
  197. oldInbound.Port = inbound.Port
  198. oldInbound.Protocol = inbound.Protocol
  199. oldInbound.Settings = inbound.Settings
  200. oldInbound.StreamSettings = inbound.StreamSettings
  201. oldInbound.Sniffing = inbound.Sniffing
  202. oldInbound.Tag = fmt.Sprintf("inbound-%v", inbound.Port)
  203. db := database.GetDB()
  204. return inbound, db.Save(oldInbound).Error
  205. }
  206. func (s *InboundService) AddInboundClient(inbound *model.Inbound) error {
  207. existEmail, err := s.checkEmailExistForInbound(inbound)
  208. if err != nil {
  209. return err
  210. }
  211. if existEmail != "" {
  212. return common.NewError("Duplicate email:", existEmail)
  213. }
  214. clients, err := s.getClients(inbound)
  215. if err != nil {
  216. return err
  217. }
  218. oldInbound, err := s.GetInbound(inbound.Id)
  219. if err != nil {
  220. return err
  221. }
  222. oldClients, err := s.getClients(oldInbound)
  223. if err != nil {
  224. return err
  225. }
  226. oldInbound.Settings = inbound.Settings
  227. if len(clients[len(clients)-1].Email) > 0 {
  228. s.AddClientStat(inbound.Id, &clients[len(clients)-1])
  229. }
  230. for i := len(oldClients); i < len(clients); i++ {
  231. if len(clients[i].Email) > 0 {
  232. s.AddClientStat(inbound.Id, &clients[i])
  233. }
  234. }
  235. db := database.GetDB()
  236. return db.Save(oldInbound).Error
  237. }
  238. func (s *InboundService) DelInboundClient(inbound *model.Inbound, email string) error {
  239. db := database.GetDB()
  240. err := s.DelClientStat(db, email)
  241. if err != nil {
  242. logger.Error("Delete stats Data Error")
  243. return err
  244. }
  245. oldInbound, err := s.GetInbound(inbound.Id)
  246. if err != nil {
  247. logger.Error("Load Old Data Error")
  248. return err
  249. }
  250. oldInbound.Settings = inbound.Settings
  251. return db.Save(oldInbound).Error
  252. }
  253. func (s *InboundService) UpdateInboundClient(inbound *model.Inbound, index int) error {
  254. existEmail, err := s.checkEmailExistForInbound(inbound)
  255. if err != nil {
  256. return err
  257. }
  258. if existEmail != "" {
  259. return common.NewError("Duplicate email:", existEmail)
  260. }
  261. clients, err := s.getClients(inbound)
  262. if err != nil {
  263. return err
  264. }
  265. oldInbound, err := s.GetInbound(inbound.Id)
  266. if err != nil {
  267. return err
  268. }
  269. oldClients, err := s.getClients(oldInbound)
  270. if err != nil {
  271. return err
  272. }
  273. oldInbound.Settings = inbound.Settings
  274. db := database.GetDB()
  275. if len(clients[index].Email) > 0 {
  276. if len(oldClients[index].Email) > 0 {
  277. s.UpdateClientStat(oldClients[index].Email, &clients[index])
  278. } else {
  279. s.AddClientStat(inbound.Id, &clients[index])
  280. }
  281. } else {
  282. s.DelClientStat(db, oldClients[index].Email)
  283. }
  284. return db.Save(oldInbound).Error
  285. }
  286. func (s *InboundService) AddTraffic(traffics []*xray.Traffic) (err error) {
  287. if len(traffics) == 0 {
  288. return nil
  289. }
  290. db := database.GetDB()
  291. db = db.Model(model.Inbound{})
  292. tx := db.Begin()
  293. defer func() {
  294. if err != nil {
  295. tx.Rollback()
  296. } else {
  297. tx.Commit()
  298. }
  299. }()
  300. for _, traffic := range traffics {
  301. if traffic.IsInbound {
  302. err = tx.Where("tag = ?", traffic.Tag).
  303. UpdateColumns(map[string]interface{}{
  304. "up": gorm.Expr("up + ?", traffic.Up),
  305. "down": gorm.Expr("down + ?", traffic.Down)}).Error
  306. if err != nil {
  307. return
  308. }
  309. }
  310. }
  311. return
  312. }
  313. func (s *InboundService) AddClientTraffic(traffics []*xray.ClientTraffic) (err error) {
  314. if len(traffics) == 0 {
  315. return nil
  316. }
  317. db := database.GetDB()
  318. dbInbound := db.Model(model.Inbound{})
  319. db = db.Model(xray.ClientTraffic{})
  320. tx := db.Begin()
  321. defer func() {
  322. if err != nil {
  323. tx.Rollback()
  324. } else {
  325. tx.Commit()
  326. }
  327. }()
  328. txInbound := dbInbound.Begin()
  329. defer func() {
  330. if err != nil {
  331. txInbound.Rollback()
  332. } else {
  333. txInbound.Commit()
  334. }
  335. }()
  336. for _, traffic := range traffics {
  337. inbound := &model.Inbound{}
  338. client := &xray.ClientTraffic{}
  339. err := tx.Where("email = ?", traffic.Email).First(client).Error
  340. if err != nil {
  341. if err == gorm.ErrRecordNotFound {
  342. logger.Warning(err, traffic.Email)
  343. }
  344. continue
  345. }
  346. err = txInbound.Where("id=?", client.InboundId).First(inbound).Error
  347. if err != nil {
  348. if err == gorm.ErrRecordNotFound {
  349. logger.Warning(err, traffic.Email)
  350. }
  351. continue
  352. }
  353. // get settings clients
  354. settings := map[string][]model.Client{}
  355. json.Unmarshal([]byte(inbound.Settings), &settings)
  356. clients := settings["clients"]
  357. for _, client := range clients {
  358. if traffic.Email == client.Email {
  359. traffic.ExpiryTime = client.ExpiryTime
  360. traffic.Total = client.TotalGB
  361. }
  362. }
  363. if tx.Where("inbound_id = ? and email = ?", inbound.Id, traffic.Email).
  364. UpdateColumns(map[string]interface{}{
  365. "enable": true,
  366. "expiry_time": traffic.ExpiryTime,
  367. "total": traffic.Total,
  368. "up": gorm.Expr("up + ?", traffic.Up),
  369. "down": gorm.Expr("down + ?", traffic.Down)}).RowsAffected == 0 {
  370. err = tx.Create(traffic).Error
  371. }
  372. if err != nil {
  373. logger.Warning("AddClientTraffic update data ", err)
  374. continue
  375. }
  376. }
  377. return
  378. }
  379. func (s *InboundService) DisableInvalidInbounds() (int64, error) {
  380. db := database.GetDB()
  381. now := time.Now().Unix() * 1000
  382. result := db.Model(model.Inbound{}).
  383. Where("((total > 0 and up + down >= total) or (expiry_time > 0 and expiry_time <= ?)) and enable = ?", now, true).
  384. Update("enable", false)
  385. err := result.Error
  386. count := result.RowsAffected
  387. return count, err
  388. }
  389. func (s *InboundService) DisableInvalidClients() (int64, error) {
  390. db := database.GetDB()
  391. now := time.Now().Unix() * 1000
  392. result := db.Model(xray.ClientTraffic{}).
  393. Where("((total > 0 and up + down >= total) or (expiry_time > 0 and expiry_time <= ?)) and enable = ?", now, true).
  394. Update("enable", false)
  395. err := result.Error
  396. count := result.RowsAffected
  397. return count, err
  398. }
  399. func (s *InboundService) AddClientStat(inboundId int, client *model.Client) error {
  400. db := database.GetDB()
  401. clientTraffic := xray.ClientTraffic{}
  402. clientTraffic.InboundId = inboundId
  403. clientTraffic.Email = client.Email
  404. clientTraffic.Total = client.TotalGB
  405. clientTraffic.ExpiryTime = client.ExpiryTime
  406. clientTraffic.Enable = true
  407. clientTraffic.Up = 0
  408. clientTraffic.Down = 0
  409. result := db.Create(&clientTraffic)
  410. err := result.Error
  411. if err != nil {
  412. return err
  413. }
  414. return nil
  415. }
  416. func (s *InboundService) UpdateClientStat(email string, client *model.Client) error {
  417. db := database.GetDB()
  418. result := db.Model(xray.ClientTraffic{}).
  419. Where("email = ?", email).
  420. Updates(map[string]interface{}{
  421. "enable": true,
  422. "email": client.Email,
  423. "total": client.TotalGB,
  424. "expiry_time": client.ExpiryTime})
  425. err := result.Error
  426. if err != nil {
  427. return err
  428. }
  429. return nil
  430. }
  431. func (s *InboundService) DelClientStat(tx *gorm.DB, email string) error {
  432. return tx.Where("email = ?", email).Delete(xray.ClientTraffic{}).Error
  433. }
  434. func (s *InboundService) ResetClientTraffic(id int, clientEmail string) error {
  435. db := database.GetDB()
  436. result := db.Model(xray.ClientTraffic{}).
  437. Where("inbound_id = ? and email = ?", id, clientEmail).
  438. Updates(map[string]interface{}{"enable": true, "up": 0, "down": 0})
  439. err := result.Error
  440. if err != nil {
  441. return err
  442. }
  443. return nil
  444. }
  445. func (s *InboundService) GetClientTrafficTgBot(tguname string) (traffic []*xray.ClientTraffic, err error) {
  446. db := database.GetDB()
  447. var traffics []*xray.ClientTraffic
  448. err = db.Model(xray.ClientTraffic{}).Where("email like ?", "%@"+tguname).Find(&traffics).Error
  449. if err != nil {
  450. if err == gorm.ErrRecordNotFound {
  451. logger.Warning(err)
  452. return nil, err
  453. }
  454. }
  455. return traffics, err
  456. }
  457. func (s *InboundService) GetClientTrafficByEmail(email string) (traffic []*xray.ClientTraffic, err error) {
  458. db := database.GetDB()
  459. var traffics []*xray.ClientTraffic
  460. err = db.Model(xray.ClientTraffic{}).Where("email like ?", "%"+email+"%").Find(&traffics).Error
  461. if err != nil {
  462. if err == gorm.ErrRecordNotFound {
  463. logger.Warning(err)
  464. return nil, err
  465. }
  466. }
  467. return traffics, err
  468. }
  469. func (s *InboundService) SearchClientTraffic(query string) (traffic *xray.ClientTraffic, err error) {
  470. db := database.GetDB()
  471. inbound := &model.Inbound{}
  472. traffic = &xray.ClientTraffic{}
  473. err = db.Model(model.Inbound{}).Where("settings like ?", "%\""+query+"\"%").First(inbound).Error
  474. if err != nil {
  475. if err == gorm.ErrRecordNotFound {
  476. logger.Warning(err)
  477. return nil, err
  478. }
  479. }
  480. traffic.InboundId = inbound.Id
  481. // get settings clients
  482. settings := map[string][]model.Client{}
  483. json.Unmarshal([]byte(inbound.Settings), &settings)
  484. clients := settings["clients"]
  485. for _, client := range clients {
  486. if client.ID == query && client.Email != "" {
  487. traffic.Email = client.Email
  488. break
  489. }
  490. if client.Password == query && client.Email != "" {
  491. traffic.Email = client.Email
  492. break
  493. }
  494. }
  495. if traffic.Email == "" {
  496. return nil, err
  497. }
  498. err = db.Model(xray.ClientTraffic{}).Where("email = ?", traffic.Email).First(traffic).Error
  499. if err != nil {
  500. logger.Warning(err)
  501. return nil, err
  502. }
  503. return traffic, err
  504. }
  505. func (s *InboundService) GetInboundClientIps(clientEmail string) (string, error) {
  506. db := database.GetDB()
  507. InboundClientIps := &model.InboundClientIps{}
  508. err := db.Model(model.InboundClientIps{}).Where("client_email = ?", clientEmail).First(InboundClientIps).Error
  509. if err != nil {
  510. return "", err
  511. }
  512. return InboundClientIps.Ips, nil
  513. }
  514. func (s *InboundService) ClearClientIps(clientEmail string) (error) {
  515. db := database.GetDB()
  516. result := db.Model(model.InboundClientIps{}).
  517. Where("client_email = ?", clientEmail).
  518. Update("ips", "")
  519. err := result.Error
  520. if err != nil {
  521. return err
  522. }
  523. return nil
  524. }