Skip to content

Releases: pimalaya/himalaya

v1.1.0

11 Jan 14:50
v1.1.0
5632fda
Compare
Choose a tag to compare

Added

  • Added -y|--yes flag for folder purge and folder delete commands. [#469]

Changed

  • Put back warn the default log level. [#522]

    Since logs are sent to stderr, warnings can be easily discarded by prepending commands with RUST_LOG=off or by appending commands with 2>/dev/null.

  • Changed message.send.save-copy default to true. [#536]

  • Changed default downloads directory. [core#1]

Fixed

  • Fixed permissions issues when using install.sh. [#515]
  • Fixed de/serialization issues of backends' none variant. [#523]
  • Fixed list envelopes out of bound error when empty result. [#535]
  • Fixed macOS x86_64 builds. [#538]

v1.0.0

09 Dec 12:01
v1.0.0
ce0b2dd
Compare
Choose a tag to compare

The Himalaya CLI scope has changed. It does not include anymore the synchronization, nor the envelope watching. These scopes have moved to dedicated projects:

Due to the long time difference with the previous v1.0.0-beta.4 release, this changelog may be incomplete. The simplest way to upgrade is to reconfigure Himalaya CLI from scratch, using the wizard or the config.sample.toml.

Himalaya CLI will now try to adopt the conventional commits specification. Tools like git-cliff may help us generating more accurate changelogs in the future.

Added

  • Added message edit command to edit a message. To edit on place (replace a message), use --on-place.

  • Added account.list.table.preset global config option, accounts.<name>.folder.list.table.preset and accounts.<name>.envelope.list.table.preset account config options.

    These options customize the shape of tables, see examples at comfy_table::presets. Defaults to "|| |-||| ", which corresponds to comfy_table::presets::ASCII_MARKDOWN.

  • Added account.list.table.name-color config option to customize the color used for the accounts' NAME column (defaults to green).

  • Added account.list.table.backends-color config option to customize the color used for the folders' BACKENDS column (defaults to blue).

  • Added account.list.table.default-color config option to customize the color used for the folders' DEFAULT column (defaults to reset).

  • Added accounts.<name>.folder.list.table.name-color account config option to customize the color used for the folders' NAME column (defaults to blue).

  • Added accounts.<name>.folder.list.table.desc-color account config option to customize the color used for the folders' DESC column (defaults to green).

  • Added accounts.<name>.envelope.list.table.id-color account config option to customize the color used for the envelopes' ID column (defaults to red).

  • Added accounts.<name>.envelope.list.table.flags-color account config option to customize the color used for the envelopes' FLAGS column (defaults to reset).

  • Added accounts.<name>.envelope.list.table.subject-color account config option to customize the color used for the envelopes' SUBJECT column (defaults to green).

  • Added accounts.<name>.envelope.list.table.sender-color account config option to customize the color used for the envelopes' FROM column (defaults to blue).

  • Added accounts.<name>.envelope.list.table.date-color account config option to customize the color used for the envelopes' DATE column (defaults to dark_yellow).

  • Added accounts.<name>.envelope.list.table.unseen-char account config option to customize the char used for unseen envelopes (defaults to *).

  • Added accounts.<name>.envelope.list.table.replied-char account config option to customize the char used for replied envelopes (defaults to R).

  • Added accounts.<name>.envelope.list.table.flagged-char account config option to customize the char used for flagged envelopes (defaults to !).

  • Added accounts.<name>.envelope.list.table.attachment-char account config option to customize the char used for envelopes with at least one attachment (defaults to @).

Changed

  • Refactored the account configure command: this command stands now for creating or editing account configurations from the wizard. The command requires the wizard cargo feature.

  • Improved the account doctor command: it now checks the state of the config, and the new --fix argument allows you to configure keyring, OAuth 2.0 etc.

  • Improved long version --version. [#496]

  • Improved error messages when missing cargo features. For example, if a TOML configuration uses the IMAP backend without the imap cargo features, the error missing "imap" feature is displayed. #20

  • Normalized enum-based configurations, using the internally tagged representation type =. It should reduce issues due to misconfiguration, and improve othe error messages. Yet it is not perfect, see #802:

    • imap.*, maildir.* and notmuch.* moved to backend.*:

      # before
      imap.host = "localhost"
      imap.port = 143
      
      # after
      backend.type = "imap"
      backend.host = "localhost"
      backend.port = 143
    • smtp.* and sendmail.* moved to message.send.backend.*:

      # before
      smtp.host = "localhost"
      smtp.port = 25
      
      # after
      message.send.backend.type = "smtp"
      message.send.backend.host = "localhost"
      message.send.backend.port = 25
    • pgp.backend renamed pgp.type:

      # before
      pgp.backend = "commands"
      pgp.encrypt-cmd = "gpg --encrypt --quiet --armor <recipients>"
      
      # after
      pgp.type = "commands"
      pgp.encrypt-cmd = "gpg --encrypt --quiet --armor <recipients>"
    • {imap,smtp}.auth moved as well:

      # before
      imap.password.cmd = "pass show example"
      smtp.oauth2.method = "xoauth2"
      
      # after
      backend.auth.type = "password"
      backend.auth.cmd = "pass show example"
      message.send.backend.auth.type = "oauth2"
      message.send.backend.auth.method = "xoauth2"
  • Moved IMAP and SMTP encryption to encryption.type.

    This change prepares the config to accept different TLS providers with their options. The true and false variant have been removed as well:

     # before
     backend.encryption = "none" # or false
     backend.encryption = "start-tls"
     message.send.backend.encryption = "tls" # or true
    
     # after
     backend.encryption.type = "none"
     backend.encryption.type = "start-tls"
     message.send.backend.encryption.type = "tls"

Fixed

  • Fixed pre-release archives issue. [#492]
  • Fixed mailto parsing issue. [core#10]
  • Fixed Answered flag not set when replying to a message. [#508]

Removed

  • Removed systemd service from assets/ folder, as Himalaya CLI scope does not include synchronization nor watching anymore.

v1.0.0-beta.4

16 Apr 20:37
v1.0.0-beta.4
10de8e9
Compare
Choose a tag to compare

Added

  • Added systemd service in assets/ folder.
  • Added configuration option message.delete.style that can be either folder (deleted messages are moved to the Trash folder, default style) or flag (deleted messages receive the Deleted flag).
  • Added --debug as an alias for RUST_LOG=debug.
  • Added --trace as an alias for RUST_LOG=trace and RUST_BACKTRACE=1.
  • Added notes about --debug and --trace when error occurs.

Changed

  • Added back the search feature: you can now give an optional filter and sort query at the end of the envelope list command. See envelope list --help or pimalaya.org for more detail on the search API.
  • Changed the envelope list folder argument due to the search query: it became a flag --folder|-f.
  • Made the global --config|-c option repeatable: the first option is considered the path to the main config, and successive options are considered partial overrides #184.
  • Refactored error management: error should be more clear, colored and can now contain spantrace and backtrace.
  • Made --help content wrapping properly thanks to the clap cargo feature wrap_help.
  • Improved template {new,reply,forward} command JSON output: they return now a JSON object with 3 properties:
    • content: the content of the template
    • cursor.row: the row at which the cursor should be placed by the interface using the template
    • cursor.col: the column at which the cursor should be placed by the interface using the template

Fixed

  • Fixed watch IMAP envelopes when folder was empty #179.
  • Prevented parsing of undefined config options #188.
  • Fixed In-Reply-To header being skipped from mailto URLs #194.
  • Fixed error page out of bounds when filtering envelopes returned an empty result #195.

v1.0.0-beta.3

25 Feb 10:01
v1.0.0-beta.3
8e8040e
Compare
Choose a tag to compare

Added

  • Added account check-up command.
  • Added wizard warning about google passwords [#41].

Changed

  • Removed account configurations flatten level in order to improve diagnostic errors, due to a bug in clap. This means that accounts need to be prefixed by accounts: [my-account] becomes [accounts.my-account]. It also opens doors for interface-specific configurations.

  • Rolled back cargo feature additions from the previous release. It was a mistake: the amount of features was too big, the code (both CLI and lib) was too hard to maintain. Cargo features kept: imap, maildir, notmuch, smtp, sendmail, account-sync, account-discovery, pgp-gpg, pgp-commands and pgp-native.

  • Moved sync.strategy to folder.sync.filter.

  • Changed location of the synchronization data from $XDG_DATA_HOME/himalaya/<account-name> to $XDG_DATA_HOME/pimalaya/email/sync/<account-name>-cache.

  • Changed location of the synchronization cache from sync.dir to $XDG_CACHE_HOME/pimalaya/email/sync/<hash>/.

  • Replaced id mapping database SQLite by sled, a pure key-val store written in Rust to improve portability of the tool. Therefore, id aliases are reset.

  • Improved pre and post edit choices interaction [#58].

  • Improved account synchronization performances, making it 50% faster than mbsync and 370% faster than OfflineIMAP.

  • Changed envelope.watch.{event}.{hook}: hooks can now be cumulated. For example it is possible to send a system notification and execute a shell command when receiving a new envelope:

    envelope.watch.received.notify.summary = "New message from {sender}"
    envelope.watch.received.notify.body = "{subject}"
    envelope.watch.received.cmd = "echo {id} >> /tmp/new-email-counter"

Fixed

  • Fixed bug that was preventing watch placeholders to be replaced when using shell command hook.
  • Fixed watch IMAP envelopes issue preventing events to be triggered.
  • Fixed DNS account discovery priority issues.
  • Fixed SMTP messages not properly sent to all recipients [#172].
  • Fixed backend feature badly linked, leading to reply and forward message errors [#173].

v1.0.0-beta.2

27 Jan 21:54
v1.0.0-beta.2
e5cf39b
Compare
Choose a tag to compare

Added

  • Added cargo feature wizard, enabled by default.
  • Added one cargo feature per backend feature:
    • account including account-configure, account-list, account-sync and the account-subcmd
    • folder including folder-add, folder-list, folder-expunge, folder-purge, folder-delete and the folder-subcmd
    • envelope including envelope-list, envelope-watch, envelope-get and the envelope-subcmd
    • flag including flag-add, flag-set, flag-remove and the flag-subcmd
    • message including message-read, message-write, message-mailto, message-reply, message-forward, message-copy, message-move, message-delete, message-save, message-send and the message-subcmd
    • attachment including attachment-download and the attachment-subcmd
    • template including template-write, template-reply, template-forward, template-save, template-send and the template-subcmd
  • Added wizard capability to autodetect IMAP and SMTP configurations, based on the Thunderbird Autoconfiguration standard.
  • Added back Notmuch backend features.

Changed

  • Renamed folder create to folder add in order to better match types. An alias has been set up, so both create and add still work.

Fixed

  • Fixed default command: running himalaya without argument lists envelopes, as it used to be in previous versions.
  • Fixed bug when listing envelopes with backend = "imap", sync.enable = true and envelope.watch.backend = "imap" led to unwanted IMAP connection creation (which slowed down the listing).
  • Fixed builds related to enabled cargo features.

v1.0.0-beta

01 Jan 15:31
v1.0.0-beta
12e71a5
Compare
Choose a tag to compare

The new API of the configuration file contains breaking changes, see config.sample.toml for a documented example of this new API.

You can even test it:

# save the sample config locally
curl https://raw.githubusercontent.com/soywod/himalaya/master/config.sample.toml > config.sample.toml

# spawn a testing IMAP/SMTP server using docker
docker run -it --rm -p 3025:3025 -p 3110:3110 -p 3143:3143 -p 3465:3465 -p 3993:3993 -p 3995:3995 -e GREENMAIL_OPTS='-Dgreenmail.setup.test.all -Dgreenmail.hostname=0.0.0.0 -Dgreenmail.auth.disabled -Dgreenmail.verbose' greenmail/standalone:latest

# test the CLI using the sample config
himalaya -c ./config.sample.toml envelope list

Few major concepts changed:

  • The concept of Backend and Sender changed. The Sender does not exist anymore (it is now a backend feature). A Backend is now a set of features like add folders, list envelopes or send raw message. The backend of every single feature can be customized in the configuration file, which gives users more flexibility. Here the list of backend features that can be customized:
    • backend (required): the backend used by default by all backend features (maildir, imap or notmuch)
    • folder.add.backend: override the backend used for creating folders (maildir, imap or notmuch)
    • folder.list.backend: override the backend used for listing folders (maildir, imap or notmuch)
    • folder.expunge.backend: override the backend used for expunging folders (maildir, imap or notmuch)
    • folder.purge.backend: override the backend used for purging folders (maildir, imap or notmuch)
    • folder.delete.backend: override the backend used for deleting folders (maildir, imap or notmuch)
    • envelope.list.backend: override the backend used for listing envelopes (maildir, imap or notmuch)
    • envelope.get.backend: override the backend used for getting envelopes (maildir, imap or notmuch)
    • envelope.watch.backend: override the backend used for watching envelopes (maildir, imap or notmuch)
    • flag.add.backend: override the backend used for adding flags (maildir, imap or notmuch)
    • flag.set.backend: override the backend used for setting flags (maildir, imap or notmuch)
    • flag.remove.backend: override the backend used for removing flags (maildir, imap or notmuch)
    • message.send.backend (required): override the backend used for sending messages (sendmail or smtp)
    • message.read.backend: override the backend used for reading messages (maildir, imap or notmuch)
    • message.write.backend: override the backend used for adding flags (maildir, imap or notmuch)
    • message.copy.backend: override the backend used for copying messages (maildir, imap or notmuch)
    • message.move.backend: override the backend used for moving messages (maildir, imap or notmuch)
  • The CLI API changed: every command is now prefixed by its domain following the format himalaya <domain> <action>. List of domain available by running himalaya -h and list of actions for a domain by running himalaya <domain> -h.
  • TOML configuration file options use now the dot notation rather than the dash notation. For example, folder-listing-page-size became folder.list.page-size. See the changed section below for more details.

Added

  • Added cargo feature maildir (not plugged yet).
  • Added cargo feature sendmail (not plugged yet).
  • Added watch hooks envelope.watch.received (when a new envelope is received) and envelope.watch.any (for any other event related to envelopes). A watch hook can be:
    • A shell command: envelope.watch.any.cmd = "mbsync -a"

    • A system notification:

      • envelope.watch.received.notify.summary = "📬 New message from {sender}": customize the notification summary (title)
      • envelope.watch.received.notify.body = "{subject}": customize the notification body (content)

      Available placeholders: id, subject, sender, sender.name, sender.address, recipient, recipient.name, recipient.address.

  • Added watch support for Maildir backend features.

Changed

  • Renamed cargo feature imap-backendimap.
  • Renamed cargo feature notmuch-backendnotmuch.
  • Renamed cargo feature smtp-sendersmtp.
  • Changed the goal of the config option backend: it is now the default backend used for all backend features. Valid backends: imap, maildir, notmuch.
  • Moved folder-aliases config option to folder.alias(es).
  • Moved folder-listing-page-size config option to folder.list.page-size.
  • Moved email-listing-page-size config option to envelope.list.page-size.
  • Moved email-listing-datetime-fmt config option to envelope.list.datetime-fmt.
  • Moved email-listing-datetime-local-tz config option to envelope.list.datetime-local-tz.
  • Moved email-reading-headers config option to message.read.headers.
  • Moved email-reading-format config option to message.read.format.
  • Moved email-writing-headers config option to message.write.headers.
  • Move email-sending-save-copy config option to message.send.save-copy.
  • Move email-hooks.pre-send config option to message.send.pre-hook.
  • Moved sync config option to sync.enable.
  • Moved sync-dir config option to sync.dir.
  • Moved sync-folders-strategy config option to sync.strategy.
  • Moved maildir-* config options to maildir.*.
  • Moved imap-* config options to imap.*.
  • Moved notmuch-* config options to notmuch.*.
  • Moved sendmail-* config options to sendmail.*.
  • Moved smtp-* config options to smtp.*.
  • Replaced options imap-ssl, imap-starttls and imap-insecure by imap.encryption:
    • imap.encryption = "tls" | true: use required encryption (SSL/TLS)
    • imap.encryption = "start-tls": use opportunistic encryption (StartTLS)
    • imap.encryption = "none" | false: do not use any encryption
  • Replaced options smtp-ssl, smtp-starttls and smtp-insecure by smtp.encryption:
    • smtp.encryption = "tls" | true: use required encryption (SSL/TLS)
    • smtp.encryption = "start-tls": use opportunistic encryption (StartTLS)
    • smtp.encryption = "none" | false: do not use any encryption

Removed

  • Disabled temporarily the notmuch backend because it needs to be refactored using the backend features system (it should be reimplemented soon).
  • Disabled temporarily the search and sort command because they need to be refactored, see #39.
  • Removed the notify command (replaced by the new watch command).
  • Removed all global options except for display-name, signature, signature-delim and downloads-dir.

See config.sample.toml for a documented configuration example with the new API.

v0.9.0

28 Aug 07:06
v0.9.0
7ad1772
Compare
Choose a tag to compare

This version should be the last before the v1.0.0-beta!

Added

  • Added 3 new cargo features:
    • pgp-commands: enables the commands PGP backend (enabled by default, same behaviour as before)
    • pgp-gpg: enables the GPG backend (requires the gpgme lib on the system)
    • pgp-native: enables the native PGP backend
  • Added account configuration pgp to configure the way PGP operations are performed.

Changed

  • Moved email-writing-encrypt-cmdto pgp.encrypt-cmd.
  • Moved email-reading-decrypt-cmd to pgp-decrypt-cmd.
  • Moved email-writing-sign-cmd to pgp.sign-cmd.
  • Moved email-reading-verify-cmd to pgp.verify-cmd.

v0.8.4

18 Jul 15:49
v0.8.4
fff8249
Compare
Choose a tag to compare

Fixed

  • Fixed windows releases due to cargo deps typo.

v0.8.3

18 Jul 15:26
v0.8.3
5c360da
Compare
Choose a tag to compare

Fixed

  • Fixed windows releases due to coredump crate compilation error.
  • Fixed macos releases due to macos 12 System Integrity Protection.

v0.8.2

18 Jul 14:42
v0.8.2
cb1178e
Compare
Choose a tag to compare

Changed

  • Made the code async using the tokio async runtime.
  • On Linux, made the kernel keyring the default one (the one based on keyutils).

Fixed

  • Fixed the way folder aliases are resolved. In some case, aliases were resolved CLI side and lib side, which led to alias errors [sourcehut#95].

pimalaya-email-tpl

Fixed

  • Fixed default PGP verify command that was using invalid option --recipient.

pimalaya-email

Changed

  • Changed the way folder aliases are resolved. They are now resolved directly from backend implementations, which frees interfaces from this responsibility [#95].
  • Bumped [email protected].

Fixed

  • Fixed absolute folder aliases for the maildir backend [#94].
  • Fixed notmuch virtual folder [#92].