mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-05 12:50:29 +02:00
49 lines
2.7 KiB
Markdown
49 lines
2.7 KiB
Markdown
|
# Note viewer isolation
|
||
|
|
||
|
The desktop application's note viewer runs in an `iframe` with a different protocol from the main application's top-level frame.
|
||
|
|
||
|
## Rationale
|
||
|
|
||
|
Running the note viewer from a different protocol and/or domain moves the `iframe`'s content to a separate process. This has at least two benefits:
|
||
|
1. Reduces the impact of bugs in Joplin's HTML sanitizer.
|
||
|
2. Improves performance when rendering large notes (see [issue #10424](https://github.com/laurent22/joplin/issues/10424)).
|
||
|
|
||
|
## Why does a different protocol improve performance/security?
|
||
|
|
||
|
Using a different domain and/or protocol for the note viewer does the following:
|
||
|
1. [enables Chromium's site isolation](https://www.chromium.org/developers/design-documents/site-isolation/) and
|
||
|
2. [prevents the note viewer from accessing the top-level context through `window.top`](https://developer.mozilla.org/en-US/docs/Web/Security/Same-origin_policy#cross-origin_script_api_access).
|
||
|
|
||
|
## The protocol
|
||
|
|
||
|
We use Electron's [protocol.handle](https://www.electronjs.org/docs/latest/api/protocol#protocolhandlescheme-handler) to register the `joplin-content://` protocol.
|
||
|
|
||
|
We use a `file://` URL to load the base electron application.
|
||
|
|
||
|
We use a `joplin-content://note-viewer/` URL to load the note viewer and the resources it contains.
|
||
|
|
||
|
For compatibility with renderer plugins that use absolute resource paths `joplin-content://note-viewer/` fetches files relative to the `/` directory.
|
||
|
|
||
|
Here's an example:
|
||
|
- The note viewer loads with the URL `joplin-content://note-viewer/tmp/.mount_JoplinA7E0A/path/to/the/note/viewer/here.html`
|
||
|
- The note renders and includes a resource with the path `/home/user/.config/joplin-desktop/path/here.css`
|
||
|
- `/home/user/.config/joplin-desktop/path/here.css` is converted to `joplin-content://note-viewer/home/user/.config/joplin-desktop/path/here.css` by Electron.
|
||
|
- Joplin checks to make sure the `joplin-content://` protocol has access to `/home/user/.config/joplin-desktop/path/here.css`. If it does, it fetches and returns the file.
|
||
|
|
||
|
|
||
|
## `joplin-content://` only has access to specific directories
|
||
|
|
||
|
When `handleCustomProtocols` creates a handler for the `joplin-content://` protocol, it returns an object that allows certain directories to be marked as readable.
|
||
|
|
||
|
By default, the list of readable directories includes:
|
||
|
- The app bundle
|
||
|
- Data directories for each of the enabled plugins
|
||
|
- The resource directory
|
||
|
- The profile directory
|
||
|
|
||
|
|
||
|
## Why not the [`sandbox`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/iframe#sandbox) property?
|
||
|
|
||
|
Enabling `sandbox` disables Electron's PDF viewer ([related HTML spec change](https://github.com/whatwg/html/pull/6946)) and prevents content within the note viewer from displaying/requesting resources.
|
||
|
|