mirror of
				https://codeberg.org/yeentown/barkey.git
				synced 2025-10-23 09:44:51 +00:00 
			
		
		
		
	don't trend notes from non-explorable or non-trendable users
This commit is contained in:
		
							parent
							
								
									0b8c101d71
								
							
						
					
					
						commit
						dee2e19b63
					
				
					 3 changed files with 33 additions and 21 deletions
				
			
		|  | @ -633,7 +633,7 @@ export class NoteCreateService implements OnApplicationShutdown { | |||
| 		} | ||||
| 
 | ||||
| 		if (this.isRenote(data) && !this.isQuote(data) && data.renote.userId !== user.id && !user.isBot) { | ||||
| 			this.incRenoteCount(data.renote); | ||||
| 			this.incRenoteCount(data.renote, user); | ||||
| 		} | ||||
| 
 | ||||
| 		if (data.poll && data.poll.expiresAt) { | ||||
|  | @ -816,8 +816,8 @@ export class NoteCreateService implements OnApplicationShutdown { | |||
| 	} | ||||
| 
 | ||||
| 	@bindThis | ||||
| 	private incRenoteCount(renote: MiNote) { | ||||
| 		this.notesRepository.createQueryBuilder().update() | ||||
| 	private async incRenoteCount(renote: MiNote, user: MiUser) { | ||||
| 		await this.notesRepository.createQueryBuilder().update() | ||||
| 			.set({ | ||||
| 				renoteCount: () => '"renoteCount" + 1', | ||||
| 			}) | ||||
|  | @ -825,7 +825,9 @@ export class NoteCreateService implements OnApplicationShutdown { | |||
| 			.execute(); | ||||
| 
 | ||||
| 		// 30%の確率、3日以内に投稿されたノートの場合ハイライト用ランキング更新
 | ||||
| 		if (Math.random() < 0.3 && (Date.now() - this.idService.parse(renote.id).date.getTime()) < 1000 * 60 * 60 * 24 * 3) { | ||||
| 		if (user.isExplorable && Math.random() < 0.3 && (Date.now() - this.idService.parse(renote.id).date.getTime()) < 1000 * 60 * 60 * 24 * 3) { | ||||
| 			const policies = await this.roleService.getUserPolicies(user); | ||||
| 			if (policies.canTrend) { | ||||
| 				if (renote.channelId != null) { | ||||
| 					if (renote.replyId == null) { | ||||
| 						this.featuredService.updateInChannelNotesRanking(renote.channelId, renote, 5); | ||||
|  | @ -838,6 +840,7 @@ export class NoteCreateService implements OnApplicationShutdown { | |||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	@bindThis | ||||
| 	private async createMentionedEvents(mentionedUsers: MinimumUser[], note: MiNote, nm: NotificationManager) { | ||||
|  |  | |||
|  | @ -30,6 +30,7 @@ import { trackPromise } from '@/misc/promise-tracker.js'; | |||
| import { isQuote, isRenote } from '@/misc/is-renote.js'; | ||||
| import { ReactionsBufferingService } from '@/core/ReactionsBufferingService.js'; | ||||
| import { PER_NOTE_REACTION_USER_PAIR_CACHE_MAX } from '@/const.js'; | ||||
| import { CacheService } from '@/core/CacheService.js'; | ||||
| 
 | ||||
| const FALLBACK = '\u2764'; | ||||
| 
 | ||||
|  | @ -102,6 +103,7 @@ export class ReactionService { | |||
| 		private apDeliverManagerService: ApDeliverManagerService, | ||||
| 		private notificationService: NotificationService, | ||||
| 		private perUserReactionsChart: PerUserReactionsChart, | ||||
| 		private readonly cacheService: CacheService, | ||||
| 	) { | ||||
| 	} | ||||
| 
 | ||||
|  | @ -220,6 +222,10 @@ export class ReactionService { | |||
| 			note.userId !== user.id && | ||||
| 			(Date.now() - this.idService.parse(note.id).date.getTime()) < 1000 * 60 * 60 * 24 * 3 | ||||
| 		) { | ||||
| 			const author = await this.cacheService.findUserById(note.userId); | ||||
| 			if (author.isExplorable) { | ||||
| 				const policies = await this.roleService.getUserPolicies(author); | ||||
| 				if (policies.canTrend) { | ||||
| 					if (note.channelId != null) { | ||||
| 						if (note.replyId == null) { | ||||
| 							this.featuredService.updateInChannelNotesRanking(note.channelId, note, 1); | ||||
|  | @ -231,6 +237,8 @@ export class ReactionService { | |||
| 						} | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		if (this.meta.enableChartsForRemoteUser || (user.host == null)) { | ||||
| 			this.perUserReactionsChart.update(user, note); | ||||
|  |  | |||
|  | @ -117,7 +117,8 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint- | |||
| 				.leftJoinAndSelect('note.renote', 'renote') | ||||
| 				.leftJoinAndSelect('reply.user', 'replyUser') | ||||
| 				.leftJoinAndSelect('renote.user', 'renoteUser') | ||||
| 				.leftJoinAndSelect('note.channel', 'channel'); | ||||
| 				.leftJoinAndSelect('note.channel', 'channel') | ||||
| 				.andWhere('user.isExplorable = TRUE'); | ||||
| 
 | ||||
| 			this.queryService.generateBlockedHostQueryForNote(query); | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue