2016-11-04 15:46:45 +03:00
|
|
|
/*
|
2021-03-04 04:22:57 +03:00
|
|
|
Copyright 2016, 2018, 2021 The Matrix.org Foundation C.I.C.
|
2016-11-04 15:46:45 +03:00
|
|
|
|
|
|
|
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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
// Pull in the encryption lib so that we can decrypt attachments.
|
2016-11-08 14:42:20 +03:00
|
|
|
import encrypt from 'browser-encrypt-attachment';
|
2021-06-29 15:11:58 +03:00
|
|
|
import { mediaFromContent } from "../customisations/Media";
|
2021-08-11 02:25:56 +03:00
|
|
|
import { IEncryptedFile, IMediaEventInfo } from "../customisations/models/IMediaEventContent";
|
2021-05-06 15:53:27 +03:00
|
|
|
import { getBlobSafeMimeType } from "./blobs";
|
2016-11-04 15:46:45 +03:00
|
|
|
|
2016-11-08 14:42:20 +03:00
|
|
|
/**
|
|
|
|
* Decrypt a file attached to a matrix event.
|
2021-08-11 02:25:56 +03:00
|
|
|
* @param {IEncryptedFile} file The encrypted file information taken from the matrix event.
|
2016-11-08 14:42:20 +03:00
|
|
|
* This passed to [link]{@link https://github.com/matrix-org/browser-encrypt-attachments}
|
|
|
|
* as the encryption info object, so will also have the those keys in addition to
|
|
|
|
* the keys below.
|
2021-08-11 02:25:56 +03:00
|
|
|
* @param {IMediaEventInfo} info The info parameter taken from the matrix event.
|
2021-03-04 04:22:57 +03:00
|
|
|
* @returns {Promise<Blob>} Resolves to a Blob of the file.
|
2016-11-08 14:42:20 +03:00
|
|
|
*/
|
2021-08-11 02:25:56 +03:00
|
|
|
export function decryptFile(
|
|
|
|
file: IEncryptedFile,
|
2021-08-11 02:37:18 +03:00
|
|
|
info?: IMediaEventInfo,
|
2021-08-11 02:25:56 +03:00
|
|
|
): Promise<Blob> {
|
2021-06-29 15:11:58 +03:00
|
|
|
const media = mediaFromContent({ file });
|
2016-11-04 15:46:45 +03:00
|
|
|
// Download the encrypted file as an array buffer.
|
2021-03-04 04:22:57 +03:00
|
|
|
return media.downloadSource().then((response) => {
|
2016-11-04 15:46:45 +03:00
|
|
|
return response.arrayBuffer();
|
2021-03-04 04:22:57 +03:00
|
|
|
}).then((responseData) => {
|
2016-11-04 15:46:45 +03:00
|
|
|
// Decrypt the array buffer using the information taken from
|
|
|
|
// the event content.
|
|
|
|
return encrypt.decryptAttachment(responseData, file);
|
2021-03-04 04:22:57 +03:00
|
|
|
}).then((dataArray) => {
|
2016-11-04 15:46:45 +03:00
|
|
|
// Turn the array into a Blob and give it the correct MIME-type.
|
2018-04-29 05:07:31 +03:00
|
|
|
|
|
|
|
// IMPORTANT: we must not allow scriptable mime-types into Blobs otherwise
|
|
|
|
// they introduce XSS attacks if the Blob URI is viewed directly in the
|
|
|
|
// browser (e.g. by copying the URI into a new tab or window.)
|
|
|
|
// See warning at top of file.
|
2021-08-11 02:25:56 +03:00
|
|
|
let mimetype = info?.mimetype ? info.mimetype.split(";")[0].trim() : '';
|
2021-05-06 15:53:27 +03:00
|
|
|
mimetype = getBlobSafeMimeType(mimetype);
|
2018-04-29 05:07:31 +03:00
|
|
|
|
2021-06-29 15:11:58 +03:00
|
|
|
return new Blob([dataArray], { type: mimetype });
|
2016-11-04 15:46:45 +03:00
|
|
|
});
|
|
|
|
}
|