-
Notifications
You must be signed in to change notification settings - Fork 1k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Updates to the dev faq and contributor guidelines
- Loading branch information
1 parent
67efcdc
commit a539f45
Showing
2 changed files
with
184 additions
and
66 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,38 +2,41 @@ | |
|
||
This document contain a collection of frequently asked questions (with | ||
answers) about Mailpile development. Please familiarize yourself with | ||
the contents before attempting to hack on Mailpile. | ||
the contents before attempting any deep hacking on Mailpile. | ||
|
||
You don't have to agree with all of our priorities to take part or make | ||
use of Mailpile, but we do feel it helps if most of the community is | ||
rowing in roughly the same general direction! | ||
|
||
Note: If you are just looking for debugging tips and tricks, you can skip | ||
to the end. | ||
|
||
#### Why Mailpile? | ||
|
||
### Why Mailpile? | ||
|
||
The long-term goal of Mailpile is to help *non-technical people* become | ||
**more independent** and **more private** online, online, in particular | ||
when it comes to e-mail. | ||
*more independent* and *more private* online, in particular when it | ||
comes to e-mail. | ||
|
||
By **more independent**, we mean users should be in control of their | ||
By **more independent**, we mean people should be in control of their | ||
e-mail and the software used to manage it. This is why Mailpile is Free | ||
Software, and this is why we *don't* promote Mailpile as a tool for | ||
building "cloud services". | ||
|
||
By **more private**, we mean users should have more control over who has | ||
By **more private**, we mean people should have more control over who has | ||
access to their e-mail, when and how. This is why Mailpile tries to make | ||
e-mail encryption more accessible, and this is why Mailpile tries to | ||
make it convenient *and secure* for users to store their e-mail on their | ||
make it convenient *and secure* for people to store their e-mail on their | ||
own devices. | ||
|
||
Our focus on *non-technical users* implies, amongst other things, that | ||
Our focus on **non-technical people** implies, amongst other things, that | ||
we cannot exclude people who are using non-free platforms such as | ||
Microsoft Windows or Mac OS X, and we cannot require our users learn a | ||
radically new, unfamiliar user interface or understand highly technical | ||
concepts such as public key cryptography. | ||
|
||
|
||
#### Are All of These Decisions Awesome? | ||
### Are All of These Decisions Awesome? | ||
|
||
No. Some of these decisions were almost certainly mistakes. But that's | ||
part of innovating, you try new things and see how they go! | ||
|
@@ -43,7 +46,7 @@ from picking arguments with us over these decisions. Making forward | |
progress is much more fun than rehashing the past over and over again. | ||
|
||
|
||
#### Why Do You Reinvent So Many Wheels? | ||
### Why Do You Reinvent So Many Wheels? | ||
|
||
Usually, the answer is one or more of the following: | ||
|
||
|
@@ -61,15 +64,15 @@ cross-platform packaging efforts. | |
|
||
For this reason we also tend to prefer pure-Python (or Javascript, for | ||
the UI) libraries over native code, which also avoids certain classes of | ||
security holes which are simply not present in a memory-safe, managed | ||
language. | ||
bugs and security vulnerabilities which are simply not present in a | ||
memory-safe, managed language. | ||
|
||
We have broken this rule more often than we'd like in our user-interface | ||
code, due to cultural differences between web developers and Python | ||
folks. *We would like to gradually reduce our front-end dependencies.* | ||
|
||
|
||
#### Why a Search Engine? | ||
### Why a Search Engine? | ||
|
||
Mailpile started as an experimental search engine, a hobby project. | ||
Everything else came later. | ||
|
@@ -89,34 +92,34 @@ The entire app is built around the search metaphor, much like Google's | |
GMail. This is a fundamentally different way to build an e-mail client, | ||
from the traditional "messages and mailboxes" model. | ||
|
||
The search engine also makes it easy for Mailpile to do some very | ||
interesting things internally; some examples: | ||
The search engine also makes it easy for Mailpile to do some pretty cool | ||
things. For example: | ||
|
||
* we can evaluate the trustworthiness of a message by asking the | ||
* Mailpile can evaluate the trustworthiness of a message by asking the | ||
search engine about the past behaviour of the sender | ||
* we can postpone processing of things like attached PGP keys until | ||
we actually intend to use the key: the search engine makes the keys | ||
easy to find later on | ||
* Mailpile can postpone processing of things like attached PGP keys | ||
until it actually intends to use the key: the search engine makes the | ||
keys easy to find later on | ||
|
||
|
||
#### Why doesn't Mailpile have a Native User Interface? | ||
### Why doesn't Mailpile have a Native User Interface? | ||
|
||
For now, because the team is very small and we would like to reach users | ||
on many different platforms, we have bet entirely on the web as our | ||
primary user interface. | ||
primary user interface: | ||
|
||
This decision allows us to target any operating system for which Python | ||
2.7 has been made available. | ||
* This decision allows us to target any operating system for which | ||
Python 2.7 has been made available. | ||
|
||
It also allows us to get help from the enormous community of web | ||
developers; this is a much larger talent pool than the pool of | ||
developers that know how to write native apps. | ||
* It also allows us to get help from the enormous community of web | ||
developers; this is a much larger talent pool than the pool of | ||
developers that know how to write native apps. | ||
|
||
Last but not least, the web interface is key to our plan to allow users | ||
to access their Mailpile remotely over the network. Remote access is | ||
critical if we want to get people to store their e-mail on their own | ||
devices, since most people read their mail on multiple devices (laptop, | ||
tablet, mobile, work computer, etc). | ||
* Last but not least, the web interface is key to our plan to allow | ||
users to access their Mailpile remotely over the network. Remote | ||
access is critical if we want to get people to store their e-mail | ||
on their own devices, because most people read their mail on | ||
multiple devices (laptop, tablet, mobile, work computer, etc). | ||
|
||
That said: we do want to have a minimal native user interface, on all | ||
the major desktop operating systems. [That is what the gui-o-matic | ||
|
@@ -125,7 +128,7 @@ spin-off project is about](https://github.com/mailpile/gui-o-matic). | |
Native mobile apps on Android and/or iOS would also be nice to have! | ||
|
||
|
||
#### What is Mailpile's Approach to Security? | ||
### How Does Mailpile Handle Security? | ||
|
||
This is a huge topic! Please consult our [Security | ||
Roadmap](https://github.com/mailpile/Mailpile/wiki/Security-roadmap). | ||
|
@@ -142,14 +145,17 @@ Thwarting other adversaries (criminals, jealous partners, etc.) is also | |
very much something we care about, but is probably less divisive. | ||
|
||
|
||
#### Why GnuPG? Why not GPGME? Why not PGPy? | ||
### Why GnuPG? Why not GPGME? Why not PGPy? | ||
|
||
GnuPG is mature, stable and although the user interfaces may leave | ||
GnuPG is mature and stable. Although the user interfaces may leave | ||
something to be desired, it has a rich ecosystem of powerful tools built | ||
around it. If we didn't use GnuPG, we would have to reinvent a lot of | ||
wheels that aren't central to Mailpile's mission. Our issue tracker | ||
contains [further discussions on the topic of why GnuPG and not something | ||
else, such as PGPy](https://github.com/mailpile/Mailpile/issues/1743). | ||
around it and a wealth of documentation and support to be found online. | ||
If we didn't use GnuPG, we would have to reinvent a lot of wheels that | ||
aren't central to Mailpile's mission. | ||
|
||
Our issue tracker contains [further discussions on the topic of why | ||
GnuPG and not something else, such as | ||
PGPy](https://github.com/mailpile/Mailpile/issues/1743). | ||
|
||
[Use of GPGME is also being | ||
discussed](https://github.com/mailpile/Mailpile/issues/1742). Currently, | ||
|
@@ -160,10 +166,30 @@ opposed to Python, which is memory-safe and less likely to contain | |
certain classes of security vulnerabilities). | ||
|
||
|
||
#### Why Not Django? Or Flask? | ||
### Why not Python 3? | ||
|
||
We depend on some libraries - spambayes in particular - which were not | ||
available for Python 3 when we started this project. | ||
|
||
We don't think Python 2 is going away in the near future. | ||
|
||
[There is a Github issue discussing | ||
this.](https://github.com/mailpile/Mailpile/issues/160) | ||
|
||
|
||
### Why Not Django? Or Flask? | ||
|
||
Reasons! | ||
|
||
Our way may be unsual, but it's kinda awesome once you get used to it | ||
and it wasn't obvious to us how we could get this kind of behaviour from | ||
one of the standard frameworks. | ||
|
||
Please read the next section for details. | ||
|
||
|
||
### How Does Mailpile's Web UI Work? | ||
|
||
The text-based command-line interface is an important part of Mailpile's | ||
user interface. Our home-brewed framework allows us to generate web API | ||
end-points, text commands and command-line arguments *at the same time*. | ||
|
@@ -192,17 +218,111 @@ You can try this yourself, simply by editing the URL in your browser: | |
The filename part of the URL is used to select output formats. All | ||
endpoints support `as.json`, most support HTML and/or text. | ||
|
||
Our way may be unsual, but it's kinda awesome once you get used to it | ||
and it wasn't obvious to us how we could get this kind of behaviour from | ||
one of the standard frameworks. | ||
The HTML output of each command is generated using Jinja2 templates | ||
that are found in `shared-data/default-theme/html/...`. The directory | ||
structure generally matches the URL paths seen in the browser, with | ||
the main template for each command named `index.html`. | ||
|
||
Alternate templates for the same API endpoint can have other names, for | ||
example a template named `.../html/search/social.html` would be | ||
accessible using URLs like so: | ||
|
||
### Why not Python 3? | ||
http://localhost:33411/in/inbox/social.html | ||
http://localhost:33411/search/social.html?q=from:[email protected] | ||
|
||
We depend on some libraries - spambayes in particular - which were not | ||
available for Python 3 when we started this project. | ||
|
||
We don't think Python 2 is going away in the near future. | ||
### Can I Develop Plugins For Mailpile? | ||
|
||
[There is a Github issue discussing | ||
this.](https://github.com/mailpile/Mailpile/issues/160) | ||
Sort-of! | ||
|
||
Internally, the app is quite modular and there are methods which allow | ||
code to register classes or functions that perform various functions. | ||
|
||
However, the plugin API is not considered stable, it is incomplete and | ||
it is not very well documented. It may also not be a very nice API, and | ||
we rather expect it to develop and change rapidly post-1.0. | ||
|
||
If you are interested in Mailpile's plugin APIs, take a look in | ||
`shared-data/contrib/` for some examples of "external plugins" and | ||
`mailpile/plugins/` for "internal plugins". | ||
|
||
|
||
### How Do I Debug Mailpile? | ||
|
||
Developers should learn to use the Mailpile CLI. The `mailpile>` prompt is | ||
where all of the low-level magic happens. Future versions of Mailpile will | ||
expose this functionality to the web interface itself, but for now you will | ||
need to use your shell. | ||
|
||
Possibly the most important command for Mailpile hackers, is to know | ||
how to enable debugging. An example: | ||
|
||
# Enable verbose debugging of HTTP requests and GnuPG integration | ||
# Note: HTTP debugging disables all sorts of internal caches! | ||
mailpile> set sys.debug = log http gnupg | ||
... | ||
|
||
Many other subsystems can have debugging enabled. At the time of writing, | ||
the `sys.debug` can include the following terms to make various parts of | ||
the app more verbose: | ||
|
||
log http compose cryptostate autotag rescan keywords cache connbroker | ||
vcard pop3 gnupg imap sources jinja timing sendmail httpdata | ||
|
||
There are also a few other ways to examine the app state: | ||
|
||
# Watch logging and debug messages fly by | ||
mailpile> eventlog/watch | ||
... | ||
[CTRL+C] | ||
... | ||
|
||
# Examine event log (piped through less) | ||
mailpile> pipe less eventlog | ||
... | ||
mailpile> pipe less eventlog incomplete | ||
... | ||
|
||
# Get an overview of what threads are running and what they are doing | ||
mailpile> ps | ||
... | ||
|
||
Low-level changes and exploration of the configuration are also best done | ||
from the CLI: | ||
|
||
# Explore the configuration; see also mailpile/config/defaults.py | ||
mailpile> print -short sys | ||
... | ||
mailpile> print -flat sources | ||
... | ||
mailpile> print -secrets secrets | ||
... | ||
|
||
# Change things (dangerous) | ||
mailpile> set sys.gpg_binary = /bin/false | ||
... | ||
|
||
# Reset something to its default setting | ||
mailpile> unset sys.gpg_binary | ||
... | ||
|
||
There is also a help command, and you can use tab completion to try and | ||
"guess" what commands exist. | ||
|
||
mailpile> help | ||
... | ||
mailpile> help tags | ||
... | ||
|
||
Finally, the app ships with a `hacks` plugin which is disabled by default. | ||
If you load it, that will add a few more low-level commands, including an | ||
embedded Python interpretor: | ||
|
||
mailpile> plugins/load hacks | ||
... | ||
|
||
mailpile> hacks/pycli | ||
... | ||
|
||
There's sure to be more; please feel free to file a pull request against | ||
this document to add your favourite tricks or clarify these. |