POP3 stuff, particularly a streaming downloader and a simple command line which runs it.
Project description
POP3 stuff, particularly a streaming downloader and a simple command line which runs it.
Latest release 20240201: Test release with better DISTINFO.
I spend some time on a geostationary satellite connection, where round trip ping times are over 600ms when things are good.
My mail setup involves fetching messages from my inbox
for local storage in my laptop, usually using POP3.
The common standalone tools for this are fetchmail
and getmail
.
However, both are very subject to the link latency,
in that they request a message, collect it, issue a delete, then repeat.
On a satellite link that incurs a cost of over a second per message,
making catch up after a period offline a many minutes long exercise in tedium.
This module does something I've been meaning to do for literally years:
a bulk fetch. It issues RETR
ieves for every message up front as fast as possible.
A separate thread collects the messages as they are delivered
and issues DELE
tes for the saved messages as soon as each is saved.
This results in a fetch process which is orders of magnitude faster. Even on a low latency link the throughput is much faster; on the satellite it is gobsmackingly faster.
Class ConnectionSpec(ConnectionSpec, builtins.tuple)
A specification for a POP3 connection.
Function main(argv=None)
The pop3
command line mode.
Class NetrcEntry(NetrcEntry, builtins.tuple)
A namedtuple
representation of a netrc
entry.
Class POP3(cs.resources.MultiOpenMixin, cs.context.ContextManagerMixin)
Simple POP3 class with support for streaming use.
Class POP3Command(cs.cmdutils.BaseCommand)
Command line implementation for POP3 operations.
Credentials are obtained via the .netrc
file presently.
Connection specifications consist of an optional leading mode prefix followed by a netrc(5) account name or an explicit connection specification from which to derive:
user
: the user name to log in astcp_host
: the hostname to which to establish a TCP connectionport
: the TCP port to connect on, default 995 for TLS/SSL or 110 for cleartextsni_host
: the TLS/SSL SNI server name, which may be different from thetcp_host
The optional mode prefix is one of:
ssl:
: use TLS/SSL - this is the defaulttcp:
: use cleartext - this is useful for ssh port forwards to some not-publicly-exposed clear text POP service; in particular streaming performs better this way, I think because the Python SSL layer does not buffer writes
Example connection specifications:
username@mail.example.com
: use TLS/SSL to connect to the POP3S service atmail.example.com
, logging in asusername
mail.example.com
: use TLS/SSL to connect to the POP3S service atmail.example.com
, logging in with the same login as the local effective usertcp:username@localhost:1110
: use cleartext to connect tolocalhost:1110
, typically an ssh port forward to a remote private cleartext POP service, logging in asusername
username@localhost!mail.example.com:1995
: use TLS/SSL to connect tolocalhost:1995
, usually an ssh port forward to a remote private TLS/SSL POP service, logging in asusername
and passingmail.exampl.com
as the TLS/SSL server name indication (which allows certificate verification to proceed correctly)
Note that the specification may also be a netrc
account name.
If the specification matches such an account name
then values are derived from the netrc
entry.
The entry's machine
name becomes the TCP connection specification,
the entry's login
provides a default for the username,
the entry's account
host part provides the sni_host
.
Example netrc
entry:
machine username@localhost:1110
account username@mail.example.com
password ************
Such an entry allows you to use the specification tcp:username@mail.example.com
and obtain the remaining detail via the netrc
entry.
Command line usage:
Usage: pop3 subcommand [...]
Subcommands:
dl [-n] [{ssl,tcp}:]{netrc_account|[user@]host[!sni_name][:port]} maildir
help [-l] [subcommand-names...]
Print the full help for the named subcommands,
or for all subcommands if no names are specified.
-l Long help even if no subcommand-names provided.
shell
Run a command prompt via cmd.Cmd using this command's subcommands.
Release Log
Release 20240201: Test release with better DISTINFO.
Release 20221221: Fix stray %s in format string, modernise MultiOpenMixin startup/shutdown, catch ConnectionRefusedError and report succintly.
Release 20220918:
- Emit an error instead of stack trace for messages which cannot be saved (and do not delete).
- POP3Command.cmd_dl: new -n (no action) option.
Release 20220606: Minor updates.
Release 20220312: Make POP3Command.cmd_dl an instance method (static methods broke with the latest cs.cmdutils release).
Release 20211208:
- POP3.startup: do not start the worker queue until authenticated.
- POP3.get_response: return (None,None,None) at EOF.
- POP3.shutdown: catch exceptions from client QUIT.
Release 20210407.2: Provide "pop3" console_script.
Release 20210407.1: Bump for cs.cmdutils minor bugfix, also fix a few docstring typos.
Release 20210407: Initial PyPI release.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for cs.pop3-20240201-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | a6893ad9f16b08a167cbeb1ae26fb1f5f3483d3e7bbc751bdfb80b21a84f57ae |
|
MD5 | 28e6bf0e116f21efb7bcb34a75761e0e |
|
BLAKE2b-256 | 08a599076a9f9391982a2d0609d653d320b7632d1d20bc033899346406aa6809 |