mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-26 17:08:25 +00:00 
			
		
		
		
	Improve template system and panic recovery (#24461)
Partially for #24457 Major changes: 1. The old `signedUserNameStringPointerKey` is quite hacky, use `ctx.Data[SignedUser]` instead 2. Move duplicate code from `Contexter` to `CommonTemplateContextData` 3. Remove incorrect copying&pasting code `ctx.Data["Err_Password"] = true` in API handlers 4. Use one unique `RenderPanicErrorPage` for panic error page rendering 5. Move `stripSlashesMiddleware` to be the first middleware 6. Install global panic recovery handler, it works for both `install` and `web` 7. Make `500.tmpl` only depend minimal template functions/variables, avoid triggering new panics Screenshot: <details>  </details>
This commit is contained in:
		| @@ -5,43 +5,12 @@ package templates | ||||
|  | ||||
| import ( | ||||
| 	"strings" | ||||
| 	"time" | ||||
|  | ||||
| 	"code.gitea.io/gitea/modules/assetfs" | ||||
| 	"code.gitea.io/gitea/modules/setting" | ||||
| 	"code.gitea.io/gitea/modules/util" | ||||
| ) | ||||
|  | ||||
| // Vars represents variables to be render in golang templates | ||||
| type Vars map[string]interface{} | ||||
|  | ||||
| // Merge merges another vars to the current, another Vars will override the current | ||||
| func (vars Vars) Merge(another map[string]interface{}) Vars { | ||||
| 	for k, v := range another { | ||||
| 		vars[k] = v | ||||
| 	} | ||||
| 	return vars | ||||
| } | ||||
|  | ||||
| // BaseVars returns all basic vars | ||||
| func BaseVars() Vars { | ||||
| 	startTime := time.Now() | ||||
| 	return map[string]interface{}{ | ||||
| 		"IsLandingPageHome":          setting.LandingPageURL == setting.LandingPageHome, | ||||
| 		"IsLandingPageExplore":       setting.LandingPageURL == setting.LandingPageExplore, | ||||
| 		"IsLandingPageOrganizations": setting.LandingPageURL == setting.LandingPageOrganizations, | ||||
|  | ||||
| 		"ShowRegistrationButton":        setting.Service.ShowRegistrationButton, | ||||
| 		"ShowMilestonesDashboardPage":   setting.Service.ShowMilestonesDashboardPage, | ||||
| 		"ShowFooterVersion":             setting.Other.ShowFooterVersion, | ||||
| 		"DisableDownloadSourceArchives": setting.Repository.DisableDownloadSourceArchives, | ||||
|  | ||||
| 		"EnableSwagger":      setting.API.EnableSwagger, | ||||
| 		"EnableOpenIDSignIn": setting.Service.EnableOpenIDSignIn, | ||||
| 		"PageStartTime":      startTime, | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func AssetFS() *assetfs.LayeredFS { | ||||
| 	return assetfs.Layered(CustomAssets(), BuiltinAssets()) | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user