service_wireguard_test.go 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. package sub
  2. import (
  3. "net/url"
  4. "testing"
  5. "github.com/mhsanaei/3x-ui/v3/internal/database"
  6. "github.com/mhsanaei/3x-ui/v3/internal/database/model"
  7. wgutil "github.com/mhsanaei/3x-ui/v3/internal/util/wireguard"
  8. )
  9. func TestGenWireguardLinkFields(t *testing.T) {
  10. serverPriv, serverPub, err := wgutil.GenerateWireguardKeypair()
  11. if err != nil {
  12. t.Fatalf("keypair: %v", err)
  13. }
  14. clientPriv, _, err := wgutil.GenerateWireguardKeypair()
  15. if err != nil {
  16. t.Fatalf("client keypair: %v", err)
  17. }
  18. inbound := &model.Inbound{
  19. Listen: "203.0.113.7",
  20. Port: 51820,
  21. Protocol: model.WireGuard,
  22. Remark: "wg-sub",
  23. Settings: `{"secretKey":"` + serverPriv + `","mtu":1420,"clients":[{"email":"user","privateKey":"` + clientPriv + `","allowedIPs":["10.0.0.2/32"],"keepAlive":25}]}`,
  24. }
  25. s := &SubService{}
  26. link := s.genWireguardLink(inbound, "user")
  27. u, err := url.Parse(link)
  28. if err != nil {
  29. t.Fatalf("link does not parse: %v\n got: %s", err, link)
  30. }
  31. if u.Scheme != "wireguard" {
  32. t.Fatalf("scheme = %q, want wireguard", u.Scheme)
  33. }
  34. if u.Host != "203.0.113.7:51820" {
  35. t.Fatalf("host = %q, want 203.0.113.7:51820", u.Host)
  36. }
  37. if u.User.Username() != clientPriv {
  38. t.Fatalf("userinfo = %q, want client private key %q", u.User.Username(), clientPriv)
  39. }
  40. q := u.Query()
  41. if q.Get("publickey") != serverPub {
  42. t.Fatalf("publickey = %q, want server public key %q", q.Get("publickey"), serverPub)
  43. }
  44. if q.Get("address") != "10.0.0.2/32" {
  45. t.Fatalf("address = %q, want 10.0.0.2/32", q.Get("address"))
  46. }
  47. if q.Get("mtu") != "1420" {
  48. t.Fatalf("mtu = %q, want 1420", q.Get("mtu"))
  49. }
  50. }
  51. func TestGenWireguardLinkWrongProtocol(t *testing.T) {
  52. s := &SubService{}
  53. vless := &model.Inbound{Protocol: model.VLESS, Settings: `{"clients":[{"email":"user"}]}`}
  54. if got := s.genWireguardLink(vless, "user"); got != "" {
  55. t.Fatalf("wrong protocol should yield empty link, got %q", got)
  56. }
  57. }
  58. func TestGenWireguardLinkNoKey(t *testing.T) {
  59. s := &SubService{}
  60. inbound := &model.Inbound{
  61. Protocol: model.WireGuard,
  62. Port: 51820,
  63. Settings: `{"secretKey":"x","clients":[{"email":"user"}]}`,
  64. }
  65. if got := s.genWireguardLink(inbound, "user"); got != "" {
  66. t.Fatalf("client without private key should yield empty link, got %q", got)
  67. }
  68. }
  69. func TestGetInboundsBySubIdIncludesWireguard(t *testing.T) {
  70. initSubDB(t)
  71. db := database.GetDB()
  72. in := &model.Inbound{Port: 51820, Protocol: model.WireGuard, Enable: true, Tag: "wg-sub", Settings: `{"secretKey":"x","clients":[]}`}
  73. if err := db.Create(in).Error; err != nil {
  74. t.Fatalf("create inbound: %v", err)
  75. }
  76. rec := &model.ClientRecord{Email: "u@wg", SubID: "subwg", Enable: true}
  77. if err := db.Create(rec).Error; err != nil {
  78. t.Fatalf("create client: %v", err)
  79. }
  80. if err := db.Create(&model.ClientInbound{ClientId: rec.Id, InboundId: in.Id}).Error; err != nil {
  81. t.Fatalf("create link: %v", err)
  82. }
  83. s := &SubService{}
  84. inbounds, err := s.getInboundsBySubId("subwg")
  85. if err != nil {
  86. t.Fatalf("getInboundsBySubId: %v", err)
  87. }
  88. if len(inbounds) != 1 || inbounds[0].Id != in.Id {
  89. t.Fatalf("wireguard inbound not returned for subId: %+v", inbounds)
  90. }
  91. }