Skip to content

SecureDrop Research Project Ideas

Kevin O'Gorman edited this page Nov 4, 2021 · 15 revisions

Riseup pad is here: https://pad.riseup.net/p/fpf-epic-brainstorm-1y-keep/timeslider#3550

Context and strategy

Securedrop-related project ideas suitable for short-term engagements are useful to have for programs like Google Summer of Code, as well as for students and researchers looking to engage with the project in an academic contest. FPF participated in GSoC in 2018, offering the following suggested areas of focus: https://github.com/freedomofpress/securedrop/wiki/Google-Summer-of-Code-2018-Ideas

Some of the GSoC ideas have already seen some action, some may no longer be valid, and new ideas may have come up since. The purpose of this async meeting was to brainstorm on updated project ideas, with the assumption that said ideas should be achievable by an individual - with some level of mentoring support - within a time frame of about 3 months.

Logistics:

Sync meeting took place on 20 Oct 2021 1330 Eastern. The meeting was Asynchronously open for participation until 28 Oct 2021. Google Meet was used for the sync meeting. A Riseup pad was used for both: https://pad.riseup.net/p/fpf-epic-brainstorm-1y-keep/timeslider#3550

pad snapshot for posterity: fpf-epic-brainstorm.txt
GSoC-alike/Thesis/Internship Project Ideas - Brainstorming

Logistics
Asynchronously open for participation until 28 Oct 2021
Sync meeting time: 20 Oct 2021  1330 Eastern
Sync meeting: meet.google.com/ekb-kkhf-mrk

Intro
We started work on this during the synch meeting on Oct 21 - it's now available as a worksheet for folks working through it asynchronously. Instructions are italicized below.

Who's Here and how are you feeling??? 
Write your name and a word/phrase describing how you're feeling right now as you fill this out 
	* [ example of something a participant might write: Sisi Wei, excited ]
	* 
	* 
	* 
	* 
	* Abigail, just observing :)
	* Gonzalo, curious. I'll probably be mostly observing :)
	* Conor, stoked to try a new meeting regimen. Really liking the inclusive nature of the explicit pro-async framing.
	* Erik, beep boop! I am asynchronous participant (may join later)
	* Kev, feeling a tad apprehensive
	* Cory, appreciative of the opportunity to follow and contribute async beforehand and/or (in this case) afterwards!
	* Allie, contemplative about how i am feeling introspective


Context and strategy
A potential contributor recently reached out via https://forum.securedrop.org/t/project-ideas/1431 looking for help  picking something SecureDrop-related to work on for a thesis project. They'd independently found https://github.com/freedomofpress/securedrop/wiki/Google-Summer-of-Code-2018-Ideas and expressed an interest in the first idea (better monitoring) but didn't know if it was still a priority and wanted some advice.

Some of the GSoC ideas have already seen some action, some may no longer be valid, and new ideas may have come up since. To help this person and others looking for larger projects than a single issue, we could put together a list of ideas along with related metadata as per the GSoC list, and make that available publicly.
The purpose of this session is to brainstorm on ideas, with the assumption that said ideas should be achievable by an individual with some level of mentoring within a timeframe of about 3 months. It's also assumed that we'll follow the same format as the existing GSoC ideas. (Please feel free to challenge said assumptions)

	* [Collective notes welcome here!]
	* 
	* 
	* 
	* Should we remove/archive the GSOC 2018 wiki page?
	* https://securedrop.org/research/ <-- Published research, should we post CFPs there too?
	* https://github.com/freedomofpress/securedrop-workstation/issues/602 <-- SecureBoot research ask, for Workstation
	* Likely we should capture any and all of those ideas in the GH wiki (seems like an accessible, visible, easy to edit)


Check-in Moment: After hearing (learning about? hearing/reading) the context and strategy, how clearly do you understand the context and reasoning behind what we’re doing? (1 being "I'm really confused", 3 being "I think I get it", 5 being "It's crystal clear I could explain it to someone else")
	* 
	* 
	* 
	* 
	* 
	* Gonzalo 5
	* Conor 5
	* Erik 13/10 would async again
	* Kev sez 5
	* Cory: 5.  This is like giving context for a pull request, but in the case of a meeting what you're pulling/requesting is folks' time and attention!  :-)
	* Allie, 3 (when is the sync meeting mentioned above?)


Reflecting back on past experiences
Pick one of the following prompts and share your response below:
1. How have similarly-scoped projects like this worked out before for participants?
2. Based on prior experience,what could we do to optimise both for good participant outcomes and for useful project outcomes?

Responses/thoughts/reactions:
	* 
	* 
	* 
	* 
	* 
	* I'd make sure we allocate a resonable amount of time for someone* to dedicate to supporting/collaborating/stakeholding with the participant, as they will likely not have most of the context that day-to-day experience provides us all. *I believe it's important for that person to be familiar with the project goals, and with how the project outcome would fit within FPF's larger goals.
	* +1, that's certainly key for programs like Outreachy & GSoC. For a thesis the person will want to operate with a fair degree of autonomy so we'll want to find the right balance.
	* In the past, such as with osresearch's suggestion about SecureBoot in the Workstation, we tend to refer the interested party upstream, so that we can minimize our maintenance obligations while maximizing impact of the work if it's accepted.
	* SD/W can be extremely challenging to get started with: containers exist for server code dev, but installing Qubes for Workstation dev is a big ask.
	* Having time/resources available for mentoring is important - expectations need to be set and it needs to be included in planning
	* Agree with the above. Also in-house mentorship is a useful way to build our mentorship muscles.


What stuck with you from the responses above?: 
If others have shared already, read through their responses above, and if something really strikes you, jot it down below. If you're the first person to do this, come back later in the week and see if there's anything you want to react to!
	* 
	* 
	* 
	* 
	* 
	* We seem to assume that most SD development will be performed by FPF staff, or at least an SD expert.
	* We aren't explicitly allotting time for external mentorship (well, recently we've started with Outreachy!)
	* We tend to assum a uniform and pretty beefy development setup (possibly even a dedicated Qubes machine) - this may not work for non-staff
	* For the client, we have ways to do most development without Qubes. Since Debian is free and easy to run in a VM, it's a good option for newcomers. I think clear system requirements is extremely helpful rather than poorly maintaining too much hardware
Brainstorm time!!! 
Before reading any ideas below, do a free form brainstorm and jot down your ideas below. Once you're done, read through what others have written below and add reactions (such as +1) or comments if you want to share more or iterate on an idea, or just give it more love. Finally, when you're ready to move to the next section, add some blank lines right below these instructions, like you see now, so the next person can have some blank space to work!
Prompt: Here's a cool SD-related project for someone to work on...
	* 
	* 
	* 
	* 
	* focus on e2ee
	* support encrypted conversations between journalists
	* signal vm integration with the client
	* sanitization workflow
	* create a *-security private repo for the rest of our repos (also convert securedrop-security to a private clone) and start tracking more of our security conversations there when there is a vulnerability or audit that involves bugs
	* add a more user-friendly api for building reproducible wheels: https://github.com/freedomofpress/securedrop-security/issues/64
	* support veracrypt
	* Get high severity OSSEC alerts via Signal: https://github.com/freedomofpress/securedrop/issues/3182
	* Replace OSSEC with a more tailor-made notification system that lives on the app server and treat OSSEC as an optional part of a SecureDrop setup or deprecate it entirely
	* Explore ways to fully support full-disk encryption on the server
	* SecureBoot support! https://github.com/freedomofpress/securedrop/issues/5867
	* grsec alternatives?
	* End-to-end testing strategies for Qubes
	* Per-source DispVMs: https://github.com/freedomofpress/securedrop-workstation/issues/333
	* What if SecureDrop but not GPG (swapping in e.g. age strikes me as a passable improvement, just without the complexity of a migration)
	* What if SecureDrop but i2p or nym instead of Tor? (comparative properties of anonmyzation networks in the context of a whistleblowing app?)
		* +1 given past comments from Kev, Ro, &a. re: countries where a Tor dependency is a nonstarter.
	* Is the 500MB upload limit reasonable? A lot has changed in the past years. Is there a meaningful impact on network observability/deanonymization for very large (e.g. >1GB) uploads?
	* Does using HTTPS over Onions increase circuit fingerprintability? (This is more a Tor concern than a strictly SD concern, but still interested to know).
		* ^ These last two suggest a distinction between "ecosystem research" projects and "SecureDrop R&D/prototyping" projects.
	* Adding DDOS protection to SecureDrop (eg. Endgame threat modeling/integration, adding an optional captcha, Onionbalance support)
	* Custom file-handling RPC service for Qubes


Next steps
#1: Who's willing to provide low-effort advice/mentorshop to external contributors, and for what ideas?
	* 
	* 
	* 
	* Allie: I will commit to team, project-based, and outreachy (or a similar org) mentorship
	* Happy to provide some product-y guidance on notification systems for admins
	* Conor is interested in network/onion/ddos research
	* Cory is interested in "shadowing" mentorship (if/as appropriate), (a) to connect past (e.g.) network-stack interests to the SecureDrop project and (b) to learn from this kind of relationship- and capacity-building in an open-source project.
	* 

#2: Can you commit to writing a short blurb about a idea, including skill prerequisites, relative difficulty, links to docs? (if yes, which do you want?)
	* 
	* 
	* 
	* See https://www.outreachy.org/outreachy-december-2021-internship-round/communities/securedrop/
	* Could expand on alerting/OSSEC issues above; end-to-end testing for SecureDrop Workstation
	* Sure, Conor would be happy to provide a blurb on forum thread, provided folks agree that the network/onion/ddos ideas are worth sharing
	* Kev also into writing up the DDOS one and the ones about swapping out different parts of the tech stack.
	* 

This meeting template is licensed by Creative Commons (CC BY 3.0) by OpenNews, and was created by Sisi Wei during her RJI Fellowship in support of the DEI Coalition.
Clone this wiki locally