mirror of
				https://codeberg.org/yeentown/barkey.git
				synced 2025-11-03 23:14:13 +00:00 
			
		
		
		
	`/users/:user`, `/@:user`, `/notes/:note` return different responses depending on the request's `Accept:` header. If we don't consistently return a `Vary: Accept` header, browsers and caching proxies will get confused, and return AP representations when HTML was requested, or vice versa. Co-authored-by: dakkar <dakkar@thenautilus.net> Co-authored-by: syuilo <Syuilotan@yahoo.co.jp>
This commit is contained in:
		
							parent
							
								
									4c87e98e12
								
							
						
					
					
						commit
						fb309f3d4f
					
				
					 2 changed files with 8 additions and 0 deletions
				
			
		| 
						 | 
				
			
			@ -648,6 +648,8 @@ export class ActivityPubServerService {
 | 
			
		|||
		});
 | 
			
		||||
 | 
			
		||||
		fastify.get<{ Params: { user: string; } }>('/users/:user', { constraints: { apOrHtml: 'ap' } }, async (request, reply) => {
 | 
			
		||||
			vary(reply.raw, 'Accept');
 | 
			
		||||
 | 
			
		||||
			const userId = request.params.user;
 | 
			
		||||
 | 
			
		||||
			const user = await this.usersRepository.findOneBy({
 | 
			
		||||
| 
						 | 
				
			
			@ -660,6 +662,8 @@ export class ActivityPubServerService {
 | 
			
		|||
		});
 | 
			
		||||
 | 
			
		||||
		fastify.get<{ Params: { user: string; } }>('/@:user', { constraints: { apOrHtml: 'ap' } }, async (request, reply) => {
 | 
			
		||||
			vary(reply.raw, 'Accept');
 | 
			
		||||
 | 
			
		||||
			const user = await this.usersRepository.findOneBy({
 | 
			
		||||
				usernameLower: request.params.user.toLowerCase(),
 | 
			
		||||
				host: IsNull(),
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -476,6 +476,8 @@ export class ClientServerService {
 | 
			
		|||
				isSuspended: false,
 | 
			
		||||
			});
 | 
			
		||||
 | 
			
		||||
			vary(reply.raw, 'Accept');
 | 
			
		||||
 | 
			
		||||
			if (user != null) {
 | 
			
		||||
				const profile = await this.userProfilesRepository.findOneByOrFail({ userId: user.id });
 | 
			
		||||
				const meta = await this.metaService.fetch();
 | 
			
		||||
| 
						 | 
				
			
			@ -515,6 +517,8 @@ export class ClientServerService {
 | 
			
		|||
				return;
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
			vary(reply.raw, 'Accept');
 | 
			
		||||
 | 
			
		||||
			reply.redirect(`/@${user.username}${ user.host == null ? '' : '@' + user.host}`);
 | 
			
		||||
		});
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		
		Reference in a new issue