fix: File attachments have no content when exporting room messages as file (#30596)

pull/30613/head^2
Matheus Barbosa Silva 3 years ago committed by GitHub
parent 4a59798da8
commit 3650ab81b5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 5
      .changeset/lucky-vans-develop.md
  2. 11
      apps/meteor/app/file-upload/server/config/AmazonS3.ts
  3. 11
      apps/meteor/app/file-upload/server/config/GoogleStorage.ts
  4. 4
      apps/meteor/app/file-upload/server/config/Webdav.ts
  5. 4
      apps/meteor/server/lib/dataExport/sendFile.ts

@ -0,0 +1,5 @@
---
"@rocket.chat/meteor": patch
---
Fixed issue with file attachments in rooms' messages export having no content

@ -32,12 +32,15 @@ const get: FileUploadClass['get'] = async function (this: FileUploadClass, file,
const copy: FileUploadClass['copy'] = async function (this: FileUploadClass, file, out) {
const fileUrl = await this.store.getRedirectURL(file);
if (fileUrl) {
const request = /^https:/.test(fileUrl) ? https : http;
request.get(fileUrl, (fileRes) => fileRes.pipe(out));
} else {
if (!fileUrl) {
out.end();
return;
}
const request = /^https:/.test(fileUrl) ? https : http;
return new Promise((resolve) => {
request.get(fileUrl, (fileRes) => fileRes.pipe(out).on('finish', () => resolve()));
});
};
const AmazonS3Uploads = new FileUploadClass({

@ -32,12 +32,15 @@ const get: FileUploadClass['get'] = async function (this: FileUploadClass, file,
const copy: FileUploadClass['copy'] = async function (this: FileUploadClass, file, out) {
const fileUrl = await this.store.getRedirectURL(file, false);
if (fileUrl) {
const request = /^https:/.test(fileUrl) ? https : http;
request.get(fileUrl, (fileRes) => fileRes.pipe(out));
} else {
if (!fileUrl) {
out.end();
return;
}
const request = /^https:/.test(fileUrl) ? https : http;
return new Promise((resolve) => {
request.get(fileUrl, (fileRes) => fileRes.pipe(out).on('finish', () => resolve()));
});
};
const GoogleCloudStorageUploads = new FileUploadClass({

@ -19,7 +19,9 @@ const get: FileUploadClass['get'] = async function (this: FileUploadClass, file,
};
const copy: FileUploadClass['copy'] = async function (this: FileUploadClass, file, out) {
(await this.store.getReadStream(file._id, file)).pipe(out);
return new Promise(async (resolve) => {
(await this.store.getReadStream(file._id, file)).pipe(out).on('finish', () => resolve());
});
};
const WebdavUploads = new FileUploadClass({

@ -64,9 +64,11 @@ export const sendFile = async (data: ExportFile, user: IUser): Promise<void> =>
await exportMessages();
const promises: Promise<void>[] = [];
for await (const attachmentData of fullFileList) {
await copyFileUpload(attachmentData, assetsPath);
promises.push(copyFileUpload(attachmentData, assetsPath));
}
await Promise.all(promises);
const exportFile = `${baseDir}-export.zip`;
await makeZipFile(exportPath, exportFile);

Loading…
Cancel
Save