Reset locale on login (#17734)
When logging in reset the user's locale to ensure that it matches their preferred locale. Fix #15612 Signed-off-by: Andrew Thornton <art27@cantab.net>
This commit is contained in:
		
							parent
							
								
									f8ec43dbc7
								
							
						
					
					
						commit
						0fa41b6dc4
					
				| @ -245,6 +245,9 @@ func APIAuth(authMethod auth.Method) func(*APIContext) { | |||||||
| 		// Get user from session if logged in.
 | 		// Get user from session if logged in.
 | ||||||
| 		ctx.User = authMethod.Verify(ctx.Req, ctx.Resp, ctx, ctx.Session) | 		ctx.User = authMethod.Verify(ctx.Req, ctx.Resp, ctx, ctx.Session) | ||||||
| 		if ctx.User != nil { | 		if ctx.User != nil { | ||||||
|  | 			if ctx.Locale.Language() != ctx.User.Language { | ||||||
|  | 				ctx.Locale = middleware.Locale(ctx.Resp, ctx.Req) | ||||||
|  | 			} | ||||||
| 			ctx.IsBasicAuth = ctx.Data["AuthedMethod"].(string) == auth.BasicMethodName | 			ctx.IsBasicAuth = ctx.Data["AuthedMethod"].(string) == auth.BasicMethodName | ||||||
| 			ctx.IsSigned = true | 			ctx.IsSigned = true | ||||||
| 			ctx.Data["IsSigned"] = ctx.IsSigned | 			ctx.Data["IsSigned"] = ctx.IsSigned | ||||||
|  | |||||||
| @ -614,6 +614,9 @@ func Auth(authMethod auth.Method) func(*Context) { | |||||||
| 	return func(ctx *Context) { | 	return func(ctx *Context) { | ||||||
| 		ctx.User = authMethod.Verify(ctx.Req, ctx.Resp, ctx, ctx.Session) | 		ctx.User = authMethod.Verify(ctx.Req, ctx.Resp, ctx, ctx.Session) | ||||||
| 		if ctx.User != nil { | 		if ctx.User != nil { | ||||||
|  | 			if ctx.Locale.Language() != ctx.User.Language { | ||||||
|  | 				ctx.Locale = middleware.Locale(ctx.Resp, ctx.Req) | ||||||
|  | 			} | ||||||
| 			ctx.IsBasicAuth = ctx.Data["AuthedMethod"].(string) == auth.BasicMethodName | 			ctx.IsBasicAuth = ctx.Data["AuthedMethod"].(string) == auth.BasicMethodName | ||||||
| 			ctx.IsSigned = true | 			ctx.IsSigned = true | ||||||
| 			ctx.Data["IsSigned"] = ctx.IsSigned | 			ctx.Data["IsSigned"] = ctx.IsSigned | ||||||
|  | |||||||
| @ -572,6 +572,10 @@ func handleSignInFull(ctx *context.Context, u *models.User, remember bool, obeyR | |||||||
| 
 | 
 | ||||||
| 	middleware.SetLocaleCookie(ctx.Resp, u.Language, 0) | 	middleware.SetLocaleCookie(ctx.Resp, u.Language, 0) | ||||||
| 
 | 
 | ||||||
|  | 	if ctx.Locale.Language() != u.Language { | ||||||
|  | 		ctx.Locale = middleware.Locale(ctx.Resp, ctx.Req) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	// Clear whatever CSRF has right now, force to generate a new one
 | 	// Clear whatever CSRF has right now, force to generate a new one
 | ||||||
| 	middleware.DeleteCSRFCookie(ctx.Resp) | 	middleware.DeleteCSRFCookie(ctx.Resp) | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user