rm opengrouprefs
parent
6afddf38df
commit
131123e751
@ -1,82 +0,0 @@
|
|||||||
// This is the Open Group equivalent to the PubKey type.
|
|
||||||
|
|
||||||
interface OpenGroupParams {
|
|
||||||
server: string;
|
|
||||||
channel: number;
|
|
||||||
conversationId: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
export class OpenGroup {
|
|
||||||
private static readonly serverRegex = new RegExp(
|
|
||||||
'^([\\w-]{2,}.){1,2}[\\w-]{2,}$'
|
|
||||||
);
|
|
||||||
private static readonly groupIdRegex = new RegExp(
|
|
||||||
'^publicChat:[0-9]*@([\\w-]{2,}.){1,2}[\\w-]{2,}$'
|
|
||||||
);
|
|
||||||
public readonly server: string;
|
|
||||||
public readonly channel: number;
|
|
||||||
public readonly groupId?: string;
|
|
||||||
public readonly conversationId: string;
|
|
||||||
|
|
||||||
constructor(params: OpenGroupParams) {
|
|
||||||
const strippedServer = params.server.replace('https://', '');
|
|
||||||
this.server = strippedServer;
|
|
||||||
|
|
||||||
// Validate server format
|
|
||||||
const isValid = OpenGroup.serverRegex.test(this.server);
|
|
||||||
if (!isValid) {
|
|
||||||
throw Error('an invalid server or groupId was provided');
|
|
||||||
}
|
|
||||||
|
|
||||||
this.channel = params.channel;
|
|
||||||
this.conversationId = params.conversationId;
|
|
||||||
this.groupId = OpenGroup.getGroupId(this.server, this.channel);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static from(
|
|
||||||
groupId: string,
|
|
||||||
conversationId: string
|
|
||||||
): OpenGroup | undefined {
|
|
||||||
// Returns a new instance from a groupId if it's valid
|
|
||||||
// eg. groupId = 'publicChat:1@chat.getsession.org'
|
|
||||||
|
|
||||||
const server = this.getServer(groupId);
|
|
||||||
const channel = this.getChannel(groupId);
|
|
||||||
|
|
||||||
// Was groupId successfully utilized?
|
|
||||||
if (!server || !channel) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
const openGroupParams = {
|
|
||||||
server,
|
|
||||||
channel,
|
|
||||||
groupId,
|
|
||||||
conversationId,
|
|
||||||
} as OpenGroupParams;
|
|
||||||
|
|
||||||
if (this.serverRegex.test(server)) {
|
|
||||||
return new OpenGroup(openGroupParams);
|
|
||||||
}
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static getServer(groupId: string): string | undefined {
|
|
||||||
const isValid = this.groupIdRegex.test(groupId);
|
|
||||||
|
|
||||||
return isValid ? groupId.split('@')[1] : undefined;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static getChannel(groupId: string): number | undefined {
|
|
||||||
const isValid = this.groupIdRegex.test(groupId);
|
|
||||||
const channelMatch = groupId.match(/^.*\:([0-9]*)\@.*$/);
|
|
||||||
|
|
||||||
return channelMatch && isValid ? Number(channelMatch[1]) : undefined;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static getGroupId(server: string, channel: number): string {
|
|
||||||
// server is already validated in constructor; no need to re-check
|
|
||||||
return `publicChat:${channel}@${server}`;
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in New Issue