You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

migrate_test.go 4.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. // Copyright 2019 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package migrations
  4. import (
  5. "net"
  6. "path/filepath"
  7. "testing"
  8. "code.gitea.io/gitea/models/unittest"
  9. user_model "code.gitea.io/gitea/models/user"
  10. "code.gitea.io/gitea/modules/setting"
  11. "github.com/stretchr/testify/assert"
  12. )
  13. func TestMigrateWhiteBlocklist(t *testing.T) {
  14. assert.NoError(t, unittest.PrepareTestDatabase())
  15. adminUser := unittest.AssertExistsAndLoadBean(t, &user_model.User{Name: "user1"})
  16. nonAdminUser := unittest.AssertExistsAndLoadBean(t, &user_model.User{Name: "user2"})
  17. setting.Migrations.AllowedDomains = "github.com"
  18. setting.Migrations.AllowLocalNetworks = false
  19. assert.NoError(t, Init())
  20. err := IsMigrateURLAllowed("https://gitlab.com/gitlab/gitlab.git", nonAdminUser)
  21. assert.Error(t, err)
  22. err = IsMigrateURLAllowed("https://github.com/go-gitea/gitea.git", nonAdminUser)
  23. assert.NoError(t, err)
  24. err = IsMigrateURLAllowed("https://gITHUb.com/go-gitea/gitea.git", nonAdminUser)
  25. assert.NoError(t, err)
  26. setting.Migrations.AllowedDomains = ""
  27. setting.Migrations.BlockedDomains = "github.com"
  28. assert.NoError(t, Init())
  29. err = IsMigrateURLAllowed("https://gitlab.com/gitlab/gitlab.git", nonAdminUser)
  30. assert.NoError(t, err)
  31. err = IsMigrateURLAllowed("https://github.com/go-gitea/gitea.git", nonAdminUser)
  32. assert.Error(t, err)
  33. err = IsMigrateURLAllowed("https://10.0.0.1/go-gitea/gitea.git", nonAdminUser)
  34. assert.Error(t, err)
  35. setting.Migrations.AllowLocalNetworks = true
  36. assert.NoError(t, Init())
  37. err = IsMigrateURLAllowed("https://10.0.0.1/go-gitea/gitea.git", nonAdminUser)
  38. assert.NoError(t, err)
  39. old := setting.ImportLocalPaths
  40. setting.ImportLocalPaths = false
  41. err = IsMigrateURLAllowed("/home/foo/bar/goo", adminUser)
  42. assert.Error(t, err)
  43. setting.ImportLocalPaths = true
  44. abs, err := filepath.Abs(".")
  45. assert.NoError(t, err)
  46. err = IsMigrateURLAllowed(abs, adminUser)
  47. assert.NoError(t, err)
  48. err = IsMigrateURLAllowed(abs, nonAdminUser)
  49. assert.Error(t, err)
  50. nonAdminUser.AllowImportLocal = true
  51. err = IsMigrateURLAllowed(abs, nonAdminUser)
  52. assert.NoError(t, err)
  53. setting.ImportLocalPaths = old
  54. }
  55. func TestAllowBlockList(t *testing.T) {
  56. init := func(allow, block string, local bool) {
  57. setting.Migrations.AllowedDomains = allow
  58. setting.Migrations.BlockedDomains = block
  59. setting.Migrations.AllowLocalNetworks = local
  60. assert.NoError(t, Init())
  61. }
  62. // default, allow all external, block none, no local networks
  63. init("", "", false)
  64. assert.NoError(t, checkByAllowBlockList("domain.com", []net.IP{net.ParseIP("1.2.3.4")}))
  65. assert.Error(t, checkByAllowBlockList("domain.com", []net.IP{net.ParseIP("127.0.0.1")}))
  66. // allow all including local networks (it could lead to SSRF in production)
  67. init("", "", true)
  68. assert.NoError(t, checkByAllowBlockList("domain.com", []net.IP{net.ParseIP("1.2.3.4")}))
  69. assert.NoError(t, checkByAllowBlockList("domain.com", []net.IP{net.ParseIP("127.0.0.1")}))
  70. // allow wildcard, block some subdomains. if the domain name is allowed, then the local network check is skipped
  71. init("*.domain.com", "blocked.domain.com", false)
  72. assert.NoError(t, checkByAllowBlockList("sub.domain.com", []net.IP{net.ParseIP("1.2.3.4")}))
  73. assert.NoError(t, checkByAllowBlockList("sub.domain.com", []net.IP{net.ParseIP("127.0.0.1")}))
  74. assert.Error(t, checkByAllowBlockList("blocked.domain.com", []net.IP{net.ParseIP("1.2.3.4")}))
  75. assert.Error(t, checkByAllowBlockList("sub.other.com", []net.IP{net.ParseIP("1.2.3.4")}))
  76. // allow wildcard (it could lead to SSRF in production)
  77. init("*", "", false)
  78. assert.NoError(t, checkByAllowBlockList("domain.com", []net.IP{net.ParseIP("1.2.3.4")}))
  79. assert.NoError(t, checkByAllowBlockList("domain.com", []net.IP{net.ParseIP("127.0.0.1")}))
  80. // local network can still be blocked
  81. init("*", "127.0.0.*", false)
  82. assert.NoError(t, checkByAllowBlockList("domain.com", []net.IP{net.ParseIP("1.2.3.4")}))
  83. assert.Error(t, checkByAllowBlockList("domain.com", []net.IP{net.ParseIP("127.0.0.1")}))
  84. // reset
  85. init("", "", false)
  86. }