UNPKG

matrix-react-sdk

Version:
107 lines (104 loc) 17.4 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _matrix = require("matrix-js-sdk/src/matrix"); var _logger = require("matrix-js-sdk/src/logger"); var _Exporter = _interopRequireDefault(require("./Exporter")); var _DateUtils = require("../../DateUtils"); var _languageHandler = require("../../languageHandler"); var _EventTileFactory = require("../../events/EventTileFactory"); /* Copyright 2024 New Vector Ltd. Copyright 2021, 2022 The Matrix.org Foundation C.I.C. SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only Please see LICENSE files in the repository root for full details. */ class JSONExporter extends _Exporter.default { constructor(room, exportType, exportOptions, setProgressText) { super(room, exportType, exportOptions, setProgressText); (0, _defineProperty2.default)(this, "totalSize", 0); (0, _defineProperty2.default)(this, "messages", []); } get destinationFileName() { return this.makeFileNameNoExtension() + ".json"; } createJSONString() { const exportDate = (0, _DateUtils.formatFullDateNoDayNoTime)(new Date()); const creator = this.room.currentState.getStateEvents(_matrix.EventType.RoomCreate, "")?.getSender(); const creatorName = creator && this.room?.getMember(creator)?.rawDisplayName || creator; const topic = this.room.currentState.getStateEvents(_matrix.EventType.RoomTopic, "")?.getContent()?.topic || ""; const exporter = this.room.client.getUserId(); const exporterName = this.room?.getMember(exporter)?.rawDisplayName || exporter; const jsonObject = { room_name: this.room.name, room_creator: creatorName, topic, export_date: exportDate, exported_by: exporterName, messages: this.messages }; return JSON.stringify(jsonObject, null, 2); } async getJSONString(mxEv) { if (this.exportOptions.attachmentsIncluded && this.isAttachment(mxEv)) { try { const blob = await this.getMediaBlob(mxEv); if (this.totalSize + blob.size < this.exportOptions.maxSize) { this.totalSize += blob.size; const filePath = this.getFilePath(mxEv); if (this.totalSize == this.exportOptions.maxSize) { this.exportOptions.attachmentsIncluded = false; } this.addFile(filePath, blob); } } catch (err) { _logger.logger.log("Error fetching file: " + err); } } return mxEv.getEffectiveEvent(); } async createOutput(events) { for (let i = 0; i < events.length; i++) { const event = events[i]; this.updateProgress((0, _languageHandler._t)("export_chat|processing_event_n", { number: i + 1, total: events.length }), false, true); if (this.cancelled) return this.cleanUp(); if (!(0, _EventTileFactory.haveRendererForEvent)(event, this.room.client, false)) continue; this.messages.push(await this.getJSONString(event)); } return this.createJSONString(); } async export() { _logger.logger.info("Starting export process..."); _logger.logger.info("Fetching events..."); const fetchStart = performance.now(); const res = await this.getRequiredEvents(); const fetchEnd = performance.now(); _logger.logger.log(`Fetched ${res.length} events in ${(fetchEnd - fetchStart) / 1000}s`); _logger.logger.info("Creating output..."); const text = await this.createOutput(res); if (this.files.length) { this.addFile("export.json", new Blob([text])); await this.downloadZIP(); } else { const fileName = this.destinationFileName; this.downloadPlainText(fileName, text); } const exportEnd = performance.now(); if (this.cancelled) { _logger.logger.info("Export cancelled successfully"); } else { _logger.logger.info("Export successful!"); _logger.logger.log(`Exported ${res.length} events in ${(exportEnd - fetchStart) / 1000} seconds`); } this.cleanUp(); } } exports.default = JSONExporter; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_matrix","require","_logger","_Exporter","_interopRequireDefault","_DateUtils","_languageHandler","_EventTileFactory","JSONExporter","Exporter","constructor","room","exportType","exportOptions","setProgressText","_defineProperty2","default","destinationFileName","makeFileNameNoExtension","createJSONString","exportDate","formatFullDateNoDayNoTime","Date","creator","currentState","getStateEvents","EventType","RoomCreate","getSender","creatorName","getMember","rawDisplayName","topic","RoomTopic","getContent","exporter","client","getUserId","exporterName","jsonObject","room_name","name","room_creator","export_date","exported_by","messages","JSON","stringify","getJSONString","mxEv","attachmentsIncluded","isAttachment","blob","getMediaBlob","totalSize","size","maxSize","filePath","getFilePath","addFile","err","logger","log","getEffectiveEvent","createOutput","events","i","length","event","updateProgress","_t","number","total","cancelled","cleanUp","haveRendererForEvent","push","export","info","fetchStart","performance","now","res","getRequiredEvents","fetchEnd","text","files","Blob","downloadZIP","fileName","downloadPlainText","exportEnd","exports"],"sources":["../../../src/utils/exportUtils/JSONExport.ts"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2021, 2022 The Matrix.org Foundation C.I.C.\n\nSPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only\nPlease see LICENSE files in the repository root for full details.\n*/\n\nimport { Room, IEvent, MatrixEvent, EventType } from \"matrix-js-sdk/src/matrix\";\nimport { logger } from \"matrix-js-sdk/src/logger\";\n\nimport Exporter from \"./Exporter\";\nimport { formatFullDateNoDayNoTime } from \"../../DateUtils\";\nimport { ExportType, IExportOptions } from \"./exportUtils\";\nimport { _t } from \"../../languageHandler\";\nimport { haveRendererForEvent } from \"../../events/EventTileFactory\";\n\nexport default class JSONExporter extends Exporter {\n    protected totalSize = 0;\n    protected messages: Record<string, any>[] = [];\n\n    public constructor(\n        room: Room,\n        exportType: ExportType,\n        exportOptions: IExportOptions,\n        setProgressText: React.Dispatch<React.SetStateAction<string>>,\n    ) {\n        super(room, exportType, exportOptions, setProgressText);\n    }\n\n    public get destinationFileName(): string {\n        return this.makeFileNameNoExtension() + \".json\";\n    }\n\n    protected createJSONString(): string {\n        const exportDate = formatFullDateNoDayNoTime(new Date());\n        const creator = this.room.currentState.getStateEvents(EventType.RoomCreate, \"\")?.getSender();\n        const creatorName = (creator && this.room?.getMember(creator)?.rawDisplayName) || creator;\n        const topic = this.room.currentState.getStateEvents(EventType.RoomTopic, \"\")?.getContent()?.topic || \"\";\n        const exporter = this.room.client.getUserId()!;\n        const exporterName = this.room?.getMember(exporter)?.rawDisplayName || exporter;\n        const jsonObject = {\n            room_name: this.room.name,\n            room_creator: creatorName,\n            topic,\n            export_date: exportDate,\n            exported_by: exporterName,\n            messages: this.messages,\n        };\n        return JSON.stringify(jsonObject, null, 2);\n    }\n\n    protected async getJSONString(mxEv: MatrixEvent): Promise<IEvent> {\n        if (this.exportOptions.attachmentsIncluded && this.isAttachment(mxEv)) {\n            try {\n                const blob = await this.getMediaBlob(mxEv);\n                if (this.totalSize + blob.size < this.exportOptions.maxSize) {\n                    this.totalSize += blob.size;\n                    const filePath = this.getFilePath(mxEv);\n                    if (this.totalSize == this.exportOptions.maxSize) {\n                        this.exportOptions.attachmentsIncluded = false;\n                    }\n                    this.addFile(filePath, blob);\n                }\n            } catch (err) {\n                logger.log(\"Error fetching file: \" + err);\n            }\n        }\n        return mxEv.getEffectiveEvent();\n    }\n\n    protected async createOutput(events: MatrixEvent[]): Promise<string> {\n        for (let i = 0; i < events.length; i++) {\n            const event = events[i];\n            this.updateProgress(\n                _t(\"export_chat|processing_event_n\", {\n                    number: i + 1,\n                    total: events.length,\n                }),\n                false,\n                true,\n            );\n            if (this.cancelled) return this.cleanUp();\n            if (!haveRendererForEvent(event, this.room.client, false)) continue;\n            this.messages.push(await this.getJSONString(event));\n        }\n        return this.createJSONString();\n    }\n\n    public async export(): Promise<void> {\n        logger.info(\"Starting export process...\");\n        logger.info(\"Fetching events...\");\n\n        const fetchStart = performance.now();\n        const res = await this.getRequiredEvents();\n        const fetchEnd = performance.now();\n\n        logger.log(`Fetched ${res.length} events in ${(fetchEnd - fetchStart) / 1000}s`);\n\n        logger.info(\"Creating output...\");\n        const text = await this.createOutput(res);\n\n        if (this.files.length) {\n            this.addFile(\"export.json\", new Blob([text]));\n            await this.downloadZIP();\n        } else {\n            const fileName = this.destinationFileName;\n            this.downloadPlainText(fileName, text);\n        }\n\n        const exportEnd = performance.now();\n\n        if (this.cancelled) {\n            logger.info(\"Export cancelled successfully\");\n        } else {\n            logger.info(\"Export successful!\");\n            logger.log(`Exported ${res.length} events in ${(exportEnd - fetchStart) / 1000} seconds`);\n        }\n\n        this.cleanUp();\n    }\n}\n"],"mappings":";;;;;;;;AAQA,IAAAA,OAAA,GAAAC,OAAA;AACA,IAAAC,OAAA,GAAAD,OAAA;AAEA,IAAAE,SAAA,GAAAC,sBAAA,CAAAH,OAAA;AACA,IAAAI,UAAA,GAAAJ,OAAA;AAEA,IAAAK,gBAAA,GAAAL,OAAA;AACA,IAAAM,iBAAA,GAAAN,OAAA;AAfA;AACA;AACA;AACA;AACA;AACA;AACA;;AAWe,MAAMO,YAAY,SAASC,iBAAQ,CAAC;EAIxCC,WAAWA,CACdC,IAAU,EACVC,UAAsB,EACtBC,aAA6B,EAC7BC,eAA6D,EAC/D;IACE,KAAK,CAACH,IAAI,EAAEC,UAAU,EAAEC,aAAa,EAAEC,eAAe,CAAC;IAAC,IAAAC,gBAAA,CAAAC,OAAA,qBATtC,CAAC;IAAA,IAAAD,gBAAA,CAAAC,OAAA,oBACqB,EAAE;EAS9C;EAEA,IAAWC,mBAAmBA,CAAA,EAAW;IACrC,OAAO,IAAI,CAACC,uBAAuB,CAAC,CAAC,GAAG,OAAO;EACnD;EAEUC,gBAAgBA,CAAA,EAAW;IACjC,MAAMC,UAAU,GAAG,IAAAC,oCAAyB,EAAC,IAAIC,IAAI,CAAC,CAAC,CAAC;IACxD,MAAMC,OAAO,GAAG,IAAI,CAACZ,IAAI,CAACa,YAAY,CAACC,cAAc,CAACC,iBAAS,CAACC,UAAU,EAAE,EAAE,CAAC,EAAEC,SAAS,CAAC,CAAC;IAC5F,MAAMC,WAAW,GAAIN,OAAO,IAAI,IAAI,CAACZ,IAAI,EAAEmB,SAAS,CAACP,OAAO,CAAC,EAAEQ,cAAc,IAAKR,OAAO;IACzF,MAAMS,KAAK,GAAG,IAAI,CAACrB,IAAI,CAACa,YAAY,CAACC,cAAc,CAACC,iBAAS,CAACO,SAAS,EAAE,EAAE,CAAC,EAAEC,UAAU,CAAC,CAAC,EAAEF,KAAK,IAAI,EAAE;IACvG,MAAMG,QAAQ,GAAG,IAAI,CAACxB,IAAI,CAACyB,MAAM,CAACC,SAAS,CAAC,CAAE;IAC9C,MAAMC,YAAY,GAAG,IAAI,CAAC3B,IAAI,EAAEmB,SAAS,CAACK,QAAQ,CAAC,EAAEJ,cAAc,IAAII,QAAQ;IAC/E,MAAMI,UAAU,GAAG;MACfC,SAAS,EAAE,IAAI,CAAC7B,IAAI,CAAC8B,IAAI;MACzBC,YAAY,EAAEb,WAAW;MACzBG,KAAK;MACLW,WAAW,EAAEvB,UAAU;MACvBwB,WAAW,EAAEN,YAAY;MACzBO,QAAQ,EAAE,IAAI,CAACA;IACnB,CAAC;IACD,OAAOC,IAAI,CAACC,SAAS,CAACR,UAAU,EAAE,IAAI,EAAE,CAAC,CAAC;EAC9C;EAEA,MAAgBS,aAAaA,CAACC,IAAiB,EAAmB;IAC9D,IAAI,IAAI,CAACpC,aAAa,CAACqC,mBAAmB,IAAI,IAAI,CAACC,YAAY,CAACF,IAAI,CAAC,EAAE;MACnE,IAAI;QACA,MAAMG,IAAI,GAAG,MAAM,IAAI,CAACC,YAAY,CAACJ,IAAI,CAAC;QAC1C,IAAI,IAAI,CAACK,SAAS,GAAGF,IAAI,CAACG,IAAI,GAAG,IAAI,CAAC1C,aAAa,CAAC2C,OAAO,EAAE;UACzD,IAAI,CAACF,SAAS,IAAIF,IAAI,CAACG,IAAI;UAC3B,MAAME,QAAQ,GAAG,IAAI,CAACC,WAAW,CAACT,IAAI,CAAC;UACvC,IAAI,IAAI,CAACK,SAAS,IAAI,IAAI,CAACzC,aAAa,CAAC2C,OAAO,EAAE;YAC9C,IAAI,CAAC3C,aAAa,CAACqC,mBAAmB,GAAG,KAAK;UAClD;UACA,IAAI,CAACS,OAAO,CAACF,QAAQ,EAAEL,IAAI,CAAC;QAChC;MACJ,CAAC,CAAC,OAAOQ,GAAG,EAAE;QACVC,cAAM,CAACC,GAAG,CAAC,uBAAuB,GAAGF,GAAG,CAAC;MAC7C;IACJ;IACA,OAAOX,IAAI,CAACc,iBAAiB,CAAC,CAAC;EACnC;EAEA,MAAgBC,YAAYA,CAACC,MAAqB,EAAmB;IACjE,KAAK,IAAIC,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGD,MAAM,CAACE,MAAM,EAAED,CAAC,EAAE,EAAE;MACpC,MAAME,KAAK,GAAGH,MAAM,CAACC,CAAC,CAAC;MACvB,IAAI,CAACG,cAAc,CACf,IAAAC,mBAAE,EAAC,gCAAgC,EAAE;QACjCC,MAAM,EAAEL,CAAC,GAAG,CAAC;QACbM,KAAK,EAAEP,MAAM,CAACE;MAClB,CAAC,CAAC,EACF,KAAK,EACL,IACJ,CAAC;MACD,IAAI,IAAI,CAACM,SAAS,EAAE,OAAO,IAAI,CAACC,OAAO,CAAC,CAAC;MACzC,IAAI,CAAC,IAAAC,sCAAoB,EAACP,KAAK,EAAE,IAAI,CAACzD,IAAI,CAACyB,MAAM,EAAE,KAAK,CAAC,EAAE;MAC3D,IAAI,CAACS,QAAQ,CAAC+B,IAAI,CAAC,MAAM,IAAI,CAAC5B,aAAa,CAACoB,KAAK,CAAC,CAAC;IACvD;IACA,OAAO,IAAI,CAACjD,gBAAgB,CAAC,CAAC;EAClC;EAEA,MAAa0D,MAAMA,CAAA,EAAkB;IACjChB,cAAM,CAACiB,IAAI,CAAC,4BAA4B,CAAC;IACzCjB,cAAM,CAACiB,IAAI,CAAC,oBAAoB,CAAC;IAEjC,MAAMC,UAAU,GAAGC,WAAW,CAACC,GAAG,CAAC,CAAC;IACpC,MAAMC,GAAG,GAAG,MAAM,IAAI,CAACC,iBAAiB,CAAC,CAAC;IAC1C,MAAMC,QAAQ,GAAGJ,WAAW,CAACC,GAAG,CAAC,CAAC;IAElCpB,cAAM,CAACC,GAAG,CAAC,WAAWoB,GAAG,CAACf,MAAM,cAAc,CAACiB,QAAQ,GAAGL,UAAU,IAAI,IAAI,GAAG,CAAC;IAEhFlB,cAAM,CAACiB,IAAI,CAAC,oBAAoB,CAAC;IACjC,MAAMO,IAAI,GAAG,MAAM,IAAI,CAACrB,YAAY,CAACkB,GAAG,CAAC;IAEzC,IAAI,IAAI,CAACI,KAAK,CAACnB,MAAM,EAAE;MACnB,IAAI,CAACR,OAAO,CAAC,aAAa,EAAE,IAAI4B,IAAI,CAAC,CAACF,IAAI,CAAC,CAAC,CAAC;MAC7C,MAAM,IAAI,CAACG,WAAW,CAAC,CAAC;IAC5B,CAAC,MAAM;MACH,MAAMC,QAAQ,GAAG,IAAI,CAACxE,mBAAmB;MACzC,IAAI,CAACyE,iBAAiB,CAACD,QAAQ,EAAEJ,IAAI,CAAC;IAC1C;IAEA,MAAMM,SAAS,GAAGX,WAAW,CAACC,GAAG,CAAC,CAAC;IAEnC,IAAI,IAAI,CAACR,SAAS,EAAE;MAChBZ,cAAM,CAACiB,IAAI,CAAC,+BAA+B,CAAC;IAChD,CAAC,MAAM;MACHjB,cAAM,CAACiB,IAAI,CAAC,oBAAoB,CAAC;MACjCjB,cAAM,CAACC,GAAG,CAAC,YAAYoB,GAAG,CAACf,MAAM,cAAc,CAACwB,SAAS,GAAGZ,UAAU,IAAI,IAAI,UAAU,CAAC;IAC7F;IAEA,IAAI,CAACL,OAAO,CAAC,CAAC;EAClB;AACJ;AAACkB,OAAA,CAAA5E,OAAA,GAAAR,YAAA","ignoreList":[]}