Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (C) 2022 Savoir-faire Linux Inc. |
| 3 | * |
| 4 | * This program is free software; you can redistribute it and/or modify |
| 5 | * it under the terms of the GNU Affero General Public License as |
| 6 | * published by the Free Software Foundation; either version 3 of the |
| 7 | * License, or (at your option) any later version. |
| 8 | * |
| 9 | * This program is distributed in the hope that it will be useful, |
| 10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 12 | * GNU Affero General Public License for more details. |
| 13 | * |
| 14 | * You should have received a copy of the GNU Affero General Public |
| 15 | * License along with this program. If not, see |
| 16 | * <https://www.gnu.org/licenses/>. |
| 17 | */ |
Misha Krieger-Raynauld | b6f1c32 | 2022-10-23 20:42:57 -0400 | [diff] [blame] | 18 | import { AccountDetails, VolatileDetails } from 'jami-web-common'; |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 19 | import log from 'loglevel'; |
Misha Krieger-Raynauld | 6f9c7ae | 2022-10-28 11:41:45 -0400 | [diff] [blame] | 20 | import { filter, firstValueFrom, map, Subject } from 'rxjs'; |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 21 | import { Service } from 'typedi'; |
| 22 | |
Misha Krieger-Raynauld | addd6fe | 2022-10-22 12:46:04 -0400 | [diff] [blame] | 23 | import { JamiSignal } from './jami-signal.js'; |
| 24 | import { |
Misha Krieger-Raynauld | 68a9b56 | 2022-10-28 19:47:46 -0400 | [diff] [blame] | 25 | AccountDetailsChanged, |
| 26 | ConversationLoaded, |
| 27 | ConversationReady, |
| 28 | ConversationRemoved, |
Charlie | b62c678 | 2022-10-30 15:14:56 -0400 | [diff] [blame] | 29 | IncomingAccountMessage, |
Misha Krieger-Raynauld | 68a9b56 | 2022-10-28 19:47:46 -0400 | [diff] [blame] | 30 | KnownDevicesChanged, |
| 31 | MessageReceived, |
Misha Krieger-Raynauld | addd6fe | 2022-10-22 12:46:04 -0400 | [diff] [blame] | 32 | NameRegistrationEnded, |
| 33 | RegisteredNameFound, |
| 34 | RegistrationStateChanged, |
| 35 | VolatileDetailsChanged, |
| 36 | } from './jami-signal-interfaces.js'; |
Misha Krieger-Raynauld | bfed173 | 2022-11-01 20:49:35 -0400 | [diff] [blame] | 37 | import { JamiSwig, StringMap, stringMapToRecord, stringVectToArray, vectMapToRecordArray } from './jami-swig.js'; |
Misha Krieger-Raynauld | b6f1c32 | 2022-10-23 20:42:57 -0400 | [diff] [blame] | 38 | import { require } from './utils.js'; |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 39 | |
Misha Krieger-Raynauld | 68a9b56 | 2022-10-28 19:47:46 -0400 | [diff] [blame] | 40 | // TODO: Mechanism to map account IDs to a list of WebSockets |
Misha Krieger-Raynauld | bfed173 | 2022-11-01 20:49:35 -0400 | [diff] [blame] | 41 | // TODO: Convert Records to interfaces and replace them in common/ (e.g. Contact) |
Misha Krieger-Raynauld | 68a9b56 | 2022-10-28 19:47:46 -0400 | [diff] [blame] | 42 | |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 43 | @Service() |
| 44 | export class Jamid { |
Misha Krieger-Raynauld | b6f1c32 | 2022-10-23 20:42:57 -0400 | [diff] [blame] | 45 | private readonly jamiSwig: JamiSwig; |
| 46 | private readonly usernamesToAccountIds: Map<string, string>; |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 47 | private readonly events; |
| 48 | |
| 49 | constructor() { |
| 50 | // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment |
simon | 7d4386c | 2022-10-26 17:47:59 -0400 | [diff] [blame] | 51 | this.jamiSwig = require('../../jamid.node') as JamiSwig; // TODO: we should put the path in the .env |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 52 | |
Misha Krieger-Raynauld | 68a9b56 | 2022-10-28 19:47:46 -0400 | [diff] [blame] | 53 | this.usernamesToAccountIds = new Map<string, string>(); |
| 54 | |
| 55 | // Setup signal handlers |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 56 | const handlers: Record<string, unknown> = {}; |
Misha Krieger-Raynauld | 68a9b56 | 2022-10-28 19:47:46 -0400 | [diff] [blame] | 57 | |
| 58 | // Add default handler for all signals |
| 59 | const createDefaultHandler = (signal: string) => { |
| 60 | return (...args: unknown[]) => log.warn('Unhandled', signal, args); |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 61 | }; |
Misha Krieger-Raynauld | 68a9b56 | 2022-10-28 19:47:46 -0400 | [diff] [blame] | 62 | for (const signal in JamiSignal) { |
| 63 | handlers[signal] = createDefaultHandler(signal); |
| 64 | } |
| 65 | |
| 66 | // Overwrite handlers for handled signals using RxJS Subjects, converting multiple arguments to objects |
| 67 | const onAccountsChanged = new Subject<void>(); |
| 68 | handlers.AccountsChanged = () => onAccountsChanged.next(); |
| 69 | |
| 70 | const onAccountDetailsChanged = new Subject<AccountDetailsChanged>(); |
| 71 | handlers.AccountDetailsChanged = (accountId: string, details: AccountDetails) => |
| 72 | onAccountDetailsChanged.next({ accountId, details }); |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 73 | |
| 74 | const onVolatileDetailsChanged = new Subject<VolatileDetailsChanged>(); |
Misha Krieger-Raynauld | 68a9b56 | 2022-10-28 19:47:46 -0400 | [diff] [blame] | 75 | handlers.VolatileDetailsChanged = (accountId: string, details: VolatileDetails) => |
| 76 | onVolatileDetailsChanged.next({ accountId, details }); |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 77 | |
| 78 | const onRegistrationStateChanged = new Subject<RegistrationStateChanged>(); |
| 79 | handlers.RegistrationStateChanged = (accountId: string, state: string, code: number, details: string) => |
| 80 | onRegistrationStateChanged.next({ accountId, state, code, details }); |
| 81 | |
| 82 | const onNameRegistrationEnded = new Subject<NameRegistrationEnded>(); |
| 83 | handlers.NameRegistrationEnded = (accountId: string, state: number, username: string) => |
| 84 | onNameRegistrationEnded.next({ accountId, state, username }); |
| 85 | |
| 86 | const onRegisteredNameFound = new Subject<RegisteredNameFound>(); |
| 87 | handlers.RegisteredNameFound = (accountId: string, state: number, address: string, username: string) => |
| 88 | onRegisteredNameFound.next({ accountId, state, address, username }); |
| 89 | |
Misha Krieger-Raynauld | 68a9b56 | 2022-10-28 19:47:46 -0400 | [diff] [blame] | 90 | const onKnownDevicesChanged = new Subject<KnownDevicesChanged>(); |
| 91 | handlers.KnownDevicesChanged = (accountId: string, devices: Record<string, string>) => |
| 92 | onKnownDevicesChanged.next({ accountId, devices }); |
| 93 | |
Charlie | b62c678 | 2022-10-30 15:14:56 -0400 | [diff] [blame] | 94 | const onIncomingAccountMessage = new Subject<IncomingAccountMessage>(); |
| 95 | handlers.IncomingAccountMessage = (accountId: string, from: string, message: Record<string, string>) => |
| 96 | onIncomingAccountMessage.next({ accountId, from, message }); |
| 97 | |
Misha Krieger-Raynauld | 68a9b56 | 2022-10-28 19:47:46 -0400 | [diff] [blame] | 98 | const onConversationReady = new Subject<ConversationReady>(); |
| 99 | handlers.ConversationReady = (accountId: string, conversationId: string) => |
| 100 | onConversationReady.next({ accountId, conversationId }); |
| 101 | |
| 102 | const onConversationRemoved = new Subject<ConversationRemoved>(); |
| 103 | handlers.ConversationRemoved = (accountId: string, conversationId: string) => |
| 104 | onConversationRemoved.next({ accountId, conversationId }); |
| 105 | |
| 106 | const onConversationLoaded = new Subject<ConversationLoaded>(); |
| 107 | handlers.ConversationLoaded = ( |
| 108 | id: number, |
| 109 | accountId: string, |
| 110 | conversationId: string, |
| 111 | messages: Record<string, string>[] |
| 112 | ) => onConversationLoaded.next({ id, accountId, conversationId, messages }); |
| 113 | |
| 114 | const onMessageReceived = new Subject<MessageReceived>(); |
| 115 | handlers.MessageReceived = (accountId: string, conversationId: string, message: Record<string, string>) => |
| 116 | onMessageReceived.next({ accountId, conversationId, message }); |
| 117 | |
| 118 | // Expose all signals in an events object to allow other handlers to subscribe after jamiSwig.init() |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 119 | this.events = { |
Misha Krieger-Raynauld | 68a9b56 | 2022-10-28 19:47:46 -0400 | [diff] [blame] | 120 | onAccountsChanged: onAccountsChanged.asObservable(), |
| 121 | onAccountDetailsChanged: onAccountDetailsChanged.asObservable(), |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 122 | onVolatileDetailsChanged: onVolatileDetailsChanged.asObservable(), |
| 123 | onRegistrationStateChanged: onRegistrationStateChanged.asObservable(), |
| 124 | onNameRegistrationEnded: onNameRegistrationEnded.asObservable(), |
| 125 | onRegisteredNameFound: onRegisteredNameFound.asObservable(), |
Misha Krieger-Raynauld | 68a9b56 | 2022-10-28 19:47:46 -0400 | [diff] [blame] | 126 | onKnownDevicesChanged: onKnownDevicesChanged.asObservable(), |
Charlie | b62c678 | 2022-10-30 15:14:56 -0400 | [diff] [blame] | 127 | onIncomingAccountMessage: onIncomingAccountMessage.asObservable(), |
Misha Krieger-Raynauld | 68a9b56 | 2022-10-28 19:47:46 -0400 | [diff] [blame] | 128 | onConversationReady: onConversationReady.asObservable(), |
| 129 | onConversationRemoved: onConversationRemoved.asObservable(), |
| 130 | onConversationLoaded: onConversationLoaded.asObservable(), |
| 131 | onMessageReceived: onMessageReceived.asObservable(), |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 132 | }; |
| 133 | |
Misha Krieger-Raynauld | 68a9b56 | 2022-10-28 19:47:46 -0400 | [diff] [blame] | 134 | this.setupSignalHandlers(); |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 135 | |
Misha Krieger-Raynauld | 68a9b56 | 2022-10-28 19:47:46 -0400 | [diff] [blame] | 136 | // RxJS Subjects are used as signal handlers for the following reasons: |
| 137 | // 1. You cannot change event handlers after calling jamiSwig.init() |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 138 | // 2. You cannot specify multiple handlers for the same event |
| 139 | // 3. You cannot specify a default handler |
Misha Krieger-Raynauld | b6f1c32 | 2022-10-23 20:42:57 -0400 | [diff] [blame] | 140 | this.jamiSwig.init(handlers); |
Charlie | 6ddaefe | 2022-11-01 18:36:29 -0400 | [diff] [blame] | 141 | |
| 142 | // TODO: Bind websocket callbacks for webrtc action on Incoming account message |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 143 | } |
| 144 | |
Misha Krieger-Raynauld | 62a0da9 | 2022-10-22 13:46:59 -0400 | [diff] [blame] | 145 | stop() { |
Misha Krieger-Raynauld | b6f1c32 | 2022-10-23 20:42:57 -0400 | [diff] [blame] | 146 | this.jamiSwig.fini(); |
Misha Krieger-Raynauld | 62a0da9 | 2022-10-22 13:46:59 -0400 | [diff] [blame] | 147 | } |
| 148 | |
Misha Krieger-Raynauld | b6f1c32 | 2022-10-23 20:42:57 -0400 | [diff] [blame] | 149 | getVolatileAccountDetails(accountId: string): VolatileDetails { |
| 150 | return stringMapToRecord(this.jamiSwig.getVolatileAccountDetails(accountId)) as unknown as VolatileDetails; |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 151 | } |
| 152 | |
Misha Krieger-Raynauld | b6f1c32 | 2022-10-23 20:42:57 -0400 | [diff] [blame] | 153 | getAccountDetails(accountId: string): AccountDetails { |
| 154 | return stringMapToRecord(this.jamiSwig.getAccountDetails(accountId)) as unknown as AccountDetails; |
| 155 | } |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 156 | |
Misha Krieger-Raynauld | b6f1c32 | 2022-10-23 20:42:57 -0400 | [diff] [blame] | 157 | setAccountDetails(accountId: string, accountDetails: AccountDetails) { |
simon | 43da57b | 2022-10-26 18:22:22 -0400 | [diff] [blame] | 158 | const accountDetailsStringMap: StringMap = new this.jamiSwig.StringMap(); |
Misha Krieger-Raynauld | b6f1c32 | 2022-10-23 20:42:57 -0400 | [diff] [blame] | 159 | for (const [key, value] of Object.entries(accountDetails)) { |
| 160 | accountDetailsStringMap.set(key, value); |
| 161 | } |
| 162 | this.jamiSwig.setAccountDetails(accountId, accountDetailsStringMap); |
| 163 | } |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 164 | |
Misha Krieger-Raynauld | b6f1c32 | 2022-10-23 20:42:57 -0400 | [diff] [blame] | 165 | async addAccount(details: Map<string, string | number | boolean>) { |
simon | 43da57b | 2022-10-26 18:22:22 -0400 | [diff] [blame] | 166 | const detailsStringMap: StringMap = new this.jamiSwig.StringMap(); |
Misha Krieger-Raynauld | b6f1c32 | 2022-10-23 20:42:57 -0400 | [diff] [blame] | 167 | |
| 168 | detailsStringMap.set('Account.type', 'RING'); |
| 169 | for (const [key, value] of details.entries()) { |
| 170 | detailsStringMap.set('Account.' + key, value.toString()); |
| 171 | } |
| 172 | |
| 173 | const accountId = this.jamiSwig.addAccount(detailsStringMap); |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 174 | return firstValueFrom( |
| 175 | this.events.onRegistrationStateChanged.pipe( |
Misha Krieger-Raynauld | 6f9c7ae | 2022-10-28 11:41:45 -0400 | [diff] [blame] | 176 | filter((value) => value.accountId === accountId), |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 177 | // TODO: is it the only state? |
Misha Krieger-Raynauld | 6f9c7ae | 2022-10-28 11:41:45 -0400 | [diff] [blame] | 178 | // TODO: Replace with string enum in common/ |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 179 | filter(({ state }) => state === 'REGISTERED') |
| 180 | ) |
| 181 | ); |
| 182 | } |
| 183 | |
Misha Krieger-Raynauld | b6f1c32 | 2022-10-23 20:42:57 -0400 | [diff] [blame] | 184 | removeAccount(accountId: string) { |
| 185 | this.jamiSwig.removeAccount(accountId); |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 186 | } |
| 187 | |
Misha Krieger-Raynauld | b6f1c32 | 2022-10-23 20:42:57 -0400 | [diff] [blame] | 188 | getAccountList(): string[] { |
| 189 | return stringVectToArray(this.jamiSwig.getAccountList()); |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 190 | } |
| 191 | |
Charlie | b62c678 | 2022-10-30 15:14:56 -0400 | [diff] [blame] | 192 | sendAccountTextMessage(accountId: string, contactId: string, type: string, message: string) { |
| 193 | const messageStringMap: StringMap = new this.jamiSwig.StringMap(); |
Charlie | 6ddaefe | 2022-11-01 18:36:29 -0400 | [diff] [blame] | 194 | messageStringMap.set(type, JSON.stringify(message)); |
Charlie | b62c678 | 2022-10-30 15:14:56 -0400 | [diff] [blame] | 195 | this.jamiSwig.sendAccountTextMessage(accountId, contactId, messageStringMap); |
| 196 | } |
| 197 | |
Misha Krieger-Raynauld | 6f9c7ae | 2022-10-28 11:41:45 -0400 | [diff] [blame] | 198 | async lookupUsername(username: string, accountId?: string) { |
| 199 | const hasRingNs = this.jamiSwig.lookupName(accountId || '', '', username); |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 200 | if (!hasRingNs) { |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 201 | throw new Error('Jami does not have NS'); |
| 202 | } |
Misha Krieger-Raynauld | 6f9c7ae | 2022-10-28 11:41:45 -0400 | [diff] [blame] | 203 | return firstValueFrom( |
| 204 | this.events.onRegisteredNameFound.pipe( |
| 205 | filter((value) => value.username === username), |
| 206 | map(({ accountId: _, ...response }) => response) // Remove accountId from response |
| 207 | ) |
| 208 | ); |
| 209 | } |
| 210 | |
| 211 | async lookupAddress(address: string, accountId?: string) { |
| 212 | const hasRingNs = this.jamiSwig.lookupAddress(accountId || '', '', address); |
| 213 | if (!hasRingNs) { |
| 214 | throw new Error('Jami does not have NS'); |
| 215 | } |
| 216 | return firstValueFrom( |
| 217 | this.events.onRegisteredNameFound.pipe( |
| 218 | filter((value) => value.address === address), |
| 219 | map(({ accountId: _, ...response }) => response) // Remove accountId from response |
| 220 | ) |
| 221 | ); |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 222 | } |
| 223 | |
Misha Krieger-Raynauld | b6f1c32 | 2022-10-23 20:42:57 -0400 | [diff] [blame] | 224 | async registerUsername(accountId: string, username: string, password: string) { |
| 225 | const hasRingNs = this.jamiSwig.registerName(accountId, password, username); |
| 226 | if (!hasRingNs) { |
Misha Krieger-Raynauld | b6f1c32 | 2022-10-23 20:42:57 -0400 | [diff] [blame] | 227 | throw new Error('Jami does not have NS'); |
| 228 | } |
Misha Krieger-Raynauld | 6f9c7ae | 2022-10-28 11:41:45 -0400 | [diff] [blame] | 229 | return firstValueFrom(this.events.onNameRegistrationEnded.pipe(filter((value) => value.accountId === accountId))); |
Misha Krieger-Raynauld | b6f1c32 | 2022-10-23 20:42:57 -0400 | [diff] [blame] | 230 | } |
| 231 | |
| 232 | getDevices(accountId: string): Record<string, string> { |
| 233 | return stringMapToRecord(this.jamiSwig.getKnownRingDevices(accountId)); |
| 234 | } |
| 235 | |
Misha Krieger-Raynauld | bfed173 | 2022-11-01 20:49:35 -0400 | [diff] [blame] | 236 | addContact(accountId: string, contactId: string) { |
| 237 | this.jamiSwig.addContact(accountId, contactId); |
| 238 | } |
| 239 | |
| 240 | removeContact(accountId: string, contactId: string) { |
| 241 | this.jamiSwig.removeContact(accountId, contactId, false); |
| 242 | } |
| 243 | |
| 244 | blockContact(accountId: string, contactId: string) { |
| 245 | this.jamiSwig.removeContact(accountId, contactId, true); |
| 246 | } |
| 247 | |
| 248 | getContacts(accountId: string): Record<string, string>[] { |
| 249 | return vectMapToRecordArray(this.jamiSwig.getContacts(accountId)); |
| 250 | } |
| 251 | |
| 252 | getContactDetails(accountId: string, contactId: string): Record<string, string> { |
| 253 | return stringMapToRecord(this.jamiSwig.getContactDetails(accountId, contactId)); |
| 254 | } |
| 255 | |
Misha Krieger-Raynauld | b6f1c32 | 2022-10-23 20:42:57 -0400 | [diff] [blame] | 256 | getDefaultModerators(accountId: string): string[] { |
| 257 | return stringVectToArray(this.jamiSwig.getDefaultModerators(accountId)); |
| 258 | } |
| 259 | |
| 260 | // TODO: Ideally, we would fetch the username directly from Jami instead of |
| 261 | // keeping an internal map. |
| 262 | getAccountIdFromUsername(username: string): string | undefined { |
| 263 | return this.usernamesToAccountIds.get(username); |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 264 | } |
Misha Krieger-Raynauld | 68a9b56 | 2022-10-28 19:47:46 -0400 | [diff] [blame] | 265 | |
| 266 | private setupSignalHandlers() { |
| 267 | this.events.onAccountsChanged.subscribe(() => { |
| 268 | log.debug('Received AccountsChanged'); |
| 269 | }); |
| 270 | |
| 271 | this.events.onAccountDetailsChanged.subscribe((signal) => { |
| 272 | log.debug('Received AccountsDetailsChanged', JSON.stringify(signal)); |
| 273 | }); |
| 274 | |
| 275 | this.events.onVolatileDetailsChanged.subscribe(({ accountId, details }) => { |
| 276 | log.debug(`Received VolatileDetailsChanged: {"accountId":"${accountId}", ...}`); |
| 277 | // Keep map of usernames to account IDs |
| 278 | const username = details['Account.registeredName']; |
| 279 | if (username) { |
| 280 | this.usernamesToAccountIds.set(username, accountId); |
| 281 | } |
| 282 | }); |
| 283 | |
| 284 | this.events.onRegistrationStateChanged.subscribe((signal) => { |
| 285 | log.debug('Received RegistrationStateChanged:', JSON.stringify(signal)); |
| 286 | }); |
| 287 | |
| 288 | this.events.onNameRegistrationEnded.subscribe((signal) => { |
| 289 | log.debug('Received NameRegistrationEnded:', JSON.stringify(signal)); |
| 290 | }); |
| 291 | |
| 292 | this.events.onRegisteredNameFound.subscribe((signal) => { |
| 293 | log.debug('Received RegisteredNameFound:', JSON.stringify(signal)); |
| 294 | }); |
| 295 | |
| 296 | this.events.onKnownDevicesChanged.subscribe(({ accountId }) => { |
| 297 | log.debug(`Received KnownDevicesChanged: {"accountId":"${accountId}", ...}`); |
| 298 | }); |
| 299 | |
| 300 | this.events.onIncomingAccountMessage.subscribe((signal) => { |
| 301 | log.debug('Received IncomingAccountMessage:', JSON.stringify(signal)); |
| 302 | }); |
| 303 | |
| 304 | this.events.onConversationReady.subscribe((signal) => { |
| 305 | log.debug('Received ConversationReady:', JSON.stringify(signal)); |
| 306 | }); |
| 307 | |
| 308 | this.events.onConversationRemoved.subscribe((signal) => { |
| 309 | log.debug('Received ConversationRemoved:', JSON.stringify(signal)); |
| 310 | }); |
| 311 | |
| 312 | this.events.onConversationLoaded.subscribe((signal) => { |
| 313 | log.debug('Received ConversationLoaded:', JSON.stringify(signal)); |
| 314 | }); |
| 315 | |
| 316 | this.events.onMessageReceived.subscribe((signal) => { |
| 317 | log.debug('Received MessageReceived:', JSON.stringify(signal)); |
Charlie | 6ddaefe | 2022-11-01 18:36:29 -0400 | [diff] [blame] | 318 | // TODO: Send message to client using WS service |
Misha Krieger-Raynauld | 68a9b56 | 2022-10-28 19:47:46 -0400 | [diff] [blame] | 319 | }); |
| 320 | } |
Issam E. Maghni | f796a09 | 2022-10-09 20:25:26 +0000 | [diff] [blame] | 321 | } |