mirror of
https://github.com/Qubes-Community/Contents.git
synced 2025-01-20 11:31:37 -05:00
misc changes
This commit is contained in:
parent
29bfa3bdb3
commit
723f9f02bc
@ -1,7 +1,7 @@
|
|||||||
How to open URLs/files in other VMs
|
How to open URLs/files in other VMs
|
||||||
====================================
|
===================================
|
||||||
|
|
||||||
This document shows various approaches on how to automatically open files/attachments/URLs in another VM, with or without user confirmation. This setup particularly suits "locked down" setups with restrictive firewalls like VMs dedicated to emails.
|
This document describes how to open files/attachments/URLs in another VM, with or without user confirmation. This setup particularly suits "locked down" setups with restrictive firewalls like VMs dedicated to emails.
|
||||||
|
|
||||||
Naming convention:
|
Naming convention:
|
||||||
|
|
||||||
@ -12,10 +12,10 @@ Naming convention:
|
|||||||
Configuring dom0 RPC permissions
|
Configuring dom0 RPC permissions
|
||||||
--------------------------------
|
--------------------------------
|
||||||
|
|
||||||
There are different approaches to open files and URLs in other VMs but they all involve the `qubes.OpenInVM` and `qubes.OpenURL` [RPC services](https://www.qubes-os.org/doc/qrexec3/#qubes-rpc-services), usually through the use of the `qvm-open-in-vm` and `qvm-open-in-dvm` shell scripts in `srcVM`.
|
There are different approaches to open files and URLs in other VMs but they all rely on the `qubes.OpenInVM` and `qubes.OpenURL` [RPC services](https://www.qubes-os.org/doc/qrexec3/#qubes-rpc-services), usually through the use of the `qvm-open-in-vm` and `qvm-open-in-dvm` shell scripts in `srcVM`.
|
||||||
|
|
||||||
Depending on the RPC service, `srcVM` and optionally `dstVM` Qubes RPC policies can be configured to allow, deny, or popup a list of available destination VMs. See the [official documentation](https://www.qubes-os.org/doc/rpc-policy/).
|
Qubes RPC policies can be configured based on the service name and `srcVM` (+ optionally `dstVM`) to allow or deny the use of the service, or to ask user confirmation with a popup list of destination VMs. See the [official documentation](https://www.qubes-os.org/doc/rpc-policy/).
|
||||||
In the case that `allow` is configured (ie. no popup dialog) *and* that different destination VMs should be used depending on the URL/file (site's level of trust, protocol, file [MIME](https://en.wikipedia.org/wiki/Media_type) type, ...), then some logic must exist in `srcVM`, either in the form of a custom wrapper to the `qvm-open-in-vm` script, or a specific application add-on.
|
In the case that an `allow` policy is configured (ie. no user confirmation/popup dialog) *and* that different destination VMs are to be used - eg. depending on the URL/file (site's level of trust, protocol, file [MIME](https://en.wikipedia.org/wiki/Media_type) type, ... - it is up to `srcVM` to specify the right `dstVM`, with the help of a custom wrapper to the `qvm-open-in-vm` script, or a specific application add-on.
|
||||||
|
|
||||||
|
|
||||||
Configuring `srcVM`
|
Configuring `srcVM`
|
||||||
@ -24,12 +24,12 @@ Configuring `srcVM`
|
|||||||
The subsections below list various approaches.
|
The subsections below list various approaches.
|
||||||
|
|
||||||
|
|
||||||
### Inter-VM - copy/paste and file copy ###
|
### Inter-VM copy/paste and file copy ###
|
||||||
|
|
||||||
That approach is obvious, but is the most simple one and doesn't require any configuration.
|
This approach is obvious and is the simplest one:
|
||||||
|
|
||||||
- URLs: [copy/paste](https://www.qubes-os.org/doc/copy-paste/) the link in `dstVM`'s browser.
|
- URLs: [copy/paste](https://www.qubes-os.org/doc/copy-paste/) the link in `dstVM`.
|
||||||
- Files: [copy](https://www.qubes-os.org/doc/copying-files/) the file to `dstVM` and open it from there.
|
- Files: [copy](https://www.qubes-os.org/doc/copying-files/) the file to `dstVM` (provided that `qubes.Filecopy` RPC service's policy allows it - it does by default), and open it from there.
|
||||||
|
|
||||||
|
|
||||||
### Command-line ###
|
### Command-line ###
|
||||||
@ -53,23 +53,24 @@ Note: `qvm-open-in-dvm` is actually a wrapper to `qvm-open-in-vm`.
|
|||||||
|
|
||||||
### Per application setup ###
|
### Per application setup ###
|
||||||
|
|
||||||
Most applications provide a way to select a given program to use for specific URL/file (MIME) types. We can thus use that feature to select the `qvm-open-in-{vm,dvm}` scripts instead of the default application programs.
|
Most applications provide a way to select a given program to use for opening specific URL/file (MIME) types. We can use that feature to select the `/usr/bin/qvm-open-in-{vm,dvm}` scripts instead of the default programs.
|
||||||
|
|
||||||
The subsections below show how to configure popular applications.
|
The subsections below show how to configure popular applications.
|
||||||
|
|
||||||
|
|
||||||
#### Thunderbird ####
|
#### Thunderbird ####
|
||||||
|
|
||||||
With Thunderbird one has to define actions for opening attachements (see the [mozilla doc](http://kb.mozillazine.org/Actions_for_attachment_file_types), mainly section "Download Actions" settings"). Changing the way http and https URLs are opened requires tweaking config options though (see [this mozilla doc](http://kb.mozillazine.org/Changing_the_web_browser_invoked_by_Thunderbird)). Those changes can be made in Thunderbird's config editor, or by adding the following to `$HOME/.thunderbird/user.js` like so:
|
Opening attachements: "actions" must be defined for opening attachements; see [this document](http://kb.mozillazine.org/Actions_for_attachment_file_types), section "Download Actions" settings".
|
||||||
|
|
||||||
|
Opening URLs: changing the way http and https URLs are opened requires tweaking configuration options; see [this](http://kb.mozillazine.org/Changing_the_web_browser_invoked_by_Thunderbird) and [this](http://kb.mozillazine.org/Network.protocol-handler.expose-all) document for more information. Those changes can be made in Thunderbird's built-in config editor, or by adding the following lines to `$HOME/.thunderbird/user.js`:
|
||||||
|
|
||||||
~~~
|
~~~
|
||||||
user_pref("network.protocol-handler.warn-external.http", true);
|
user_pref("network.protocol-handler.warn-external.http", true);
|
||||||
user_pref("network.protocol-handler.warn-external.https", true);
|
user_pref("network.protocol-handler.warn-external.https", true);
|
||||||
// http://kb.mozillazine.org/Network.protocol-handler.expose-all
|
|
||||||
user_pref("network.protocol-handler.expose-all", true);
|
user_pref("network.protocol-handler.expose-all", true);
|
||||||
~~~
|
~~~
|
||||||
|
|
||||||
Thunderbird will then ask which program to use the next time a link is opened. If `dstVM` is a standard dispVM, choose `qvm-open-in-dvm`. Otherwise you'll have to create a wrapper to `qvm-open-in-vm` since arguments cannot be passed to the program in Thunderbird's dialog. For instance, put the following in `$HOME/bin/thunderbird-url`, make it executable, and select that script when asked which program to use:
|
Thunderbird will then ask which program to use the next time a link is opened. If `dstVM` is a standard (random) dispVM, choose `/usr/bin/qvm-open-in-dvm`. Otherwise you'll have to create a wrapper to `qvm-open-in-vm` since arguments cannot be passed to programs selected in Thunderbird's dialog gui. For instance, put the following text in `$HOME/bin/thunderbird-open-url`, make it executable, and select that program when asked which program to use:
|
||||||
|
|
||||||
~~~
|
~~~
|
||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
@ -79,27 +80,27 @@ qvm-open-in-vm dstVM "$@"
|
|||||||
|
|
||||||
#### Firefox, Chrome/Chromium ####
|
#### Firefox, Chrome/Chromium ####
|
||||||
|
|
||||||
Those browsers have an option to define programs associated to a file (MIME) type ; those are pretty straightforward to configure so it's outside the scope of this document.
|
Those browsers have an option to define programs associated to a file (MIME) type. It is pretty straightforward to configure and is outside the scope of this document.
|
||||||
|
|
||||||
An alternative is to use Raffaele Florio's [qubes-url-redirector](https://github.com/raffaeleflorio/qubes-url-redirector) add-on which provides: links can be opened with a context menu and the add-on has a settings page embedded in the browser to customize its default behavior, with support for whitelist regexes. This provides a lot of flexibility without the hassle of having to write custom shell wrappers to `qvm-open-in-vm`.
|
An alternative is to use Raffaele Florio's [qubes-url-redirector](https://github.com/raffaeleflorio/qubes-url-redirector) add-on, which provides a lot of flexibility when opening links without the hassle of having to write custom shell wrappers to `qvm-open-in-vm`. For instance links can be opened with a context menu and the add-on's default behavior can be configured, even with whitelist regexes.
|
||||||
|
|
||||||
Note: the qubes-url-redirector add-on will likely be included officialy in the next Qubes release (see [this](https://github.com/QubesOS/qubes-issues/issues/3152) issue), easing concerns about installing third-party software. The addon may also support Thunderbird in the future.
|
Note: the qubes-url-redirector add-on will likely be included officialy in the next Qubes release (see [this](https://github.com/QubesOS/qubes-issues/issues/3152) issue). The addon may also support Thunderbird in the future.
|
||||||
|
|
||||||
|
|
||||||
#### Vi ####
|
#### Vi ####
|
||||||
|
|
||||||
Put the following in `$HOME/.vimrc` to open URLs in `dstVM` (type `gx` when the cursor is over an URL):
|
Opening URLs: put the following in `$HOME/.vimrc`:
|
||||||
|
|
||||||
~~~
|
~~~
|
||||||
let g:netrw_browsex_viewer = 'qvm-open-in-vm dstVM'
|
let g:netrw_browsex_viewer = 'qvm-open-in-vm dstVM'
|
||||||
~~~
|
~~~
|
||||||
|
|
||||||
|
Typing `gx` when the cursor is over an URL will then open it in `dstVM`.
|
||||||
|
|
||||||
|
|
||||||
### Application independent setup ###
|
### Application independent setup ###
|
||||||
|
|
||||||
The section above relied on configuring *each* application; while it provides a good amount of flexibility, it is time consuming when the same action/program should be used by *all* the applications in `srcVM`.
|
Configuring *each* application provides a good amount of flexibility but it may not be the best approach when one wants to use the same action/program in *all* the applications in `srcVM`. In that case, provided that the applications adhere to the [freedesktop](https://en.wikipedia.org/wiki/Freedesktop.org) standard, defining a global action for a given URL/file (MIME) type is straightforward:
|
||||||
|
|
||||||
Providing that the application adheres to the [freedesktop](https://en.wikipedia.org/wiki/Freedesktop.org) standard, defining a global action is straightforward:
|
|
||||||
|
|
||||||
- put the following in `~/.local/share/applications/browser_vm.desktop`
|
- put the following in `~/.local/share/applications/browser_vm.desktop`
|
||||||
|
|
||||||
@ -119,8 +120,7 @@ Providing that the application adheres to the [freedesktop](https://en.wikipedia
|
|||||||
|
|
||||||
The same can be done with any Mime type (see `man xdg-mime` and `xdg-settings`).
|
The same can be done with any Mime type (see `man xdg-mime` and `xdg-settings`).
|
||||||
|
|
||||||
Note again that `qvm-open-in-vm dstVM` can be replaced by a user written wrapper with custom logic for selecting a specific dstVM depending on the URL/file type, site level of trust, ...
|
Again, `qvm-open-in-vm dstVM` can be replaced by a user written wrapper with custom logic for selecting a specific dstVM depending on the URL/file type, site level of trust, ...
|
||||||
|
|
||||||
|
|
||||||
**Caveat**: if dom0 default permissions are set to allow without user confirmation applications can leak data through URLs despite `srcVM`'s restrictive firewall (you may notice that an URL has been open in `dstVM` but it would be too late).
|
**Caveat**: if dom0 default permissions are set to allow without user confirmation applications can leak data through URLs despite `srcVM`'s restrictive firewall (you may notice that an URL has been open in `dstVM` but it would be too late).
|
||||||
|
|
||||||
@ -142,11 +142,13 @@ Further considerations/caveats of using dispVMs
|
|||||||
|
|
||||||
Obviously, using dispVMs as `dstVM` means that changes are lost when `dstVM` is powered off so the increased security of this setup makes saving deliberate changes harder.
|
Obviously, using dispVMs as `dstVM` means that changes are lost when `dstVM` is powered off so the increased security of this setup makes saving deliberate changes harder.
|
||||||
|
|
||||||
- inter-VM copy/paste is probably the easiest way to synchronize passwords and bookmarks between `dstVM` and `srcVM` (or another dedicated secure VM like the oft-used 'vault' VM). The following solutions are for instance popular:
|
- inter-VM copy/paste is probably the easiest way to synchronize text between `dstVM` and `srcVM` (or another dedicated secure VM like the oft-used 'vault' VM). Eg.:
|
||||||
- manage passwords with KeepassX (or one of its forks).
|
- passwords: copy/paste from/to KeepassX (or one of its forks).
|
||||||
- manage bookmarks with a plain html file (that most browsers can export/import) or use a dedicated bookmark manager like [buku](https://github.com/jarun/Buku) (available in Fedora 28 repo - `dnf install buku`).
|
- bookmarks: copy/paste from/to a plain text file, or an html file (like most browsers can export/import), or a dedicated bookmark manager like [buku](https://github.com/jarun/Buku) (command line manager, available in Fedora 28 repo - `dnf install buku`).
|
||||||
- any change that cannot be copy/pasted easily will require updating `dstVM`'s template. Care must be taken not to replicate compromised files: working with a freshly started `dstVM` and performing only the required update actions before synchronizing files with the templateVM is a good idea.
|
- other content/changes will have to be copied, usually to `dstVM`'s templateVM. Care must be taken not to replicate compromised files: working with a freshly started `dstVM` and performing only the required update actions before synchronizing files with the templateVM is usually a good idea.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
`Contributors/Credits:` @Aekez, @raffaeleflorio, [Micah Lee](https://micahflee.com/2016/06/qubes-tip-opening-links-in-your-preferred-appvm/), @taradiddles
|
`Contributors`: @Aekez, @taradiddles
|
||||||
|
|
||||||
|
`Credits:` @raffaeleflorio, [Micah Lee](https://micahflee.com/2016/06/qubes-tip-opening-links-in-your-preferred-appvm/)
|
||||||
|
Loading…
Reference in New Issue
Block a user