Skip to main content

Manage mail from your server.

Project description

Mail Muxer

cover

Are you tired of managing IMAP filters through cumbersome, slow and unintuive web interfaces ? Then Mail Muxer is here to save you from this pain !

Mail Muxer is a Python tool that will monitor your Inbox, and filter incomming emails according to the given configuration. It was designed to be intuitive and easy to use, by using compact configuration and sensible defaults: a rule can be as simple as

- condition:
    FROM: example@email.org
  move_to: some/folder

Basic Usage

  1. Install:

     pip install mmuxer
    
  2. Create configuration file:

    rules:
      - move_to: receipts
        condition:
          ANY:
            - FROM: some_store@ok.ok
            - FROM: some_other_store@store.net
      - move_to: important
        condition:
          SUBJECT: important
      - condition:
          FROM: spammer@example.com
        actions:
          - delete
    
    settings:
      server: imap.email.net
      username: me@email.net
      password: secret
    
  3. Check your configuration:

    mmuxer check --config-file config.yaml
    
  4. Check your folders:

    mmuxer folder --config-file config.yaml compare-destinations
    
  5. Monitor your inbox:

    mmuxer monitor --config-file config.yaml
    
  6. Or apply on all messages of a given IMAP folder:

    mmuxer tidy --config-file config.yaml --folder FOLDER
    
  7. Finally, to get help on a given command, add a --help to it, e.g.

    mmuxer monitor --help
    

Sieve interraction

MMuxer allows you to interract with sieves with the mmuxer sieve commands:

  • list: List sieve scripts on the server.
  • put: Upload a sieve script generated from rules to the server.
  • export: Convert the rules of the give config file to sieve format.

Note that server support of managesieve commands is necessary for list and put commands to work.

Settings

Using env variables for settings

Settings values (username, password, etc.) can be configured by providing environment variables of the same name (case insensitive).

Exporting configuration to sieve format

mmuxer can also export the rules of a configuration file to the sieve format, so that the rules will be handled server side.

mmuxer sieve-export --config-file config.yaml --dest-file rules.sieve

Note on SSL

If you get SSL errors while connecting to your server, see the SSL Configuration section.

All available settings

server: str
username: str
password: str
ssl_ciphers: Optional[str] = None
imap_wait_timeout: int = 60

sieve:
  folder_prefix: str = ""  # folder prefix used when generating sieve rules
  folder_separator: str = "."  # folder separator used when generating sieve rules
  name: str | None = None  # name used when exporting with managesieve
  extensions: list[str] = ["fileinto"]

Going further on

What's next

The current implementation is mostly feature complete for me, but here are some features that could be implemented:

  • Improve tidy operation:
    • make tidy operation more performant by using IMAP search features
    • allow to run tidy on many / all folders
  • Better conditions:
    • add a REGEX operator (although not compatible with IMAP search)
    • support more fields
  • Add more actions:
    • tag emails
    • forward emails
    • move destination based on regex match group
    • automatic folder creation
    • anything else ?
  • Hot-reload config file
  • Re-configure (or execute actions) by sending emails
  • Support OAuth / Gmail (I'm not sure how feasible that would be).

Don't hesitate to ask, or make a pull request !

Credit

This program relies on

  • the imap-tools library for everything involving IMAP
  • the mock IMAP server from aioimaplib for it's tests
  • the ever excellent Typer and Pydantic libs

Many thanks to them !

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mmuxer-0.7.0.tar.gz (41.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mmuxer-0.7.0-py3-none-any.whl (34.8 kB view details)

Uploaded Python 3

File details

Details for the file mmuxer-0.7.0.tar.gz.

File metadata

  • Download URL: mmuxer-0.7.0.tar.gz
  • Upload date:
  • Size: 41.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mmuxer-0.7.0.tar.gz
Algorithm Hash digest
SHA256 2c62878b55ab7db4c09d4e2c6e78523457d38496bebf4fd369a0f815ae61e1f3
MD5 bbc2c12b2a170cf92a0cc0ff7fc89abe
BLAKE2b-256 7ce588c5745a7718b798c4c0717572cd5a1ae00cbab926439b160ead5fce3975

See more details on using hashes here.

File details

Details for the file mmuxer-0.7.0-py3-none-any.whl.

File metadata

  • Download URL: mmuxer-0.7.0-py3-none-any.whl
  • Upload date:
  • Size: 34.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mmuxer-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f7c52afe4921de897d57d84b19ca5fb7e365c04653b31f317b8e50e91520dbe1
MD5 1009c5afe745315c7f1a9712b4cfe77e
BLAKE2b-256 310a2865758561b1795bb2e2b34822641d2643e8ebdef74d1bfe21ae455415ef

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page