summaryrefslogtreecommitdiff
path: root/packages/backend/src/server/api
diff options
context:
space:
mode:
authorzyoshoka <107108195+zyoshoka@users.noreply.github.com>2023-11-26 10:05:56 +0900
committerGitHub <noreply@github.com>2023-11-26 10:05:56 +0900
commit2ee48ae04da540384214ff0d7c8df2dfb18c88fc (patch)
tree2a32f6298d23b610134b6bd0fc8414206c9ed0d1 /packages/backend/src/server/api
parentfix(backend): rename FunoutTimelineService to FanoutTimelineService (#12453) (diff)
downloadsharkey-2ee48ae04da540384214ff0d7c8df2dfb18c88fc.tar.gz
sharkey-2ee48ae04da540384214ff0d7c8df2dfb18c88fc.tar.bz2
sharkey-2ee48ae04da540384214ff0d7c8df2dfb18c88fc.zip
fix(backend): ギャラリーの人気の投稿の選出にidを用いるように (#12448)
Diffstat (limited to 'packages/backend/src/server/api')
-rw-r--r--packages/backend/src/server/api/endpoints/gallery/featured.ts35
-rw-r--r--packages/backend/src/server/api/endpoints/gallery/posts/like.ts7
-rw-r--r--packages/backend/src/server/api/endpoints/gallery/posts/unlike.ts10
3 files changed, 47 insertions, 5 deletions
diff --git a/packages/backend/src/server/api/endpoints/gallery/featured.ts b/packages/backend/src/server/api/endpoints/gallery/featured.ts
index cbab3a83a4..cea4234065 100644
--- a/packages/backend/src/server/api/endpoints/gallery/featured.ts
+++ b/packages/backend/src/server/api/endpoints/gallery/featured.ts
@@ -8,6 +8,7 @@ import { Endpoint } from '@/server/api/endpoint-base.js';
import type { GalleryPostsRepository } from '@/models/_.js';
import { GalleryPostEntityService } from '@/core/entities/GalleryPostEntityService.js';
import { DI } from '@/di-symbols.js';
+import { FeaturedService } from '@/core/FeaturedService.js';
export const meta = {
tags: ['gallery'],
@@ -27,25 +28,49 @@ export const meta = {
export const paramDef = {
type: 'object',
- properties: {},
+ properties: {
+ limit: { type: 'integer', minimum: 1, maximum: 100, default: 10 },
+ untilId: { type: 'string', format: 'misskey:id' },
+ },
required: [],
} as const;
@Injectable()
export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-disable-line import/no-default-export
+ private galleryPostsRankingCache: string[] = [];
+ private galleryPostsRankingCacheLastFetchedAt = 0;
+
constructor(
@Inject(DI.galleryPostsRepository)
private galleryPostsRepository: GalleryPostsRepository,
private galleryPostEntityService: GalleryPostEntityService,
+ private featuredService: FeaturedService,
) {
super(meta, paramDef, async (ps, me) => {
+ let postIds: string[];
+ if (this.galleryPostsRankingCacheLastFetchedAt !== 0 && (Date.now() - this.galleryPostsRankingCacheLastFetchedAt < 1000 * 60 * 30)) {
+ postIds = this.galleryPostsRankingCache;
+ } else {
+ postIds = await this.featuredService.getGalleryPostsRanking(100);
+ this.galleryPostsRankingCache = postIds;
+ this.galleryPostsRankingCacheLastFetchedAt = Date.now();
+ }
+
+ postIds.sort((a, b) => a > b ? -1 : 1);
+ if (ps.untilId) {
+ postIds = postIds.filter(id => id < ps.untilId!);
+ }
+ postIds = postIds.slice(0, ps.limit);
+
+ if (postIds.length === 0) {
+ return [];
+ }
+
const query = this.galleryPostsRepository.createQueryBuilder('post')
- .andWhere('post.createdAt > :date', { date: new Date(Date.now() - (1000 * 60 * 60 * 24 * 3)) })
- .andWhere('post.likedCount > 0')
- .orderBy('post.likedCount', 'DESC');
+ .where('post.id IN (:...postIds)', { postIds: postIds });
- const posts = await query.limit(10).getMany();
+ const posts = await query.getMany();
return await this.galleryPostEntityService.packMany(posts, me);
});
diff --git a/packages/backend/src/server/api/endpoints/gallery/posts/like.ts b/packages/backend/src/server/api/endpoints/gallery/posts/like.ts
index 561b2492ab..cc424261b4 100644
--- a/packages/backend/src/server/api/endpoints/gallery/posts/like.ts
+++ b/packages/backend/src/server/api/endpoints/gallery/posts/like.ts
@@ -6,6 +6,7 @@
import { Inject, Injectable } from '@nestjs/common';
import { Endpoint } from '@/server/api/endpoint-base.js';
import type { GalleryLikesRepository, GalleryPostsRepository } from '@/models/_.js';
+import { FeaturedService, GALLERY_POSTS_RANKING_WINDOW } from '@/core/FeaturedService.js';
import { IdService } from '@/core/IdService.js';
import { DI } from '@/di-symbols.js';
import { ApiError } from '../../../error.js';
@@ -57,6 +58,7 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-
@Inject(DI.galleryLikesRepository)
private galleryLikesRepository: GalleryLikesRepository,
+ private featuredService: FeaturedService,
private idService: IdService,
) {
super(meta, paramDef, async (ps, me) => {
@@ -88,6 +90,11 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-
userId: me.id,
});
+ // ランキング更新
+ if (Date.now() - this.idService.parse(post.id).date.getTime() < GALLERY_POSTS_RANKING_WINDOW) {
+ await this.featuredService.updateGalleryPostsRanking(post.id, 1);
+ }
+
this.galleryPostsRepository.increment({ id: post.id }, 'likedCount', 1);
});
}
diff --git a/packages/backend/src/server/api/endpoints/gallery/posts/unlike.ts b/packages/backend/src/server/api/endpoints/gallery/posts/unlike.ts
index 832b62282f..caa4d45553 100644
--- a/packages/backend/src/server/api/endpoints/gallery/posts/unlike.ts
+++ b/packages/backend/src/server/api/endpoints/gallery/posts/unlike.ts
@@ -6,6 +6,8 @@
import { Inject, Injectable } from '@nestjs/common';
import { Endpoint } from '@/server/api/endpoint-base.js';
import type { GalleryPostsRepository, GalleryLikesRepository } from '@/models/_.js';
+import { FeaturedService, GALLERY_POSTS_RANKING_WINDOW } from '@/core/FeaturedService.js';
+import { IdService } from '@/core/IdService.js';
import { DI } from '@/di-symbols.js';
import { ApiError } from '../../../error.js';
@@ -49,6 +51,9 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-
@Inject(DI.galleryLikesRepository)
private galleryLikesRepository: GalleryLikesRepository,
+
+ private featuredService: FeaturedService,
+ private idService: IdService,
) {
super(meta, paramDef, async (ps, me) => {
const post = await this.galleryPostsRepository.findOneBy({ id: ps.postId });
@@ -68,6 +73,11 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-
// Delete like
await this.galleryLikesRepository.delete(exist.id);
+ // ランキング更新
+ if (Date.now() - this.idService.parse(post.id).date.getTime() < GALLERY_POSTS_RANKING_WINDOW) {
+ await this.featuredService.updateGalleryPostsRanking(post.id, -1);
+ }
+
this.galleryPostsRepository.decrement({ id: post.id }, 'likedCount', 1);
});
}