* packedNotificationSchemaを更新 * read:gallery, write:gallery, read:gallery-likes, write:gallery-likesに翻訳を追加 * fix * add header, choice, invitation * test * fix * yatta * remove no longer needed "as PackedUser/PackedNote" * clean up * add simple-schema * fix lint * define items in full Schema * revert https://github.com/misskey-dev/misskey/pull/7772#discussion_r706627736 * user packとnote packの型不整合を修正 * add prelude/types.ts * emoji * signin * game * matching * fix * add emoji schema * add reversiGame * add reversiMatching * remove signin schema (use Signin entity) * add Packed type * note-reaction * user * user-group * user-list * note * app, messaging-message * notification * drive-file * drive-folder * following * muting * blocking * hashtag * page * app (with modifying schema) * import user? * channel * antenna * clip * gallery-post * emoji * Packed * reversi-matching * add changelog * add changelog * revert fix
93 lines
2.4 KiB
TypeScript
93 lines
2.4 KiB
TypeScript
import autobind from 'autobind-decorator';
|
|
import Channel from '../channel';
|
|
import { Notes, UserListJoinings, UserLists } from '@/models/index';
|
|
import { isMutedUserRelated } from '@/misc/is-muted-user-related';
|
|
import { User } from '@/models/entities/user';
|
|
import { isBlockerUserRelated } from '@/misc/is-blocker-user-related';
|
|
import { Packed } from '@/misc/schema';
|
|
|
|
export default class extends Channel {
|
|
public readonly chName = 'userList';
|
|
public static shouldShare = false;
|
|
public static requireCredential = false;
|
|
private listId: string;
|
|
public listUsers: User['id'][] = [];
|
|
private listUsersClock: NodeJS.Timer;
|
|
|
|
@autobind
|
|
public async init(params: any) {
|
|
this.listId = params.listId as string;
|
|
|
|
// Check existence and owner
|
|
const list = await UserLists.findOne({
|
|
id: this.listId,
|
|
userId: this.user!.id
|
|
});
|
|
if (!list) return;
|
|
|
|
// Subscribe stream
|
|
this.subscriber.on(`userListStream:${this.listId}`, this.send);
|
|
|
|
this.subscriber.on('notesStream', this.onNote);
|
|
|
|
this.updateListUsers();
|
|
this.listUsersClock = setInterval(this.updateListUsers, 5000);
|
|
}
|
|
|
|
@autobind
|
|
private async updateListUsers() {
|
|
const users = await UserListJoinings.find({
|
|
where: {
|
|
userListId: this.listId,
|
|
},
|
|
select: ['userId']
|
|
});
|
|
|
|
this.listUsers = users.map(x => x.userId);
|
|
}
|
|
|
|
@autobind
|
|
private async onNote(note: Packed<'Note'>) {
|
|
if (!this.listUsers.includes(note.userId)) return;
|
|
|
|
if (['followers', 'specified'].includes(note.visibility)) {
|
|
note = await Notes.pack(note.id, this.user, {
|
|
detail: true
|
|
});
|
|
|
|
if (note.isHidden) {
|
|
return;
|
|
}
|
|
} else {
|
|
// リプライなら再pack
|
|
if (note.replyId != null) {
|
|
note.reply = await Notes.pack(note.replyId, this.user, {
|
|
detail: true
|
|
});
|
|
}
|
|
// Renoteなら再pack
|
|
if (note.renoteId != null) {
|
|
note.renote = await Notes.pack(note.renoteId, this.user, {
|
|
detail: true
|
|
});
|
|
}
|
|
}
|
|
|
|
// 流れてきたNoteがミュートしているユーザーが関わるものだったら無視する
|
|
if (isMutedUserRelated(note, this.muting)) return;
|
|
// 流れてきたNoteがブロックされているユーザーが関わるものだったら無視する
|
|
if (isBlockerUserRelated(note, this.blocking)) return;
|
|
|
|
this.send('note', note);
|
|
}
|
|
|
|
@autobind
|
|
public dispose() {
|
|
// Unsubscribe events
|
|
this.subscriber.off(`userListStream:${this.listId}`, this.send);
|
|
this.subscriber.off('notesStream', this.onNote);
|
|
|
|
clearInterval(this.listUsersClock);
|
|
}
|
|
}
|