Qubes code audit

I’m not sure that a clear definition has been given.

The flexible nature of a community project like this is valuable. But structure is also valuable. I want to emphasize again the benefits of creating user profiles that are of interest to the community. This will help people keep realistic threats in mind. And people who are focused on a more narrow scope might notice a problem that doesn’t fit into their scope, but being primed with the range of threats that are of interest would make it more likely for them to notice those problems. And I like to think that most people would responsibly report a problem if they see it even if it doesn’t impact them directly.

I also want to note that I would typically love to participate more in a process like this, but I’m currently working on creating a Guix template for QubesOS while also working on an academic portfolio so that I’ll actually get admitted to school the next time around on top of working a full-time job so I can pay the bills… so I don’t have much spare time at the moment. =(

1 Like

One possibility would be to write a “Introduction to code auditing” which gives full examples of going in and investigating pieces of qubes code, (including things like where to download the qubes source from), and with a little bit of context so they understand what exactly they are auditing. Possibly even write it as a wikiversity book.

This could get more people into the audit group, even if at a basic level. And once they learn more, they might add that to the book.

We may also want to think through how people should report “hey I found this… is it a problem?” to other auditors before flagging it as a actual problem. (I.E. In short, it may be necessary to thin down the false alarms before they get passed to the qubes team)
One option for reporting would be to have people report it to github so that the report can point to the exact line of code in the exact version of the exact package. Another option would be something more customized where people could report what chunks they have audited, and if they found something or not. Then you could compute summary statics like “how many of the files that I said were fine were later discovered by someone else to have contained a problem?”. This would be actual feedback for people who are now learning code auditing.

Just some Ideas

2 Likes

I think the forum would be a reasonable place for this kind of discussion to happen. We don’t want to flood the developers with a large number of reports of varying quality. That would end up causing more problems than it solves, because it would take away time that could be spent addressing issues and a dedicated attacker might be able to find valuable reports before the team has a chance to respond to them. I could definitely help with the filtering process and summarizing reports into a concise problem/impact description. This is essentially what I did for most of my ~4 years as a consultant.

I do have a concern about confidentiality. The QubesOS team prefers to keep security issues confidential until they are fixed, but that is in tension with the very idea of having a large community-based audit. I don’t think it would be practical to keep everything confidential and find success in this kind of effort. So… I would feel more comfortable if someone representing the QubesOS team made a statement on that aspect of it before we started.

This sounds like a really valuable tool but also one that would take a lot of work to build. I agree that it would help a lot with coordinating this kind of audit in a decentralized fashion. I also think it would help us find organizational problems (for example, it might turn out that this kind of audit is good at finding bugs within the logic of a single module but consistently misses cross-module bugs) and help newcomers learn from prior work before they get started.

1 Like

I already asked the team whether they think that this community audit is a good idea, and they said they do. They are, of course, aware that a security vulnerability could be discovered in any kind of code audit. If that were to happen during this community audit, then the auditors should do their best to respect the guidelines for reporting security issues in Qubes OS, but I don’t think anyone expects or wants a community audit to be conducted in secret. I agree that would be both impractical and undesirable.

7 Likes

There has to be some degree of secrecy. What were you expecting to do if you find a security-busting, double-0-day RCE explote? Just post about it on the forum so we can all get our qubes ransacked at once by script kiddies? :grimacing:

Actually, on second thought, yeah let’s do just that. Wild west rule. :horse_racing: :partying_face: If you don’t keep up with community bulletins you get hacked and lose all the loot in your inventory.

My reasoning: anything we find with a community audit is likely to already have been found by their state-funded counterparts (not because we’re bad but because they have money cheatcodes), in which case it is already being employed against the people. I don’t know about you but I’d rather take an L for the team to a script kiddie if that’s what it takes to patch a hole that is otherwise being used by god knows who to spy on Qubes users daily.

Throw Qubes OS into the forge. It can only come out stronger and better.

1 Like

By necessity it wouldn’t be secret - as soon as we include any comms in the audit design then we can’t give them much trust, because we’ve no sensible way of checking community volunteers aren’t state-sponsored or other malicious. I might be wrong, but I think in the Qubes context shouting louder about a vulnerability won’t get it fixed faster, so there’s no reason to shout from the rooftops once the information is technically discoverable. If someone on the audit manages to realize a vulnerability is sensitive before they’ve drawn the group’s attention to it, then it makes sense to report it in the usual way without opening any internal discussion.

What could be bad is the auditors openly discussing whether a vulnerability is serious for weeks without informing the team. If in doubt, better to send a report than not.

4 Likes

Let’s imagine two possible examples:

  1. One of the participants in the community audit discovers a vulnerability, and the other participants don’t know about it yet. In this case, the discoverer can responsibly disclose the vulnerability to the Qubes security team without informing anyone else and without announcing it publicly.

  2. In the course of a public discussion, the participants in the community audit realize that they have discovered a vulnerability. Since their discussion is already public, all they can do is inform the Qubes security team of what they’ve discovered, including the fact that it’s already public.

I took @skyvine to be asking about the first sort of scenario. It doesn’t make sense to ask about the second sort of scenario, because once you’ve said something publicly on this forum, for example, you can’t snatch it back from other people’s inboxes (or from their minds).

By that logic, allowing the code to be open source is also “wild west rule,” because it allows bad actors to discover vulnerabilities more easily. Should we also keep the source code secret for the sake of security? Of course not, because that’s just the old security-through-obscurity fallacy.

There’s currently no such thing as “community bulletins” (unlike security bulletins, which do exist), but let’s imagine for a moment that the community were to start issuing their own community bulletins, perhaps in conjunction with this community audit. Let’s imagine they’re like a community-run version of QSBs. There are several things to keep in mind:

  1. QSBs on their own don’t do anything to your system. It’s the security patches released alongside QSBs that actually patch your system and protect it. The QSB itself is just a text document. It’s purely informational.

  2. Sometimes, QSBs contain instructions for special user actions that are required to address security vulnerabilities. This is relatively rare, but it does happen from time to time. In this case, it’s users actually following the instructions and taking those actions on their own systems that does something.

  3. It’s unlikely that community security bulletins would be accompanied by community security patches. Not only would this require considerable expertise (to actually create working patches), but it would probably be very difficult for most Qubes users to trust the patches. It would probably also be non-trivial for many users to actually install the patches, since the community doesn’t have access to official Qubes signing keys.

  4. This means that the utility of community bulletins would probably be limited to providing instructions for users to follow in order to make modifications to their own systems. This is risky for most users, since following such instructions (e.g., entering commands one doesn’t understand in dom0) could compromise the system.

  5. This also assumes that the there wouldn’t be an official QSB (and possibly accompanying patches) that address the same security vulnerabilities. If there’s both an official QSB and an unofficial community bulletin for the same vulnerability, then there’s no reason to follow the community bulletin. It’s more risk for no added benefit.

3 Likes

or what system is in place to get it audited? Whats the point of making it open source, if its never going to be audited? or perhaps auditing parts of qube code that has the higher probability of being exploited?

And to the mods, ill stop posting if you just want users to have blind trust.

Here’s just one idea. If there’s already not a youtube channel, qubes team can make one. And they themselves can audit parts of there code. Inviting and encouraging others to do the same. This way forum participants here will have something tangible to share in security forums.

Has there been any, read through the post. doesnt seem to find any details of an audit. also there were suggestion of adding “code audit” section to the forum. Which i dont see implemented here.

The term “audit” implies that it’s done by someone independent so it’s not an audit if the developers will check their own code by themselves.
As for the audit of third-party components:

1 Like

This is false. Keeping the code open at least enables anyone to audit the code themselves and to organize the paid audit in the future, apart from many other advantages of FLOSS.

You can’t be so sure. Interested users certainly did read the code, if you follow this forum.

They wrote the code themselves and confirm its correctness (to the best of their knowledge) by signing ISOs with the Qubes Master Key.

Maybe it should be created, but at the moment there is no single topic that would fit there, because there is no active ongoing community audit as far as I know. You could probably start it yourself instead of complaining. Creating a new Section and moving a post there is easy. Making an audit isn’t.

This is not relevant to this topic. Also, Qubes team is extremely busy keeping Qubes secure, up-to-date and writing the new version, 4.3. Their resources are very limited. Creating such a video is sufficiently simple that any user could probably do it. Also, Qubes’ security is in principle already explained at https://qubes-os.org, which is why I switched to Qubes.

3 Likes

One issue I have is that I can never find anything in GitHub. Apparently Qubes is broken down into a lot of sub-projects, and the search will either function just in the sub-project you happen to be looking at (which is likely the wrong one), or ALL of GitHub (so you get buried in totally irrelevant hits).

When I commented on this some time ago, I was told to just ask where such-and-such feature was implemented. What an auditor would really need is a top-down guide to which project correspond to which features (and/or specific executables/scripts/config files) in QubesOS.

2 Likes

How would you trust the audit done by some stranger?

Let’s imagine I say I audited Qubes OS code and everything was fine, how could you trust me? I could write a fake report saying everything is good.

Qubes OS being open source allows audits, but also people to contribute, figure where an issue comes from and fix it and then offer the fix upstream so it benefits everyone.

1 Like

Probably best to cut out the middleman. Download the source locally, do your searching across the repos with your own superior local tools.

If you really do want to clone all of the repositories, you can use these commands:

curl "https://api.github.com/orgs/QubesOS/repos?page=1&per_page=100" | grep -e 'clone_url*' | cut -d \" -f 4 | xargs -L1 git clone
curl "https://api.github.com/orgs/QubesOS/repos?page=2&per_page=100" | grep -e 'clone_url*' | cut -d \" -f 4 | xargs -L1 git clone
1 Like

Is it really that difficult for the official team to provide that?

official source would be better to avoid the following issue -

Not sure how laborious cloning all repositories would be, but if we can facilitate than burdening with laborious task, that would be helpful. And shouldn’t be a difficult task for official qubes team, i guess.

I hope the above code helps @SteveC solve his issue and we finally move towards a solution.

with a GitHub account, the search can work within Qubes OS organization or project, this is really handy when looking for functions names where it’s used in project B and defined in project A.

Completely unrelated to the main topic, the fact that there’s basically no README in most of them makes learning curve look like a learning cliff for potential contributors. Why?

1 Like

You don’t need to. A stranger just point to a suspicious part of the code and everyone decides themselves if it’s really problematic.