mirror of
				https://codeberg.org/yeentown/barkey.git
				synced 2025-10-26 11:07:48 +00:00 
			
		
		
		
	check privacy settings in charts/user/following
This commit is contained in:
		
							parent
							
								
									f6964f6e27
								
							
						
					
					
						commit
						7a25ff3d65
					
				
					 1 changed files with 78 additions and 1 deletions
				
			
		|  | @ -8,6 +8,8 @@ import { Endpoint } from '@/server/api/endpoint-base.js'; | ||||||
| import { getJsonSchema } from '@/core/chart/core.js'; | import { getJsonSchema } from '@/core/chart/core.js'; | ||||||
| import PerUserFollowingChart from '@/core/chart/charts/per-user-following.js'; | import PerUserFollowingChart from '@/core/chart/charts/per-user-following.js'; | ||||||
| import { schema } from '@/core/chart/charts/entities/per-user-following.js'; | import { schema } from '@/core/chart/charts/entities/per-user-following.js'; | ||||||
|  | import { CacheService } from '@/core/CacheService.js'; | ||||||
|  | import { RoleService } from '@/core/RoleService.js'; | ||||||
| 
 | 
 | ||||||
| export const meta = { | export const meta = { | ||||||
| 	tags: ['charts', 'users', 'following'], | 	tags: ['charts', 'users', 'following'], | ||||||
|  | @ -40,9 +42,84 @@ export const paramDef = { | ||||||
| export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-disable-line import/no-default-export
 | export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-disable-line import/no-default-export
 | ||||||
| 	constructor( | 	constructor( | ||||||
| 		private perUserFollowingChart: PerUserFollowingChart, | 		private perUserFollowingChart: PerUserFollowingChart, | ||||||
|  | 		private readonly cacheService: CacheService, | ||||||
|  | 		private readonly roleService: RoleService, | ||||||
| 	) { | 	) { | ||||||
| 		super(meta, paramDef, async (ps, me) => { | 		super(meta, paramDef, async (ps, me) => { | ||||||
| 			return await this.perUserFollowingChart.getChart(ps.span, ps.limit, ps.offset ? new Date(ps.offset) : null, ps.userId); | 			const profile = await this.cacheService.userProfileCache.fetch(ps.userId); | ||||||
|  | 
 | ||||||
|  | 			// These are structured weird to avoid un-necessary calls to roleService and cacheService
 | ||||||
|  | 			const iAmModeratorOrTarget = me && (me.id === ps.userId || await this.roleService.isModerator(me)); | ||||||
|  | 			const iAmFollowingOrTarget = me && (me.id === ps.userId || await this.cacheService.isFollowing(me.id, ps.userId)); | ||||||
|  | 
 | ||||||
|  | 			const canViewFollowing = | ||||||
|  | 				profile.followingVisibility === 'public' | ||||||
|  | 				|| iAmModeratorOrTarget | ||||||
|  | 				|| (profile.followingVisibility === 'followers' && iAmFollowingOrTarget); | ||||||
|  | 
 | ||||||
|  | 			const canViewFollowers = | ||||||
|  | 				profile.followersVisibility === 'public' | ||||||
|  | 				|| iAmModeratorOrTarget | ||||||
|  | 				|| (profile.followersVisibility === 'followers' && iAmFollowingOrTarget); | ||||||
|  | 
 | ||||||
|  | 			if (!canViewFollowing && !canViewFollowers) { | ||||||
|  | 				return { | ||||||
|  | 					local: { | ||||||
|  | 						followings: { | ||||||
|  | 							total: [], | ||||||
|  | 							inc: [], | ||||||
|  | 							dec: [], | ||||||
|  | 						}, | ||||||
|  | 						followers: { | ||||||
|  | 							total: [], | ||||||
|  | 							inc: [], | ||||||
|  | 							dec: [], | ||||||
|  | 						}, | ||||||
|  | 					}, | ||||||
|  | 					remote: { | ||||||
|  | 						followings: { | ||||||
|  | 							total: [], | ||||||
|  | 							inc: [], | ||||||
|  | 							dec: [], | ||||||
|  | 						}, | ||||||
|  | 						followers: { | ||||||
|  | 							total: [], | ||||||
|  | 							inc: [], | ||||||
|  | 							dec: [], | ||||||
|  | 						}, | ||||||
|  | 					}, | ||||||
|  | 				}; | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 			const chart = await this.perUserFollowingChart.getChart(ps.span, ps.limit, ps.offset ? new Date(ps.offset) : null, ps.userId); | ||||||
|  | 
 | ||||||
|  | 			if (!canViewFollowers) { | ||||||
|  | 				chart.local.followers = { | ||||||
|  | 					total: [], | ||||||
|  | 					inc: [], | ||||||
|  | 					dec: [], | ||||||
|  | 				}; | ||||||
|  | 				chart.remote.followers = { | ||||||
|  | 					total: [], | ||||||
|  | 					inc: [], | ||||||
|  | 					dec: [], | ||||||
|  | 				}; | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 			if (!canViewFollowing) { | ||||||
|  | 				chart.local.followings = { | ||||||
|  | 					total: [], | ||||||
|  | 					inc: [], | ||||||
|  | 					dec: [], | ||||||
|  | 				}; | ||||||
|  | 				chart.remote.followings = { | ||||||
|  | 					total: [], | ||||||
|  | 					inc: [], | ||||||
|  | 					dec: [], | ||||||
|  | 				}; | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 			return chart; | ||||||
| 		}); | 		}); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue