mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-26 08:58:24 +00:00 
			
		
		
		
	Display deprecated warning in admin panel pages as well as in the log file (#26094)
This PR includes #26007 's changes but have a UI to prompt administrator about the deprecated settings as well as the log or console warning. Then users will have enough time to notice the problem and don't have surprise like before. <img width="1293" alt="图片" src="https://github.com/go-gitea/gitea/assets/81045/c33355f0-1ea7-4fb3-ad43-cd23cd15391d"> --------- Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
This commit is contained in:
		| @@ -316,15 +316,14 @@ func mustMapSetting(rootCfg ConfigProvider, sectionName string, setting any) { | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // DeprecatedWarnings contains the warning message for various deprecations, including: setting option, file/folder, etc | ||||
| var DeprecatedWarnings []string | ||||
|  | ||||
| func deprecatedSetting(rootCfg ConfigProvider, oldSection, oldKey, newSection, newKey, version string) { | ||||
| 	if rootCfg.Section(oldSection).HasKey(oldKey) { | ||||
| 		log.Error("Deprecated fallback `[%s]` `%s` present. Use `[%s]` `%s` instead. This fallback will be/has been removed in %s", oldSection, oldKey, newSection, newKey, version) | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func deprecatedSettingFatal(rootCfg ConfigProvider, oldSection, oldKey, newSection, newKey, version string) { | ||||
| 	if rootCfg.Section(oldSection).HasKey(oldKey) { | ||||
| 		log.Fatal("Deprecated fallback `[%s]` `%s` present. Use `[%s]` `%s` instead. This fallback will be/has been removed in %s. Shutting down", oldSection, oldKey, newSection, newKey, version) | ||||
| 		msg := fmt.Sprintf("Deprecated config option `[%s]` `%s` present. Use `[%s]` `%s` instead. This fallback will be/has been removed in %s", oldSection, oldKey, newSection, newKey, version) | ||||
| 		log.Error("%v", msg) | ||||
| 		DeprecatedWarnings = append(DeprecatedWarnings, msg) | ||||
| 	} | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -34,7 +34,14 @@ func loadLFSFrom(rootCfg ConfigProvider) error { | ||||
| 	// Specifically default PATH to LFS_CONTENT_PATH | ||||
| 	// DEPRECATED should not be removed because users maybe upgrade from lower version to the latest version | ||||
| 	// if these are removed, the warning will not be shown | ||||
| 	deprecatedSettingFatal(rootCfg, "server", "LFS_CONTENT_PATH", "lfs", "PATH", "v1.19.0") | ||||
| 	deprecatedSetting(rootCfg, "server", "LFS_CONTENT_PATH", "lfs", "PATH", "v1.19.0") | ||||
|  | ||||
| 	if val := sec.Key("LFS_CONTENT_PATH").String(); val != "" { | ||||
| 		if lfsSec == nil { | ||||
| 			lfsSec = rootCfg.Section("lfs") | ||||
| 		} | ||||
| 		lfsSec.Key("PATH").MustString(val) | ||||
| 	} | ||||
|  | ||||
| 	var err error | ||||
| 	LFS.Storage, err = getStorage(rootCfg, "lfs", "", lfsSec) | ||||
|   | ||||
| @@ -21,6 +21,30 @@ func Test_getStorageInheritNameSectionTypeForLFS(t *testing.T) { | ||||
| 	assert.EqualValues(t, "minio", LFS.Storage.Type) | ||||
| 	assert.EqualValues(t, "lfs/", LFS.Storage.MinioConfig.BasePath) | ||||
|  | ||||
| 	iniStr = ` | ||||
| [server] | ||||
| LFS_CONTENT_PATH = path_ignored | ||||
| [lfs] | ||||
| PATH = path_used | ||||
| ` | ||||
| 	cfg, err = NewConfigProviderFromData(iniStr) | ||||
| 	assert.NoError(t, err) | ||||
| 	assert.NoError(t, loadLFSFrom(cfg)) | ||||
|  | ||||
| 	assert.EqualValues(t, "local", LFS.Storage.Type) | ||||
| 	assert.Contains(t, LFS.Storage.Path, "path_used") | ||||
|  | ||||
| 	iniStr = ` | ||||
| [server] | ||||
| LFS_CONTENT_PATH = deprecatedpath | ||||
| ` | ||||
| 	cfg, err = NewConfigProviderFromData(iniStr) | ||||
| 	assert.NoError(t, err) | ||||
| 	assert.NoError(t, loadLFSFrom(cfg)) | ||||
|  | ||||
| 	assert.EqualValues(t, "local", LFS.Storage.Type) | ||||
| 	assert.Contains(t, LFS.Storage.Path, "deprecatedpath") | ||||
|  | ||||
| 	iniStr = ` | ||||
| [storage.lfs] | ||||
| STORAGE_TYPE = minio | ||||
|   | ||||
		Reference in New Issue
	
	Block a user