add main stream

This commit is contained in:
tamaina 2021-09-06 00:55:40 +09:00
parent 08576c49de
commit 06c0373be9
3 changed files with 55 additions and 27 deletions

View file

@ -11,35 +11,34 @@ export default class extends Channel {
public async init(params: any) { public async init(params: any) {
// Subscribe main stream channel // Subscribe main stream channel
this.subscriber.on(`mainStream:${this.user!.id}`, async data => { this.subscriber.on(`mainStream:${this.user!.id}`, async data => {
const { type } = data; switch (data.type) {
let { body } = data;
switch (type) {
case 'notification': { case 'notification': {
if (this.muting.has(body.userId)) return; if (data.body.userId && this.muting.has(data.body.userId)) return;
if (body.note && body.note.isHidden) {
const note = await Notes.pack(body.note.id, this.user, { // ????
if (data.body.note && data.body.note.isHidden) {
const note = await Notes.pack(data.body.note.id, this.user, {
detail: true detail: true
}); });
this.connection.cacheNote(note); this.connection.cacheNote(note);
body.note = note; data.body.note = note;
} }
break; break;
} }
case 'mention': { case 'mention': {
if (this.muting.has(body.userId)) return; if (this.muting.has(data.body.userId)) return;
if (body.isHidden) { if (data.body.isHidden) {
const note = await Notes.pack(body.id, this.user, { const note = await Notes.pack(data.body.id, this.user, {
detail: true detail: true
}); });
this.connection.cacheNote(note); this.connection.cacheNote(note);
body = note; data.body = note;
} }
break; break;
} }
} }
this.send(type, body); this.send(data.type, data.body);
}); });
} }
} }

View file

@ -15,7 +15,7 @@ import { UserProfile } from '@/models/entities/user-profile';
import { publishChannelStream, publishGroupMessagingStream, publishMessagingStream } from '@/services/stream'; import { publishChannelStream, publishGroupMessagingStream, publishMessagingStream } from '@/services/stream';
import { UserGroup } from '@/models/entities/user-group'; import { UserGroup } from '@/models/entities/user-group';
import { PackedNote } from '@/models/repositories/note'; import { PackedNote } from '@/models/repositories/note';
import { StreamEventEmitter, UserEvent } from './types'; import { StreamEventEmitter, UserEvents } from './types';
/** /**
* Main stream connection * Main stream connection
@ -65,7 +65,7 @@ export default class Connection {
} }
@autobind @autobind
private onUserEvent(ev: UserEvent) { // { type, body }と展開すると型も展開されてしまう private onUserEvent(ev: UserEvents) { // { type, body }と展開すると型も展開されてしまう
switch (ev.type) { switch (ev.type) {
case 'follow': case 'follow':
this.following.add(ev.body.id); this.following.add(ev.body.id);

View file

@ -5,6 +5,8 @@ import StreamTypes from 'misskey-js/built/streaming.types';
import { Channel } from '@/models/entities/channel'; import { Channel } from '@/models/entities/channel';
import { UserProfile } from '@/models/entities/user-profile'; import { UserProfile } from '@/models/entities/user-profile';
import { PackedUser } from '@/models/repositories/user'; import { PackedUser } from '@/models/repositories/user';
import { PackedNotification } from '@/models/repositories/notification';
import { PackedNote } from '@/models/repositories/note';
type Payload<T extends (payload: any) => void> = T extends (payload: infer P) => void ? P : never; type Payload<T extends (payload: any) => void> = T extends (payload: infer P) => void ? P : never;
@ -14,11 +16,12 @@ type EventUnionFromDictionary<
U = { [K in keyof T]: { type: K; body: T[K]} } U = { [K in keyof T]: { type: K; body: T[K]} }
> = U[keyof U]; > = U[keyof U];
export type BroadcastStream<T extends keyof StreamTypes.BroadcasrEvents> = { type EventUnionFromMkJSTypes<
name: 'broadcast'; T extends { [key: string]: ((payload: any) => void) | (() => void) },
type: T; U = { [K in keyof T]: { type: K; body: Payload<T[K]>} }
body: Payload<StreamTypes.BroadcasrEvents[T]>; > = U[keyof U]
};
export type BroadcastStream = EventUnionFromMkJSTypes<StreamTypes.BroadcasrEvents>;
export interface UserEventTypes { export interface UserEventTypes {
terminate: {}; terminate: {};
@ -31,19 +34,45 @@ export interface UserEventTypes {
unfollow: PackedUser; unfollow: PackedUser;
userAdded: PackedUser; userAdded: PackedUser;
}; };
// UserList userRemoved: PackedUser;
export type UserEventName = `user:${User['id']}`; export type UserEventName = `user:${User['id']}`;
export type UserEvent = EventUnionFromDictionary<UserEventTypes>; export type UserEvents = EventUnionFromDictionary<UserEventTypes>;
export interface mainStreamTypes {
notification: PackedNotification;
mention: PackedNote;
reply: PackedNote;
renote: PackedNote;
follow: PackedUser;
followed: PackedUser;
unfollow: PackedUser;
meUpdated: PackedUser;
pageEvent: Payload<StreamTypes.Channels['main']['events']['pageEvent']>;
urlUploadFinished: Payload<StreamTypes.Channels['main']['events']['urlUploadFinished']>;
readAllNotifications: never;
unreadNotification: never;
unreadMention: never;
readAllUnreadMentions: never;
unreadSpecifiedNote: never;
readAllUnreadSpecifiedNotes: never;
readAllMessagingMessages: never;
unreadMessagingMessage: never;
readAllAntennas: never;
unreadAntenna: never;
readAllAnnouncements: never;
readAllChannels: never;
unreadChannel: never;
myTokenRegenerated: never;
};
export type mainStreamName = `mainStream:${User['id']}`;
export type mainStreams = EventUnionFromDictionary<mainStreamTypes>;
interface StreamEvents { interface StreamEvents {
'broadcast': <T extends keyof StreamTypes.BroadcasrEvents>(e: BroadcastStream<T>) => void; 'broadcast': (e: BroadcastStream) => void;
} }
interface AuthenticatedStreamEvents { interface AuthenticatedStreamEvents {
[key: UserEventName]: (e: UserEvent) => void; [key: UserEventName]: (e: UserEvents) => void;
[key: `mainStream:${User['id']}`]: (e: { type: string; body: any }) => void; [key: mainStreamName]: (e: mainStreams) => void;
[key: `driveStream:${User['id']}`]: (e: { type: string; body: any }) => void; [key: `driveStream:${User['id']}`]: (e: { type: string; body: any }) => void;
} }