mirror of
https://github.com/streetwriters/notesnook.git
synced 2025-12-25 16:09:42 +01:00
138 lines
4.1 KiB
JavaScript
138 lines
4.1 KiB
JavaScript
/*
|
|
This file is part of the Notesnook project (https://notesnook.com/)
|
|
|
|
Copyright (C) 2023 Streetwriters (Private) Limited
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
import { protocol } from "electron";
|
|
import { isDevelopment, getPath } from "./utils";
|
|
import { createReadStream } from "fs";
|
|
import { extname, normalize } from "path";
|
|
import { logger } from "./logger";
|
|
import { Blob } from "buffer";
|
|
import { URL } from "url";
|
|
|
|
const FILE_NOT_FOUND = -6;
|
|
const BASE_PATH = isDevelopment() ? "../public" : "";
|
|
const HOSTNAME = `app.notesnook.com`;
|
|
const PROTOCOL = "https";
|
|
const extensionToMimeType = {
|
|
html: "text/html",
|
|
json: "application/json",
|
|
js: "application/javascript",
|
|
css: "text/css",
|
|
svg: "image/svg+xml",
|
|
png: "image/png"
|
|
};
|
|
|
|
function registerProtocol() {
|
|
const protocolInterceptionResult = protocol.interceptStreamProtocol(
|
|
PROTOCOL,
|
|
async (request, callback) => {
|
|
const url = new URL(request.url);
|
|
if (shouldInterceptRequest(url)) {
|
|
logger.info("Intercepting request:", request);
|
|
|
|
const loadIndex = !extname(url.pathname);
|
|
const absoluteFilePath = normalize(
|
|
`${__dirname}${
|
|
loadIndex
|
|
? `${BASE_PATH}/index.html`
|
|
: `${BASE_PATH}/${url.pathname}`
|
|
}`
|
|
);
|
|
const filePath = getPath(absoluteFilePath);
|
|
if (!filePath) {
|
|
logger.error("Local asset file not found at", filePath);
|
|
callback({ error: FILE_NOT_FOUND });
|
|
return;
|
|
}
|
|
const fileExtension = extname(filePath).replace(".", "");
|
|
|
|
const data = createReadStream(filePath);
|
|
callback({
|
|
data,
|
|
mimeType: extensionToMimeType[fileExtension]
|
|
});
|
|
} else {
|
|
var response;
|
|
try {
|
|
const body = await getBody(request);
|
|
response = await fetch(request.url, {
|
|
...request,
|
|
body,
|
|
headers: {
|
|
...request.headers,
|
|
origin: `${PROTOCOL}://${HOSTNAME}/`
|
|
},
|
|
redirect: "manual"
|
|
});
|
|
} catch (e) {
|
|
console.error(e);
|
|
logger.error(`Error sending request to `, request.url, "Error: ", e);
|
|
callback({ statusCode: 400 });
|
|
return;
|
|
}
|
|
callback({
|
|
statusCode: response.status,
|
|
data: response.body,
|
|
headers: Object.fromEntries(response.headers.entries()),
|
|
mimeType: response.headers.get("Content-Type")
|
|
});
|
|
}
|
|
}
|
|
);
|
|
|
|
logger.info(
|
|
`${PROTOCOL} protocol inteception ${
|
|
protocolInterceptionResult ? "successful" : "failed"
|
|
}.`
|
|
);
|
|
}
|
|
|
|
const bypassedRoutes = ["/notes/index_v14.json", "/notes/welcome-web"];
|
|
function shouldInterceptRequest(url) {
|
|
let shouldIntercept = url.hostname === HOSTNAME;
|
|
return shouldIntercept && !bypassedRoutes.includes(url.pathname);
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param {Electron.ProtocolRequest} request
|
|
*/
|
|
async function getBody(request) {
|
|
/**
|
|
* @type {Electron.Session}
|
|
*/
|
|
const session = globalThis.window.webContents.session;
|
|
|
|
const blobParts = [];
|
|
if (!request.uploadData || !request.uploadData.length) return null;
|
|
for (let data of request.uploadData) {
|
|
if (data.type === "rawData") {
|
|
blobParts.push(new Uint8Array(data.bytes));
|
|
} else if (data.type === "blob") {
|
|
const buffer = await session.getBlobData(data.blobUUID);
|
|
blobParts.push(new Uint8Array(buffer));
|
|
}
|
|
}
|
|
const blob = new Blob(blobParts);
|
|
return await blob.arrayBuffer();
|
|
}
|
|
|
|
const PROTOCOL_URL = `${PROTOCOL}://${HOSTNAME}/`;
|
|
export { registerProtocol, PROTOCOL_URL };
|