mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-31 21:28:11 +09:00 
			
		
		
		
	Fix all possible setting error related storages and added some tests (#23911)
Follow up #22405 Fix #20703 This PR rewrites storage configuration read sequences with some breaks and tests. It becomes more strict than before and also fixed some inherit problems. - Move storage's MinioConfig struct into setting, so after the configuration loading, the values will be stored into the struct but not still on some section. - All storages configurations should be stored on one section, configuration items cannot be overrided by multiple sections. The prioioty of configuration is `[attachment]` > `[storage.attachments]` | `[storage.customized]` > `[storage]` > `default` - For extra override configuration items, currently are `SERVE_DIRECT`, `MINIO_BASE_PATH`, `MINIO_BUCKET`, which could be configured in another section. The prioioty of the override configuration is `[attachment]` > `[storage.attachments]` > `default`. - Add more tests for storages configurations. - Update the storage documentations. --------- Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
This commit is contained in:
		| @@ -7,7 +7,7 @@ package setting | ||||
|  | ||||
| var ( | ||||
| 	Avatar = struct { | ||||
| 		Storage | ||||
| 		Storage *Storage | ||||
|  | ||||
| 		MaxWidth           int | ||||
| 		MaxHeight          int | ||||
| @@ -27,23 +27,26 @@ var ( | ||||
| 	EnableFederatedAvatar bool // Depreciated: migrated to database | ||||
|  | ||||
| 	RepoAvatar = struct { | ||||
| 		Storage | ||||
| 		Storage *Storage | ||||
|  | ||||
| 		Fallback      string | ||||
| 		FallbackImage string | ||||
| 	}{} | ||||
| ) | ||||
|  | ||||
| func loadPictureFrom(rootCfg ConfigProvider) { | ||||
| func loadAvatarsFrom(rootCfg ConfigProvider) error { | ||||
| 	sec := rootCfg.Section("picture") | ||||
|  | ||||
| 	avatarSec := rootCfg.Section("avatar") | ||||
| 	storageType := sec.Key("AVATAR_STORAGE_TYPE").MustString("") | ||||
| 	// Specifically default PATH to AVATAR_UPLOAD_PATH | ||||
| 	avatarSec.Key("PATH").MustString( | ||||
| 		sec.Key("AVATAR_UPLOAD_PATH").String()) | ||||
| 	avatarSec.Key("PATH").MustString(sec.Key("AVATAR_UPLOAD_PATH").String()) | ||||
|  | ||||
| 	Avatar.Storage = getStorage(rootCfg, "avatars", storageType, avatarSec) | ||||
| 	var err error | ||||
| 	Avatar.Storage, err = getStorage(rootCfg, "avatars", storageType, avatarSec) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	Avatar.MaxWidth = sec.Key("AVATAR_MAX_WIDTH").MustInt(4096) | ||||
| 	Avatar.MaxHeight = sec.Key("AVATAR_MAX_HEIGHT").MustInt(4096) | ||||
| @@ -67,7 +70,7 @@ func loadPictureFrom(rootCfg ConfigProvider) { | ||||
| 	EnableFederatedAvatar = sec.Key("ENABLE_FEDERATED_AVATAR").MustBool(GetDefaultEnableFederatedAvatar(DisableGravatar)) | ||||
| 	deprecatedSettingDB(rootCfg, "", "ENABLE_FEDERATED_AVATAR") | ||||
|  | ||||
| 	loadRepoAvatarFrom(rootCfg) | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func GetDefaultDisableGravatar() bool { | ||||
| @@ -85,17 +88,22 @@ func GetDefaultEnableFederatedAvatar(disableGravatar bool) bool { | ||||
| 	return v | ||||
| } | ||||
|  | ||||
| func loadRepoAvatarFrom(rootCfg ConfigProvider) { | ||||
| func loadRepoAvatarFrom(rootCfg ConfigProvider) error { | ||||
| 	sec := rootCfg.Section("picture") | ||||
|  | ||||
| 	repoAvatarSec := rootCfg.Section("repo-avatar") | ||||
| 	storageType := sec.Key("REPOSITORY_AVATAR_STORAGE_TYPE").MustString("") | ||||
| 	// Specifically default PATH to AVATAR_UPLOAD_PATH | ||||
| 	repoAvatarSec.Key("PATH").MustString( | ||||
| 		sec.Key("REPOSITORY_AVATAR_UPLOAD_PATH").String()) | ||||
| 	repoAvatarSec.Key("PATH").MustString(sec.Key("REPOSITORY_AVATAR_UPLOAD_PATH").String()) | ||||
|  | ||||
| 	RepoAvatar.Storage = getStorage(rootCfg, "repo-avatars", storageType, repoAvatarSec) | ||||
| 	var err error | ||||
| 	RepoAvatar.Storage, err = getStorage(rootCfg, "repo-avatars", storageType, repoAvatarSec) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	RepoAvatar.Fallback = sec.Key("REPOSITORY_AVATAR_FALLBACK").MustString("none") | ||||
| 	RepoAvatar.FallbackImage = sec.Key("REPOSITORY_AVATAR_FALLBACK_IMAGE").MustString(AppSubURL + "/assets/img/repo_default.png") | ||||
|  | ||||
| 	return nil | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user