mirror of
https://github.com/toeverything/AFFiNE.git
synced 2026-02-14 21:27:20 +00:00
124 lines
3.3 KiB
TypeScript
124 lines
3.3 KiB
TypeScript
import path from 'node:path';
|
|
|
|
import type { App } from 'electron';
|
|
|
|
import { buildType, isDev } from './config';
|
|
import { logger } from './logger';
|
|
import { uiSubjects } from './ui';
|
|
import {
|
|
addTabWithUrl,
|
|
getMainWindow,
|
|
loadUrlInActiveTab,
|
|
openUrlInHiddenWindow,
|
|
showMainWindow,
|
|
} from './windows-manager';
|
|
|
|
let protocol = buildType === 'stable' ? 'affine' : `affine-${buildType}`;
|
|
if (isDev) {
|
|
protocol = 'affine-dev';
|
|
}
|
|
|
|
export function setupDeepLink(app: App) {
|
|
if (process.defaultApp) {
|
|
if (process.argv.length >= 2) {
|
|
app.setAsDefaultProtocolClient(protocol, process.execPath, [
|
|
path.resolve(process.argv[1]),
|
|
]);
|
|
}
|
|
} else {
|
|
app.setAsDefaultProtocolClient(protocol);
|
|
}
|
|
|
|
app.on('open-url', (event, url) => {
|
|
logger.log('open-url', url);
|
|
if (url.startsWith(`${protocol}://`)) {
|
|
event.preventDefault();
|
|
app
|
|
.whenReady()
|
|
.then(() => handleAffineUrl(url))
|
|
.catch(e => {
|
|
logger.error('failed to handle affine url', e);
|
|
});
|
|
}
|
|
});
|
|
|
|
// on windows & linux, we need to listen for the second-instance event
|
|
app.on('second-instance', (event, commandLine) => {
|
|
getMainWindow()
|
|
.then(window => {
|
|
if (!window) {
|
|
logger.error('main window is not ready');
|
|
return;
|
|
}
|
|
window.show();
|
|
const url = commandLine.pop();
|
|
if (url?.startsWith(`${protocol}://`)) {
|
|
event.preventDefault();
|
|
handleAffineUrl(url).catch(e => {
|
|
logger.error('failed to handle affine url', e);
|
|
});
|
|
}
|
|
})
|
|
.catch(e => console.error('Failed to restore or create window:', e));
|
|
});
|
|
|
|
app.on('ready', () => {
|
|
// app may be brought up without having a running instance
|
|
// need to read the url from the command line
|
|
const url = process.argv.at(-1);
|
|
logger.log('url from argv', process.argv, url);
|
|
if (url?.startsWith(`${protocol}://`)) {
|
|
handleAffineUrl(url).catch(e => {
|
|
logger.error('failed to handle affine url', e);
|
|
});
|
|
}
|
|
});
|
|
}
|
|
|
|
async function handleAffineUrl(url: string) {
|
|
await showMainWindow();
|
|
|
|
logger.info('open affine url', url);
|
|
const urlObj = new URL(url);
|
|
|
|
if (urlObj.hostname === 'authentication') {
|
|
const method = urlObj.searchParams.get('method');
|
|
const payload = JSON.parse(urlObj.searchParams.get('payload') ?? 'false');
|
|
const server = urlObj.searchParams.get('server') || undefined;
|
|
|
|
if (
|
|
!method ||
|
|
(method !== 'magic-link' && method !== 'oauth') ||
|
|
!payload
|
|
) {
|
|
logger.error('Invalid authentication url', url);
|
|
return;
|
|
}
|
|
|
|
uiSubjects.authenticationRequest$.next({
|
|
method,
|
|
payload,
|
|
server,
|
|
});
|
|
} else if (
|
|
urlObj.searchParams.get('new-tab') &&
|
|
urlObj.pathname.startsWith('/workspace')
|
|
) {
|
|
// @todo(@forehalo): refactor router utilities
|
|
// basename of /workspace/xxx/yyy is /workspace/xxx
|
|
await addTabWithUrl(url);
|
|
} else {
|
|
const hiddenWindow = urlObj.searchParams.get('hidden')
|
|
? await openUrlInHiddenWindow(urlObj)
|
|
: await loadUrlInActiveTab(url);
|
|
|
|
const main = await getMainWindow();
|
|
if (main && hiddenWindow) {
|
|
// when hidden window closed, the main window will be hidden somehow
|
|
hiddenWindow.on('close', () => {
|
|
main.show();
|
|
});
|
|
}
|
|
}
|
|
}
|