mirror of
https://iceshrimp.dev/limepotato/jormungandr-bite.git
synced 2025-01-25 14:51:31 -07:00
try to fix streaming
This commit is contained in:
parent
42ba2cf94a
commit
9d315aa1e1
1 changed files with 13 additions and 7 deletions
|
@ -2,12 +2,13 @@ import Channel from '../channel.js';
|
||||||
import { fetchMeta } from '@/misc/fetch-meta.js';
|
import { fetchMeta } from '@/misc/fetch-meta.js';
|
||||||
import { checkWordMute } from '@/misc/check-word-mute.js';
|
import { checkWordMute } from '@/misc/check-word-mute.js';
|
||||||
import { isUserRelated } from '@/misc/is-user-related.js';
|
import { isUserRelated } from '@/misc/is-user-related.js';
|
||||||
|
import { isInstanceMuted } from '@/misc/is-instance-muted.js';
|
||||||
import { Packed } from '@/misc/schema.js';
|
import { Packed } from '@/misc/schema.js';
|
||||||
|
|
||||||
export default class extends Channel {
|
export default class extends Channel {
|
||||||
public readonly chName = 'recommendedTimeline';
|
public readonly chName = 'recommendedTimeline';
|
||||||
public static shouldShare = true;
|
public static shouldShare = true;
|
||||||
public static requireCredential = false;
|
public static requireCredential = true;
|
||||||
|
|
||||||
constructor(id: string, connection: Channel['connection']) {
|
constructor(id: string, connection: Channel['connection']) {
|
||||||
super(id, connection);
|
super(id, connection);
|
||||||
|
@ -16,19 +17,24 @@ export default class extends Channel {
|
||||||
|
|
||||||
public async init(params: any) {
|
public async init(params: any) {
|
||||||
const meta = await fetchMeta();
|
const meta = await fetchMeta();
|
||||||
if (meta.disableRecommendedTimeline) {
|
if (meta.disableLocalTimeline && !this.user!.isAdmin && !this.user!.isModerator) return;
|
||||||
if (this.user == null || (!this.user.isAdmin && !this.user.isModerator)) return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Subscribe events
|
// Subscribe events
|
||||||
this.subscriber.on('notesStream', this.onNote);
|
this.subscriber.on('notesStream', this.onNote);
|
||||||
}
|
}
|
||||||
|
|
||||||
private async onNote(note: Packed<'Note'>) {
|
private async onNote(note: Packed<'Note'>) {
|
||||||
|
// チャンネルの投稿ではなく、自分自身の投稿 または
|
||||||
|
// チャンネルの投稿ではなく、その投稿のユーザーをフォローしている または
|
||||||
|
// チャンネルの投稿ではなく、全体公開のローカルの投稿 または
|
||||||
|
// フォローしているチャンネルの投稿 の場合だけ
|
||||||
const meta = await fetchMeta();
|
const meta = await fetchMeta();
|
||||||
if (note.user.host !== null && !meta.recommendedInstances.includes(note.user.host)) return;
|
if (!(
|
||||||
if (note.visibility !== 'public') return;
|
((note.user.host == null || meta.recommendedInstances.includes(note.user.host)) && note.visibility === 'public')
|
||||||
if (note.channelId != null && !this.followingChannels.has(note.channelId)) return;
|
)) return;
|
||||||
|
|
||||||
|
// Ignore notes from instances the user has muted
|
||||||
|
if (isInstanceMuted(note, new Set<string>(this.userProfile?.mutedInstances ?? []))) return;
|
||||||
|
|
||||||
// 関係ない返信は除外
|
// 関係ない返信は除外
|
||||||
if (note.reply && !this.user!.showTimelineReplies) {
|
if (note.reply && !this.user!.showTimelineReplies) {
|
||||||
|
|
Loading…
Reference in a new issue