summaryrefslogtreecommitdiff
path: root/packages/backend/src/server
diff options
context:
space:
mode:
authorHazelnoot <acomputerdog@gmail.com>2025-05-04 08:55:57 -0400
committerHazelnoot <acomputerdog@gmail.com>2025-05-04 08:55:57 -0400
commit76597d1a4c7ee04244a35c2c4dcfe6dc5dc85ac1 (patch)
tree25744724758e0e63b240130239694525426f1e90 /packages/backend/src/server
parentuse bucket rate limit for featured timeline (diff)
downloadsharkey-76597d1a4c7ee04244a35c2c4dcfe6dc5dc85ac1.tar.gz
sharkey-76597d1a4c7ee04244a35c2c4dcfe6dc5dc85ac1.tar.bz2
sharkey-76597d1a4c7ee04244a35c2c4dcfe6dc5dc85ac1.zip
check role assignments in featured timeline
Diffstat (limited to 'packages/backend/src/server')
-rw-r--r--packages/backend/src/server/api/endpoints/notes/featured.ts16
1 files changed, 16 insertions, 0 deletions
diff --git a/packages/backend/src/server/api/endpoints/notes/featured.ts b/packages/backend/src/server/api/endpoints/notes/featured.ts
index b5d2a71ecd..02d572e89b 100644
--- a/packages/backend/src/server/api/endpoints/notes/featured.ts
+++ b/packages/backend/src/server/api/endpoints/notes/featured.ts
@@ -12,6 +12,8 @@ import { FeaturedService } from '@/core/FeaturedService.js';
import { isUserRelated } from '@/misc/is-user-related.js';
import { CacheService } from '@/core/CacheService.js';
import { QueryService } from '@/core/QueryService.js';
+import { ApiError } from '@/server/api/error.js';
+import { RoleService } from '@/core/RoleService.js';
export const meta = {
tags: ['notes'],
@@ -30,6 +32,14 @@ export const meta = {
},
},
+ errors: {
+ ltlDisabled: {
+ message: 'Local timeline has been disabled.',
+ code: 'LTL_DISABLED',
+ id: '45a6eb02-7695-4393-b023-dd3be9aaaefd',
+ },
+ },
+
// Burst of 10 calls to handle tab reload, then 4/second for refresh
limit: {
type: 'bucket',
@@ -61,8 +71,14 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-
private noteEntityService: NoteEntityService,
private featuredService: FeaturedService,
private queryService: QueryService,
+ private readonly roleService: RoleService,
) {
super(meta, paramDef, async (ps, me) => {
+ const policies = await this.roleService.getUserPolicies(me ? me.id : null);
+ if (!policies.ltlAvailable) {
+ throw new ApiError(meta.errors.ltlDisabled);
+ }
+
let noteIds: string[];
if (ps.channelId) {
noteIds = await this.featuredService.getInChannelNotesRanking(ps.channelId, 50);