mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-26 12:01:08 +00:00 
			
		
		
		
	[GITEA] rework long-term authentication
- The current architecture is inherently insecure, because you can construct the 'secret' cookie value with values that are available in the database. Thus provides zero protection when a database is dumped/leaked. - This patch implements a new architecture that's inspired from: [Paragonie Initiative](https://paragonie.com/blog/2015/04/secure-authentication-php-with-long-term-persistence#secure-remember-me-cookies). - Integration testing is added to ensure the new mechanism works. - Removes a setting, because it's not used anymore. (cherry picked from commiteff097448b) [GITEA] rework long-term authentication (squash) add migration Reminder: the migration is run via integration tests as explained in the commit "[DB] run all Forgejo migrations in integration tests" (cherry picked from commit4accf7443c)
This commit is contained in:
		
					parent
					
						
							
								711638193d
							
						
					
				
			
			
				commit
				
					
						a14be197eb
					
				
			
		
					 17 changed files with 365 additions and 154 deletions
				
			
		|  | @ -19,7 +19,6 @@ var ( | |||
| 	SecretKey                          string | ||||
| 	InternalToken                      string // internal access token | ||||
| 	LogInRememberDays                  int | ||||
| 	CookieUserName                     string | ||||
| 	CookieRememberName                 string | ||||
| 	ReverseProxyAuthUser               string | ||||
| 	ReverseProxyAuthEmail              string | ||||
|  | @ -104,7 +103,6 @@ func loadSecurityFrom(rootCfg ConfigProvider) { | |||
| 	sec := rootCfg.Section("security") | ||||
| 	InstallLock = HasInstallLock(rootCfg) | ||||
| 	LogInRememberDays = sec.Key("LOGIN_REMEMBER_DAYS").MustInt(7) | ||||
| 	CookieUserName = sec.Key("COOKIE_USERNAME").MustString("gitea_awesome") | ||||
| 	SecretKey = loadSecret(sec, "SECRET_KEY_URI", "SECRET_KEY") | ||||
| 	if SecretKey == "" { | ||||
| 		// FIXME: https://github.com/go-gitea/gitea/issues/16832 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue