qubes-doc/developer/general/gsod.md

147 lines
8.2 KiB
Markdown
Raw Normal View History

2019-04-19 23:06:47 -04:00
---
lang: en
layout: doc
permalink: /gsod/
ref: 242
title: Google Season of Docs (GSoD)
2019-04-19 23:06:47 -04:00
---
Thank you for your interest in participating in the [2021 Google Season of Docs](https://developers.google.com/season-of-docs/) program with the [Qubes OS team](/team/). You can read more about the Google Season of Docs in the official [guides](https://developers.google.com/season-of-docs/docs/) and [FAQ](https://developers.google.com/season-of-docs/docs/faq).
2019-04-19 23:06:47 -04:00
## 2021 Project Idea
2019-04-19 23:06:47 -04:00
### Qubes OS on Virtual Machines and Disposable VMs documentation - Qubes OS
2019-04-19 23:06:47 -04:00
#### About your organization
2019-04-19 23:10:09 -04:00
Qubes OS is a free and open source operating system uniquely designed to protect the security and privacy of the user. Its architecture is built to enable a user to define different security environments ("qubes") on their computer and visually manage their interaction with each other and the world.
2019-04-19 23:06:47 -04:00
Qubes OS was launched in 2011 and has [received praise from security experts](https://www.qubes-os.org/experts/) like Edward Snowden, Bill Buddington (EFF), Isis Lovecruft (Tor Project), and Kenn White (Open Crypto Audit), and has over [30,000 active users](https://www.qubes-os.org/statistics/).
2019-04-19 23:06:47 -04:00
From network-level to software-level protections, as well as protections against firmware and hardware attacks, Qubes OS is trying to protect the user from the most significant attacks they encounter so that they can get their work done, safely.
2019-04-19 23:06:47 -04:00
#### The Project
2019-04-19 23:06:47 -04:00
The goal of the project is to improve the documentation related to Disposable VMs and installing Qubes OS on Virtual Machines.
2019-04-19 23:06:47 -04:00
The current Disposable VMs documentation is scarce, inconsistent in places and is scattered across multiple pages, sometimes hard to find. This project involves consolidating it into one or few easy to find pages, covering all related subjects. It should be written in way easy to follow and understand, clearly separating basic use cases, advanced ones and internal details. The terminology should also be used consistently.
2019-04-19 23:06:47 -04:00
Additionally, Qubes OS is missing an installation guide for virtual machines. Users are installing an outdated and unsupported version of Qubes OS (3.2) instead of the supported version. There is unofficial existing installation guide for Qubes OS on a virtual box but it is misleading and lacks documentation. Usually, users face some errors and bugs while installing Qubes OS on a virtual machine. This project also involves writing an installation guide that details how to install Qubes on virtual machines, and how to troubleshoot any issues that may arise.
2019-04-22 17:44:38 -04:00
#### Projects scope
2019-04-22 17:44:38 -04:00
The technical writer will:
2019-04-22 17:44:38 -04:00
* Review existing Disposable VM documentation
2019-04-22 17:44:38 -04:00
* Propose new documentation layout, including split between pages
2019-04-22 17:44:38 -04:00
* Propose updated and clarified content
2019-04-22 17:44:38 -04:00
* Provide a new option of installation guide for users working on virtual machines.
2019-04-22 17:44:38 -04:00
* Review existing problems and provide solutions to them.
2019-04-22 17:44:38 -04:00
* Giving a warning for using outdated versions of Qubes.
2019-04-22 17:44:38 -04:00
Knowledge prerequisites:
2019-04-22 17:44:38 -04:00
* Basic Qubes OS knowledge - intro, getting started.
2019-04-22 17:44:38 -04:00
* Markdown.
2019-04-22 17:44:38 -04:00
* Experience in virtual boxes and machines.
2019-04-22 17:44:38 -04:00
* Basic knowledge about Fedora Linux architecture.
2019-04-23 06:38:23 -04:00
The project is estimated to need around 6 months, with a part-time (20hr/week) workload. Qubes OS team members focused on documentation (Michael Carbone, Andrew David Wong, Marek Marczykowski-Górecki) have committed to supporting the project.
2019-04-23 06:38:23 -04:00
#### Measuring the projects success
2019-04-23 06:38:23 -04:00
We will consider the project successful if, after publication of the new documentation:
2019-04-23 06:38:23 -04:00
* The Disposable VM documentation is consilidated into a few pages and easier to find.
2019-04-23 06:38:23 -04:00
* Disposable VM terminology is consistent across all pages
2019-04-23 06:38:23 -04:00
* There is a new installation guide detailing how to install Qubes on virtual machines (VirtualBox), complete with screenshots and troubleshooting steps where necessary.
2019-04-23 06:38:23 -04:00
* There is a decrease (by ~20%) in the number of issues and questions raised for topics covered in the documentation, whether in the official Github issues tracker, the Qubes mailing list, or the Qubes community forum.
2019-04-23 06:38:23 -04:00
#### Budget
| Budget item | Amount | Running total | Note / Justification |
|-|-|-|-|
| Technical writer audit, update, and write new documentation | $12000 | $12000 | based on a 20hr/week for 6 months at 25$/hr |
| TOTAL | | $12000 | |
#### Additional information
Qubes OS regularly participates in the Google Summer of Code and Google Season of Docs. This is our third time in a row participating in Google Season of Docs. Our mentorships for GSoD 2019 and 2020 were successes and both projects were completed
within the times allotted. The past Google Season of Docs projects have given us experience in working with technical writers, and has helped us to understand the benefits of technical writers can to our project
## Past Projects
You can view the project we had in 2019 in the [2019 GSoD archive](https://developers.google.com/season-of-docs/docs/2019/participants/project-qubes) and the [2019 writer's report](https://refre.ch/report-qubesos/).
You can also view the project we had in 2020 in the [2020 GSoD archive](https://developers.google.com/season-of-docs/docs/2020/participants/project-qubesos-c1e0) and the [2020 writer's report](https://gist.github.com/PROTechThor/bfe9b8b28295d88c438b6f6c754ae733).
Here are some successful projects which have been implemented in the past by Google Season of Docs participants.
2019-04-23 06:38:23 -04:00
### Consolidate troubleshooting guides
**Project**: Consolidate troubleshooting guides
**Brief explanation**: Troubleshooting guides are scattered across many pages and sometimes incomplete, leading to repeatedly posting the same instruction over and over when helping users to diagnose problems.
This could be helped by writing a consolidated guide with a clear list of symptom-action layout.
2019-04-23 06:38:23 -04:00
**Expected results**:
- Review existing [troubleshooting guides](/doc/#troubleshooting)
- Review [issues](https://github.com/QubesOS/qubes-issues/issues?q=is%3Aopen+is%3Aissue+label%3A%22C%3A+doc%22) containing common troubleshooting steps (checking specific logs etc)
2019-04-23 06:38:23 -04:00
- Propose updated, consolidated troubleshooting documentation, including its layout
**Knowledge prerequisite**:
- [Markdown](https://daringfireball.net/projects/markdown/)
2019-04-23 06:38:23 -04:00
**Mentor**: [Marek Marczykowski-Górecki](/team/)
2019-04-19 23:06:47 -04:00
### Improve Getting Started page
**Project**: Improve Getting Started page
**Brief explanation**: The [Getting Started page](https://www.qubes-os.org/doc/getting-started/) is the place a new user would go to understand better how to use Qubes. It is currently has old screenshots not using the default desktop environment and could have much better flow. In addition, this improved page content may end up being served more directly to the user via the [offline documentation](https://github.com/QubesOS/qubes-issues/issues/1019) or the firstboot guide.
**Expected results**:
- Review the existing page and website, similar pages for other OSes
- Provide visual mock-ups and proposed text
**Knowledge prerequisite**:
- basic Qubes OS knowledge
- [Markdown](https://daringfireball.net/projects/markdown/)
**Mentor**: [Michael Carbone](/team/)
### Rewrite qrexec documentation
**Project**: Rewrite qrexec documentation
**Brief explanation**: Current qrexec (qubes remote exec) documentation is hard to follow, important informations are hidden within a wall of text.
Some parts are split into multiple sections, for example version specific to avoid duplication, but it doesn't help reading it.
Additionally, protocol documentation describes only few specific use cases, instead of being clear and precise protocol specification.
Fixing this last point may require very close cooperation with developers, as the current documentation doesn't multiple corner cases (that's one of the issue with its current shape).
**Expected results**:
- Review existing [qrexec documentation](https://www.qubes-os.org/doc/qrexec3/) and an [issue about it](https://github.com/QubesOS/qubes-issues/issues/1392)
- Propose updated, consolidated admin documentation (policy writing, adding services)
- Propose consolidated protocol specification, based on the current documentation, and cooperation with developers
**Knowledge prerequisite**:
- [Markdown](https://daringfireball.net/projects/markdown/)
**Mentor**: [Marek Marczykowski-Górecki](/team/)