2015-01-14 07:16:27 -05:00
|
|
|
---
|
2021-03-13 13:06:18 -05:00
|
|
|
lang: en
|
2019-05-26 21:04:23 -04:00
|
|
|
layout: doc
|
2021-06-16 22:56:25 -04:00
|
|
|
permalink: /security/pack/
|
2015-10-11 03:04:59 -04:00
|
|
|
redirect_from:
|
2017-03-18 22:31:12 -04:00
|
|
|
- /doc/security-pack/
|
2015-10-28 18:14:40 -04:00
|
|
|
- /en/doc/security-pack/
|
2021-06-14 23:58:18 -04:00
|
|
|
- /security-pack/
|
2015-10-11 03:04:59 -04:00
|
|
|
- /doc/SecurityPack/
|
|
|
|
- /wiki/SecurityPack/
|
2016-07-13 07:21:37 -04:00
|
|
|
- /qsp/
|
|
|
|
- /sec-pack/
|
|
|
|
- /secpack/
|
|
|
|
- /doc/qsp/
|
|
|
|
- /doc/sec-pack/
|
|
|
|
- /doc/secpack/
|
2021-03-13 13:06:18 -05:00
|
|
|
ref: 213
|
2021-06-17 05:40:43 -04:00
|
|
|
title: Qubes Security Pack (qubes-secpack)
|
2015-01-14 07:16:27 -05:00
|
|
|
---
|
|
|
|
|
2021-06-18 09:25:06 -04:00
|
|
|
The **Qubes Security Pack** (`qubes-secpack`) is a Git repository that
|
|
|
|
contains:
|
2015-01-14 07:16:27 -05:00
|
|
|
|
2021-06-22 13:50:12 -04:00
|
|
|
* [Qubes Security Bulletins (QSBs)](/security/qsb/)
|
2021-06-22 14:00:51 -04:00
|
|
|
* [Qubes Canaries](/security/canary/)
|
|
|
|
* [Signed Qubes ISO digests](/security/verifying-signatures/#how-to-verify-qubes-iso-digests)
|
2021-06-15 00:08:22 -04:00
|
|
|
* [Qubes fund information](https://github.com/QubesOS/qubes-secpack/tree/master/fund)
|
2021-06-22 14:00:51 -04:00
|
|
|
* [Qubes PGP keys](https://keys.qubes-os.org/keys/)
|
2021-03-13 12:03:23 -05:00
|
|
|
* Security-related information and announcements (e.g., key revocations)
|
2015-01-14 07:16:27 -05:00
|
|
|
|
2016-11-22 17:33:56 -05:00
|
|
|
While `qubes-secpack` itself is independent of any particular host, its current
|
|
|
|
official location is:
|
2015-06-04 23:19:01 -04:00
|
|
|
|
2016-11-22 17:33:56 -05:00
|
|
|
<https://github.com/QubesOS/qubes-secpack>
|
2015-01-14 07:16:27 -05:00
|
|
|
|
2021-06-14 23:58:18 -04:00
|
|
|
## How to obtain, verify, and read
|
2015-01-14 07:16:27 -05:00
|
|
|
|
2016-11-22 17:33:56 -05:00
|
|
|
The following example demonstrates one method of obtaining the `qubes-secpack`,
|
|
|
|
verifying its contents, and reading them.
|
2015-01-14 07:16:27 -05:00
|
|
|
|
2021-03-13 12:03:23 -05:00
|
|
|
1. Clone the `qubes-secpack` repo.
|
|
|
|
|
|
|
|
```shell_session
|
|
|
|
$ git clone https://github.com/QubesOS/qubes-secpack.git
|
|
|
|
Cloning into 'qubes-secpack'...
|
|
|
|
remote: Counting objects: 195, done.
|
|
|
|
remote: Total 195 (delta 0), reused 0 (delta 0)
|
|
|
|
Receiving objects: 100% (195/195), 130.94 KiB | 207.00 KiB/s, done.
|
|
|
|
Resolving deltas: 100% (47/47), done.
|
|
|
|
Checking connectivity... done.
|
|
|
|
```
|
|
|
|
|
|
|
|
2. Import the included PGP keys.
|
|
|
|
|
|
|
|
```shell_session
|
|
|
|
$ gpg --import qubes-secpack/keys/*/*
|
|
|
|
gpg: directory `/home/user/.gnupg' created
|
|
|
|
gpg: new configuration file `/home/user/.gnupg/gpg.conf' created
|
|
|
|
gpg: WARNING: options in `/home/user/.gnupg/gpg.conf' are not yet active during this run
|
|
|
|
gpg: keyring `/home/user/.gnupg/secring.gpg' created
|
|
|
|
gpg: keyring `/home/user/.gnupg/pubring.gpg' created
|
|
|
|
gpg: /home/user/.gnupg/trustdb.gpg: trustdb created
|
|
|
|
gpg: key C37BB66B: public key "Joanna Rutkowska (Qubes OS signing key) <joanna@invisiblethingslab.com>" imported
|
|
|
|
gpg: key 1E30A75D: public key "Joanna Rutkowska (Qubes OS signing key) <joanna@invisiblethingslab.com>" imported
|
|
|
|
gpg: key 74EADABC: public key "Joanna Rutkowska (Qubes OS signing key) <joanna@invisiblethingslab.com>" imported
|
|
|
|
gpg: key 65EF29CA: public key "Joanna Rutkowska (Qubes OS Signing Key) <joanna@invisiblethingslab.com>" imported
|
|
|
|
gpg: key 34898310: public key "Joanna Rutkowska (Qubes OS Signing Key) <joanna@invisiblethingslab.com>" imported
|
|
|
|
gpg: key B298547C: public key "Marek Marczykowski (Qubes OS signing key) <marmarek@mimuw.edu.pl>" imported
|
|
|
|
gpg: key AB5EEF90: public key "Marek Marczykowski (Qubes OS signing key) <marmarek@invisiblethingslab.com>" imported
|
|
|
|
gpg: key A603BCB6: public key "Marek Marczykowski (Qubes OS signing key) <marmarek@invisiblethingslab.com>" imported
|
|
|
|
gpg: key 42CFA724: public key "Marek Marczykowski-Górecki (Qubes OS signing key) <marmarek@invisiblethingslab.com>" imported
|
|
|
|
gpg: key 15CE40BF: public key "Wojciech Zygmunt Porczyk (Qubes OS signing key) <woju@invisiblethingslab.com>" imported
|
|
|
|
gpg: key 36879494: public key "Qubes Master Signing Key" imported
|
|
|
|
gpg: key 211093A7: public key "Qubes OS Release 1 Signing Key" imported
|
|
|
|
gpg: key 0A40E458: public key "Qubes OS Release 2 Signing Key" imported
|
|
|
|
gpg: key 03FA5082: public key "Qubes OS Release 3 Signing Key" imported
|
|
|
|
gpg: key 92C7B3DC: public key "Joanna Rutkowska (Qubes Security Pack Signing Key) <joanna@invisiblethingslab.com>" imported
|
|
|
|
gpg: key 1830E06A: public key "Marek Marczykowski-Górecki (Qubes security pack) <marmarek@invisiblethingslab.com>" imported
|
|
|
|
gpg: key 3F48CB21: public key "Qubes OS Security Team <security@qubes-os.org>" imported
|
|
|
|
gpg: Total number processed: 17
|
|
|
|
gpg: imported: 17 (RSA: 17)
|
|
|
|
gpg: no ultimately trusted keys found
|
|
|
|
```
|
|
|
|
|
|
|
|
3. Verify and trust the Qubes Master Signing Key.
|
|
|
|
|
|
|
|
```shell_session
|
|
|
|
$ gpg --edit-key 36879494
|
|
|
|
gpg (GnuPG) 1.4.18; Copyright (C) 2014 Free Software Foundation, Inc.
|
|
|
|
This is free software: you are free to change and redistribute it.
|
|
|
|
There is NO WARRANTY, to the extent permitted by law.
|
|
|
|
|
|
|
|
|
|
|
|
pub 4096R/36879494 created: 2010-04-01 expires: never usage: SC
|
|
|
|
trust: unknown validity: unknown
|
|
|
|
[ unknown] (1). Qubes Master Signing Key
|
|
|
|
|
|
|
|
gpg> fpr
|
|
|
|
pub 4096R/36879494 2010-04-01 Qubes Master Signing Key
|
|
|
|
Primary key fingerprint: 427F 11FD 0FAA 4B08 0123 F01C DDFA 1A3E 3687 9494
|
|
|
|
|
|
|
|
gpg> trust
|
|
|
|
pub 4096R/36879494 created: 2010-04-01 expires: never usage: SC
|
|
|
|
trust: unknown validity: unknown
|
|
|
|
[ unknown] (1). Qubes Master Signing Key
|
|
|
|
|
|
|
|
Please decide how far you trust this user to correctly verify other users' keys
|
|
|
|
(by looking at passports, checking fingerprints from different sources, etc.)
|
|
|
|
|
|
|
|
1 = I don't know or won't say
|
|
|
|
2 = I do NOT trust
|
|
|
|
3 = I trust marginally
|
|
|
|
4 = I trust fully
|
|
|
|
5 = I trust ultimately
|
|
|
|
m = back to the main menu
|
|
|
|
|
|
|
|
Your decision? 5
|
|
|
|
Do you really want to set this key to ultimate trust? (y/N) y
|
|
|
|
|
|
|
|
pub 4096R/36879494 created: 2010-04-01 expires: never usage: SC
|
|
|
|
trust: ultimate validity: unknown
|
|
|
|
[ unknown] (1). Qubes Master Signing Key
|
|
|
|
Please note that the shown key validity is not necessarily correct
|
|
|
|
unless you restart the program.
|
|
|
|
|
|
|
|
gpg> q
|
|
|
|
```
|
|
|
|
|
|
|
|
**Important!**
|
|
|
|
|
|
|
|
In order to verify the authenticity of the Qubes Master Signing Key prior to
|
|
|
|
trusting it, you should obtain the Qubes Master Signing Key fingerprint from
|
|
|
|
a trustworthy source (ideally, multiple sources) *other than* this website
|
|
|
|
and visually compare it (them) to the fingerprint displayed in the preceding
|
|
|
|
step, ensuring they match. You can read more about digital signatures and
|
|
|
|
key verification [here](/security/verifying-signatures/).
|
|
|
|
|
|
|
|
4. Verify signed Git tags.
|
|
|
|
|
|
|
|
```shell_session
|
|
|
|
$ cd qubes-secpack/
|
|
|
|
$ git tag -v `git describe`
|
|
|
|
object 2bb7f0b966593d8ed74e140a04d60c68b96b164e
|
|
|
|
type commit
|
|
|
|
tag joanna_sec_2bb7f0b9
|
|
|
|
tagger Joanna Rutkowska <joanna@invisiblethingslab.com> 1468335706 +0000
|
|
|
|
|
|
|
|
Tag for commit 2bb7f0b966593d8ed74e140a04d60c68b96b164e
|
|
|
|
gpg: Signature made 2016-07-12T08:01:46 PDT
|
|
|
|
gpg: using RSA key 0x4E6829BC92C7B3DC
|
|
|
|
gpg: Good signature from "Joanna Rutkowska (Qubes Security Pack Signing Key) <joanna@invisiblethingslab.com>" [full]
|
|
|
|
```
|
2015-01-14 07:16:27 -05:00
|
|
|
|
2016-07-13 07:21:37 -04:00
|
|
|
(The final line of output confirms that the signature is good.)
|
|
|
|
|
2021-03-13 12:03:23 -05:00
|
|
|
5. Verify detached PGP signatures.
|
2016-07-13 07:21:37 -04:00
|
|
|
|
2021-03-13 12:03:23 -05:00
|
|
|
```shell_session
|
|
|
|
$ cd canaries/
|
|
|
|
$ gpg --verify canary-001-2015.txt.sig.joanna canary-001-2015.txt
|
|
|
|
gpg: Signature made Mon Jan 5 20:21:40 2015 UTC using RSA key ID 92C7B3DC
|
|
|
|
gpg: Good signature from "Joanna Rutkowska (Qubes Security Pack Signing Key) <joanna@invisiblethingslab.com>"
|
|
|
|
$ gpg --verify canary-001-2015.txt.sig.marmarek canary-001-2015.txt
|
|
|
|
gpg: Signature made Mon Jan 5 20:13:37 2015 UTC using RSA key ID 1830E06A
|
|
|
|
gpg: Good signature from "Marek Marczykowski-Górecki (Qubes security pack) <marmarek@invisiblethingslab.com>"
|
|
|
|
```
|
2015-01-14 07:16:27 -05:00
|
|
|
|
2021-03-13 12:03:23 -05:00
|
|
|
(The fourth and final lines of output confirm that the two signatures are
|
|
|
|
good.)
|
2016-07-13 07:21:37 -04:00
|
|
|
|
2016-11-22 17:33:56 -05:00
|
|
|
The same procedures can be applied to any directory or file in the
|
2017-05-11 04:48:59 -04:00
|
|
|
`qubes-secpack`. Two methods of verification (signed Git tags and detached PGP
|
2016-11-22 17:33:56 -05:00
|
|
|
signatures) are provided to ensure that the system is robust (e.g., against a
|
|
|
|
potential failure in Git tag-based verification) and to give users more options
|
|
|
|
to verify the files.
|
2021-06-14 23:58:18 -04:00
|
|
|
|
|
|
|
|
|
|
|
## History and rationale
|
|
|
|
|
|
|
|
On 2013-01-05, Joanna Rutkowska announced the `qubes-secpack` and explained its
|
|
|
|
rationale in an
|
|
|
|
[email](https://groups.google.com/d/msg/qubes-devel/twkOEaMLtNI/lZyGx6_jFCEJ)
|
|
|
|
to the Qubes mailing lists:
|
|
|
|
|
|
|
|
```
|
|
|
|
Hello,
|
|
|
|
|
|
|
|
A new Qubes Security Bulletin has been just released and is available here:
|
|
|
|
|
|
|
|
https://github.com/QubesOS/qubes-secpack/blob/master/QSBs/qsb-013-2015.txt
|
|
|
|
|
|
|
|
As per the previous discussions about recent problems with verifying
|
|
|
|
digital signatures on messages sent to Google Groups (thanks to
|
|
|
|
automatic footer addition by Google), we have decided to change the way
|
|
|
|
we publish Qubes Security Bulletins, as well as other security-related
|
|
|
|
info pertinent to the Qubes Project.
|
|
|
|
|
|
|
|
Starting today, we will be maintain a Git repository -- "Qubes Security
|
|
|
|
Pack" -- which will contain all the QSBs released so far, all the keys,
|
|
|
|
warrant canaries [1], and potentially some additional info or
|
|
|
|
announcements (e.g. key revocations). The whole repo can be found here:
|
|
|
|
|
|
|
|
https://github.com/QubesOS/qubes-secpack
|
|
|
|
|
|
|
|
Note that all the keys distributed there should be signed by Qubes
|
|
|
|
Master Key. The Master Key is also attached in the repo, but should
|
|
|
|
really be obtained/verified using a different channel.
|
|
|
|
|
|
|
|
Additionally, most of the files are signed by core Qubes
|
|
|
|
developers (currently by Marek and myself) via detached signatures as
|
|
|
|
well as git tag signatures.
|
|
|
|
|
|
|
|
The are several advantages of using Git to distribute all these information:
|
|
|
|
|
|
|
|
1) Git repo is a collection of files, some of which can be detached GPG
|
|
|
|
signatures for other files and we can ensure all these files are
|
|
|
|
distributed together.
|
|
|
|
|
|
|
|
2) Git makes it easy for people to clone and redistribute these
|
|
|
|
collection of files, as well as to easily host them and view on the Web.
|
|
|
|
|
|
|
|
3) Git provides for signed tags mechanisms which is another mean we
|
|
|
|
utilize to ensure integrity of the distributed files.
|
|
|
|
|
|
|
|
A few words about the Warrant Canary which we've just introduced today,
|
|
|
|
and which can be seen here:
|
|
|
|
|
|
|
|
https://github.com/QubesOS/qubes-secpack/blob/master/canaries/canary-001-2015.txt
|
|
|
|
|
|
|
|
Even though we're not providing any kind of services (such as e.g. email
|
|
|
|
hosting), that could be searched or tapped by authorities, there are
|
|
|
|
other possibilities that worry us [2], in the light of various recent
|
|
|
|
law "developments", such as those that might be coercing people to hand
|
|
|
|
over their private keys to authorities.
|
|
|
|
|
|
|
|
Until we fully decentralize the root of trust for Qubes, something that
|
|
|
|
requires the move to deterministic builds [3], and so won't happen
|
|
|
|
very soon, the possibility of having to disclose any of the Qubes
|
|
|
|
signing keys to anybody might have pretty serious consequences for those
|
|
|
|
who decided to entrust Qubes with anything serious. And we would like to
|
|
|
|
somehow minimize these consequences with this canary thing.
|
|
|
|
|
|
|
|
Additionally the canary is a nice way of ensuring "freshness" of our
|
|
|
|
messaging to the community.
|
|
|
|
|
|
|
|
Of course the canary doesn't solve all the problems. E.g. if my signing
|
|
|
|
keys were somehow stolen without our knowledge, it wouldn't help.
|
|
|
|
Neither it could help in case me being or becoming a miscreant. And
|
|
|
|
probably it doesn't address many other potential problems, which could
|
|
|
|
only be solved one day with a multi-signature scheme. But anyway, until
|
|
|
|
that time, this is the best we can do, I think.
|
|
|
|
|
|
|
|
And congrats to Jann for the very interesting clipboard attack (even
|
|
|
|
though mostly theoretical, still very cool)!
|
|
|
|
|
|
|
|
Thanks,
|
|
|
|
joanna.
|
|
|
|
|
|
|
|
--
|
|
|
|
The Qubes Security Team
|
|
|
|
https://www.qubes-os.org/doc/SecurityPage
|
|
|
|
|
|
|
|
|
|
|
|
[1] http://en.wikipedia.org/wiki/Warrant_canary
|
|
|
|
|
|
|
|
[2] Especially myself, because I'm currently the Root Of Trust for all
|
|
|
|
Qubes binaries :/
|
|
|
|
|
|
|
|
[3] Deterministic builds are required because it's the only way we can
|
|
|
|
implement multiple signature scheme for distributed binaries.
|
|
|
|
|
|
|
|
```
|
|
|
|
|