add groupUpdate message and groupInfo to new pipeline
parent
b0ed0207e0
commit
bd940a9f79
@ -0,0 +1,76 @@
|
||||
import { DataMessage } from '../DataMessage';
|
||||
import { SignalService } from '../../../../../../protobuf';
|
||||
import { StringUtils } from '../../../../../utils';
|
||||
import {
|
||||
ClosedGroupMessage,
|
||||
ClosedGroupMessageParams,
|
||||
} from './ClosedGroupMessage';
|
||||
import { AttachmentPointer } from '../ChatMessage';
|
||||
import { PubKey } from '../../../../../types';
|
||||
|
||||
export interface ClosedGroupUpdateMessageParams
|
||||
extends ClosedGroupMessageParams {
|
||||
name: string;
|
||||
members?: Array<string>;
|
||||
admins?: Array<string>;
|
||||
avatar?: AttachmentPointer;
|
||||
}
|
||||
|
||||
export abstract class ClosedGroupUpdateMessage extends ClosedGroupMessage {
|
||||
private readonly name: string;
|
||||
private readonly members?: Array<string>;
|
||||
private readonly admins?: Array<string>;
|
||||
private readonly avatar?: AttachmentPointer;
|
||||
|
||||
constructor(params: ClosedGroupUpdateMessageParams) {
|
||||
super({
|
||||
timestamp: params.timestamp,
|
||||
identifier: params.identifier,
|
||||
groupId: params.groupId,
|
||||
});
|
||||
if (typeof params.name !== 'string') {
|
||||
throw new Error('name must be a string');
|
||||
}
|
||||
if (
|
||||
params.members &&
|
||||
params.members.length > 0 &&
|
||||
typeof params.members[0] !== 'string'
|
||||
) {
|
||||
throw new Error('members has not the correct type');
|
||||
}
|
||||
if (
|
||||
params.admins &&
|
||||
params.admins.length > 0 &&
|
||||
typeof params.admins[0] !== 'string'
|
||||
) {
|
||||
throw new Error('admins has not the correct type');
|
||||
}
|
||||
|
||||
this.name = params.name;
|
||||
this.members = params.members;
|
||||
this.admins = params.admins;
|
||||
this.avatar = params.avatar;
|
||||
}
|
||||
|
||||
protected groupContextType(): SignalService.GroupContext.Type {
|
||||
return SignalService.GroupContext.Type.UPDATE;
|
||||
}
|
||||
|
||||
protected groupContext(): SignalService.GroupContext {
|
||||
// use the parent method to fill id and type correctly
|
||||
const groupContext = super.groupContext();
|
||||
|
||||
if (this.name) {
|
||||
groupContext.name = this.name;
|
||||
}
|
||||
if (this.members && this.members.length > 0) {
|
||||
groupContext.members = this.members;
|
||||
}
|
||||
|
||||
if (this.admins && this.admins.length > 0) {
|
||||
groupContext.admins = this.admins;
|
||||
}
|
||||
|
||||
return groupContext;
|
||||
}
|
||||
}
|
@ -1,2 +1,5 @@
|
||||
export * from './ClosedGroupMessage';
|
||||
export * from './ClosedGroupChatMessage';
|
||||
export * from './ClosedGroupUpdateMessage';
|
||||
export * from './ClosedGroupLeaveMessage';
|
||||
export * from './ClosedGroupRequestInfoMessage';
|
||||
|
Loading…
Reference in New Issue