/* Copyright 2017 New Vector Ltd Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. */ import dis from '../dispatcher'; // TODO: migrate from sync_state to MatrixActions.sync so that more js-sdk events // become dispatches in the same place. /** * Create a MatrixActions.sync action that represents a MatrixClient `sync` event. * * @param {MatrixClient} matrixClient the matrix client * @param {string} state the current sync state. * @param {string} prevState the previous sync state. * @returns {Object} an action of type MatrixActions.sync. */ function createSyncAction(matrixClient, state, prevState) { return { action: 'MatrixActions.sync', state, prevState, matrixClient, }; } /** * Create a MatrixActions.accountData action that represents a MatrixClient `accountData` * matrix event. * * @param {MatrixClient} matrixClient the matrix client. * @param {MatrixEvent} accountDataEvent the account data event. * @returns {Object} an action of type MatrixActions.accountData. */ function createAccountDataAction(matrixClient, accountDataEvent) { return { action: 'MatrixActions.accountData', event: accountDataEvent, event_type: accountDataEvent.getType(), event_content: accountDataEvent.getContent(), }; } /** * This object is responsible for dispatching actions when certain events are emitted by * the given MatrixClient. */ export default { // A list of callbacks to call to unregister all listeners added _matrixClientListenersStop: [], /** * Start listening to certain events from the MatrixClient and dispatch actions when * they are emitted. * @param {MatrixClient} matrixClient the MatrixClient to listen to events from */ start(matrixClient) { this._addMatrixClientListener(matrixClient, 'sync', createSyncAction); this._addMatrixClientListener(matrixClient, 'accountData', createAccountDataAction); }, /** * Start listening to events emitted by matrixClient, dispatch an action created by the * actionCreator function. * @param {MatrixClient} matrixClient a MatrixClient to register a listener with. * @param {string} eventName the event to listen to on MatrixClient. * @param {function} actionCreator a function that should return an action to dispatch * when given the arguments emitted in the MatrixClient * event. */ _addMatrixClientListener(matrixClient, eventName, actionCreator) { const listener = (...args) => { dis.dispatch(actionCreator(matrixClient, ...args)); }; matrixClient.on(eventName, listener); this._matrixClientListenersStop.push(() => { matrixClient.removeListener(eventName, listener); }); }, /** * Stop listening to events. */ stop() { this._matrixClientListenersStop.forEach((stopListener) => stopListener()); }, };