Scroll to navigation

gromox(7) Gromox admin reference gromox(7)

Name

gromox — Overview of the Gromox groupware server

Description

Gromox is a groupware server capable of serving as a replacement for Microsoft Exchange. Connectivity options include RPC/HTTP (Outlook Anywhere), IMAP, POP3, an SMTP-speaking LDA, and a PHP module with a Z-MAPI function subset.

Gromox relies on other components to provide a sensibly complete mail system, such as Postfix as a mail transfer agent, and grommunio-admin for user management. A web interface is available with grommunio-web. The grommunio distribution ships these essentials and has a ready-to-run installation of Gromox. system.

Manual page listing

Gromox documentation consists of at least a dozen manual pages ("manpages") on its individual components. We have grouped these according to their principal function.

Overview and definitions

  • gromox(7) — This page, an overview of the Gromox groupware server.
  • mapi(7gx) — Definition for "Messaging Application Programming Interface"
  • gromox-selinux(5) — SELinux policy for Gromox

Exchange subsystem and its components

  • autodiscover(4gx) — Autodiscover HTTP Service Protocol handler (AutoDiscover responder).
  • exchange_emsmdb(4gx) — http(8gx) processing plugin for the Wire Format Protocol (Outlook/Exchange RPCs).
  • exchange_nsp(4gx) — http(8gx) processing plugin for the Exchange Server Name Service Provider Interface Protocol.
  • exchange_rfr(4gx) — http(8gx) processing plugin for the Address Book Name Service Provider Interface Referral Protocol.
  • exmdb_provider(4gx) — Gromox Information Store
  • ews(4gx) — http(8gx) processing plugin for EWS requests
  • http(8gx)
  • mod_cache(4gx) — http(8gx) processing plugin for serving objects from a local filesystem
  • mod_fastcgi(4gx) — http(8gx) processing plugin for proxying requests to FastCGI servers
  • mod_rewrite(4gx) — http(8gx) processing plugin for altering HTTP request URIs before processing
  • mh_emsmdb(4gx) — http(8gx) processing plugin for MAPIHTTP-wrapped EMSMDB requests
  • mh_nsp(4gx) — http(8gx) processing plugin for MAPIHTTP-wrapped NSPI requests
  • timer(8gx) — deferred command executor

PHP-MAPI subsystem

zcore(8gx) — Bridge for PHP-MAPI requests

Mail retrieval agent subsystem (MRA)

  • imap(8gx) — IMAP server
  • event_proxy(4gx) — Event sender service plugin
  • event_stub(4gx) — Event receiver service plugin
  • midb_agent(4gx) — Service plugin for conversing with midb(8gx)
  • pop3(8gx) — POP3 server

Local delivery agent (LDA)

  • alias_resolve(4gx) — Alias resolution for delivery(8gx) using MySQL
  • delivery(8gx) — Backend for local delivery
  • delivery-queue(8gx) — LMTP/SMTP frontend for local delivery
  • user_filter(4gx) — Service plugin for application of user login limits

Auxiliary services

  • pam_gromox(4gx) — a PAM plugin to authenticate with Gromox
  • event(8gx) — Folder change notification daemon
  • midb(8gx) — Message Index database daemon

System administration

Mail import, export and conversion

  • gromox-eml2mbox(8) — Utility for converting RFC5322 Internet Mail messages into a RFC4155 mbox-format mailbox
  • gromox-eml2mt(8) — Utility for analysis of/importing RFC5322 Internet Mail messages
  • gromox-exm2eml(8) — Utility for exporting messages as RFC5322 Internet Mail
  • gromox-exm2ical(8) — Utility for exporting messages as RFC5545 iCalendar objects
  • gromox-exm2mt(8) — Utility for exporting messages as a Gromox Mailbox Transfer stream
  • gromox-exm2vcf(8) — Utility for exporting messages as RFC6540 vCard objects
  • gromox-ical2mt(8) — Utility for analysis of/importing RFC5545 iCalendar objects
  • gromox-kdb2mt(8) — Utility for analysis of/importing Zarafa/Kopano SQL-stored mailboxes
  • gromox-mt2exm(8) — Utility for bulk-importing mail items into a Gromox store
  • gromox-oxm2mt(8) — Utility for analysis and import of Outlook .msg files
  • gromox-pff2mt(8) — Utility for analysis/import of PFF/PST/OST files
  • gromox-snapshot(8) — Helper to create btrfs snapshots of mailboxes
  • gromox-vcf2mt(8) — Utility for analysis/import of vCard objects
  • kdb-uidextract(8) — Helper for creating a gromox-kdb2mt ACL map
  • kdb-uidextract-limited(8) — Helper for creating a gromox-kdb2mt ACL map

Service plugins

Service plugins can be used by various processes (i.e. from different subsystems), as such, we have put them in this general category.

  • authmgr(4gx) — Demultiplexer for authentication requests
  • dnsbl_filter(4gx) — DNS Blacklist filtering
  • ldap_adaptor(4gx) — LDAP connector for authentication
  • mysql_adaptor(4gx) — MySQL/MariaDB connector for user metadata and authentication
  • timer_agent(4gx) — Service plugin for deferred command execution with timer(8gx)

Language bindings

mapi(4gx) — PHP module providing MAPI functions

Configuration files

Program configuration files reside within /etc/gromox. The format for .cfg files is: one "key=value" pair per line. Empty lines are ignored, as are lines beginning with a '#' character. Lines can have a maximum length of 1024. Each key=value line is logically split at the equals sign, and whitespace is trimmed around key and value. Comments at the end of a value are not supported. Escape sequences are not supported.

The format for .ini files is: one "key=value" pair per line. Empty lines are ignored, as are lines beginning with a ';' character.

Many programs have a config_file_path directive with which the search path for further config files can be specified. For example, http(8gx) defaults to config_file_path=/etc/gromox/http:/etc/gromox, so the mysql_adaptor(4gx) plugin as loaded by http will first try /etc/gromox/http/mysql_adaptor.cfg, then /etc/gromox/mysql_adaptor.cfg. This allows having one file that is shared between multiple programs as well as being able to override on a per program-basis.

Listing of config files per component

A list of components and the config files they potentially use.

  • alias_resolve(4gx) inside delivery(8gx): /etc/gromox/alias_resolve.cfg, /etc/gromox/mysql_adaptor.cfg
  • authmgr(4gx) inside delivery(8gx), delivery-queue(8gx), http(8gx), imap(8gx), midb(8gx), pam_gromox(4gx), pop3(8gx), zcore(8gx): /etc/gromox/authmgr.cfg
  • autodiscover(4gx) inside php-fpm(8): /etc/gromox/autodiscover.ini, /etc/gromox/mysql_adaptor.cfg
  • delivery(8gx): /etc/gromox/alias_resolve.cfg, /etc/gromox/exmdb_local.cfg, /etc/gromox/ldap_adaptor.cfg, /etc/gromox/mlist_expand.cfg, /etc/gromox/mysql_adaptor.cfg
  • delivery-queue(8gx): /etc/gromox/authmgr.cfg, /etc/gromox/midb_agent.cfg, /etc/gromox/ldap_adaptor.cfg, /etc/gromox/mysql_adaptor.cfg
  • event(8gx): /etc/gromox/event.cfg
  • exchange_emsmdb(4gx) inside http(8gx): /etc/gromox/exchange_emsmdb.cfg
  • exchange_nsp(4gx) inside http(8gx): /etc/gromox/exchange_nsp.cfg
  • exchange_rfr(4gx) inside http(8gx): no config file
  • exmdb_provider(4gx) inside http(8gx): /etc/gromox/exmdb_provider.cfg
  • http(8gx): /etc/gromox/cache.txt, /etc/gromox/exchange_emsmdb.cfg, /etc/gromox/exchange_nsp.cfg, etc/gromox/exmdb_provider.cfg, /etc/gromox/fastcgi.txt, /etc/gromox/rewrite.txt
  • imap(8gx): /etc/gromox/authmgr.cfg, /etc/gromox/event_proxy.cfg, /etc/gromox/event_stub.cfg, /etc/gromox/imap.cfg, /etc/gromox/ldap_adaptor.cfg, /etc/gromox/mysql_adaptor.cfg
  • midb_agent(4gx) inside delivery-queue(8gx), imap(8gx), pop3(8gx): /etc/gromox/midb_agent.cfg
  • mlist_expand(4gx) inside delivery(8gx): /etc/gromox/mlist_expand.cfg
  • mod_cache(4gx) inside http(8gx): /etc/gromox/http.cfg, /etc/gromox/cache.txt
  • mod_fastcgi(4gx) inside http(8gx): /etc/gromox/http.cfg, /etc/gromox/fastcgi.txt
  • mod_rewrite(4gx) inside http(8gx): /etc/gromox/http.cfg, /etc/gromox/rewrite.txt
  • mh_emsmdb(4gx) inside http(8gx): no config file
  • mh_nsp(4gx) inside http(8gx): no config file
  • pop3(8gx): /etc/gromox/authmgr.cfg, /etc/gromox/event_proxy.cfg, /etc/gromox/imap.cfg, /etc/gromox/ldap_adaptor.cfg, /etc/gromox/mysql_adaptor.cfg
  • timer(8gx): /etc/gromox/timer.cfg
  • timer_agent(4gx) inside http(8gx), zcore(8gx): /etc/gromox/timer_agent.cfg
  • user_filter(4gx) inside http(8gx), imap(8gx), pop3(8gx): /etc/gromox/gromox.cfg
  • zcore(8gx): /etc/gromox/authmgr.cfg, /etc/gromox/zcore.cfg, /etc/gromox/ldap_adaptor.cfg, /etc/gromox/mysql_adaptor.cfg, /etc/gromox/timer_agent.cfg

Listing of components per config file

  • /etc/gromox/alias_resolve.cfg: used by the alias_resolve(4gx) plugin, accessed process-wise by the delivery(8gx) process.
  • /etc/gromox/authmgr.cfg: used by the authmgr(4gx) and pam_gromox(4gx) plugin, accessed process-wise by delivery(8gx), delivery-queue(8gx), http(8gx), imap(8gx), midb(8gx), pop3(8gx), zcore(8gx), and arbitrary PAM applications.
  • /etc/gromox/autodiscover.ini: used by the autodiscover(4gx) component, accessed process-wise by php-fpm(8).
  • /etc/gromox/event.cfg: used by the event(8gx) process.
  • /etc/gromox/event_proxy.cfg: used by the event_proxy(4gx) plugin, accessed process-wise by imap(8gx), midb(8gx), pop3(8gx).
  • /etc/gromox/event_stub.cfg: used by the event_stub(4gx) plugin, accessed process-wise by imap(8gx).
  • /etc/gromox/exchange_emsmdb.cfg: used by the exchange_emsmdb(4gx) plugin, accessed process-wise by http(8gx).
  • /etc/gromox/exchange_nsp.cfg: used by the exchange_nsp(4gx) plugin, accessed process-wise by http(8gx).
  • /etc/gromox/exmdb_local.cfg: used by the exmdb_local(4gx) plugin, accessed process-wise by delivery(8gx).
  • /etc/gromox/exmdb_provider.cfg: used by the exmdb_provider(4gx) plugin, accessed process-wise by http(8gx).
  • /etc/gromox/gromox.cfg: An effort to consolidate all the invididual .cfg files you see around here. This is a work-in-progress. See the gromox.cfg(5) manpage.
  • /etc/gromox/http.cfg: used by the mod_cache(4gx), mod_fastcgi(4gx), mod_rewrite(4gx) plugins, and the http(8gx) process.
  • /etc/gromox/imap.cfg: used by the imap(8gx) process.
  • /etc/gromox/ldap_adaptor.cfg: used by the ldap_adaptor(4gx) plugin, accessed process-wise by delivery(8gx), delivery-queue(8gx), http(8gx), imap(8gx), midb(8gx), pop3(8gx), zcore(8gx), and arbitrary PAM applications.
  • /etc/gromox/midb_agent.cfg: used by the midb_agent(4gx) plugin, accessed process-wise by delivery-queue(8gx), imap(8gx), pop3(8gx).
  • /etc/gromox/mlist_expand.cfg: used by the mlist_expand(4gx) plugin, accessed process-wise by delivery(8gx).
  • /etc/gromox/mysql_adaptor.cfg: used by the alias_resolve(4gx), mysql_adaptor(4gx) plugins, accessed process-wise by delivery(8gx), delivery-queue(8gx), http(8gx), imap(8gx), midb(8gx), pop3(8gx), zcore(8gx), and arbitrary PAM applications.
  • /etc/gromox/midb.cfg: used by the midb(8gx) process.
  • /etc/gromox/mod_cache.txt: used by the mod_cache(4gx) plugin, accessed process-wise by http(8gx).
  • /etc/gromox/mod_fastcgi.txt: used by the mod_fastcgi(4gx) plugin, accessed process-wise by http(8gx).
  • /etc/gromox/mod_rewrite.txt: used by the mod_rewrite(4gx) plugin, accessed process-wise by http(8gx).
  • /etc/gromox/mysql_adaptor.cfg: used by the autodiscover(4gx) plugin, http(8gx), imap(8gx), pop3(8gx), zcore(8gx) processes.
  • /etc/gromox/pam.cfg: used by the pam_gromox(4gx) plugin, accessed process-wise by arbitrary PAM applications.
  • /etc/gromox/pop3.cfg: used by the pop3(8gx) process.
  • /etc/gromox/timer.cfg: used by the timer(8gx) process.
  • /etc/gromox/timer_agent.cfg: used by the timer_agent(4gx) plugin, accessed process-wise by http(8gx), zcore(8gx).
  • /etc/gromox/zcore.cfg: used by the zcore(8gx) process.

Databases

  • User information is held in a MariaDB/MySQL database. This database can be accessed by multiple Gromox servers, and so enables distributed Gromox operation. The MariaDB system itself provides the necessary utilities for distributing or replicating this database.
  • Per-user e-mail messages are stored in a SQLite database (e.g. /var/lib/gromox/user/m1/1/1/exchange.sqlite3), as is a message index (e.g. /var/lib/gromox/user/m1/1/1/midb.sqlite3). These are normally only used by one system, but can be shared through network filesystems provided that file locking is properly implemented in the filesystem driver. Normal file mechanisms can be used to backup or transfer the database to another Gromox host.

Host addresses

Gromox exclusively uses the AF_INET6 socket family with the Berkeley/BSD/POSIX socket API. What this means is that, whenever an IP address is logged, it will have the form specified in RFC 4291 §2.2/§2.5.5. Furthermore, whenever some configuration file directive (field) requires an IP address (i.e. you cannot or do not want to use a hostname), the RFC 4291 form must be used for both IPv6 and IPv4.

Listening sockets

  • /run/gromox/zcore.sock — zcore(8gx)
  • *:24 — delivery-queue(8gx) LMTP/SMTP service (when Postfix is on 25)
  • :*25 — Normally, your own MTA (postfix(1), exim(8), whatever the case may be). delivery-queue(8gx) will only be on 25 in developer setups that wish to cut and skip Postfix/etc. to get a simpler test setup.
  • *:80 — http(8gx) HTTP service
  • *:110 — pop3(8gx) POP3 service
  • *:143 — imap(8gx) IMAP service
  • *:443 — http(8gx) HTTP over implicit TLS
  • *:993 — imap(8gx) IMAP over implicit TLS
  • *:995 — pop3(8gx) POP3 over implicit TLS
  • [::1]:5000 — exmdb_provider(4gx) plugin inside http(8gx)
  • [::1]:5555 — midb(8gx) service
  • [::1]:6666 — timer(8gx) service
  • [::1]:33333 — event(8gx) service

Files

The exact paths depend on the options used when Gromox's build was configured. Especially the path for libraries, represented in this documentation as /usr/lib/gromox, may for example actually be /usr/lib64/gromox or /usr/lib/riscv64-linux-gnu, depending on the platform.

  • /usr/lib/gromox/libgxh_*.so: HTTP processing plugins for http(8gx)
  • /usr/lib/gromox/libgxm_*.so: hook plugins for delivery(8gx)
  • /usr/lib/gromox/libgxp_*.so: PDU processing plugins for http(8gx)
  • /usr/lib/gromox/libgxs_*.so: service plugins
  • /usr/share/gromox/cpid.txt: mapping between character set IDs and names
  • /usr/share/gromox/folder_names.txt: Translations for essential folders in a message store.
  • /usr/share/gromox/lang_charset.txt: mapping from language code to character set
  • /usr/share/gromox/lcid.txt: mapping between locale IDs and names
  • /usr/share/gromox/mime_extension.txt: mapping between file extensiosn and MIME types
  • /var/lib/gromox: basic root directory of all variadic data for Gromox
  • /var/lib/gromox/queue: directory for delivery-queue(8) temporary files
  • /var/lib/gromox/user: default directory hierarchy for private mailboxes
  • /var/lib/gromox/domain: default directory hierarchy for public mailboxes (public folders)
    Additional hierarchies for private and public can be added to exmdb_list.txt.
  • .../user/account@domain: individual mailbox container
    The directory name/path has only few requirements. It needs to be within one of the exmdb_list.txt-specified hierarchies for private/public hierarchies, and the users.maildir column in MySQL needs to reflect that location. Some user management tools generate extra directory levels, e.g. /user/m1/1/0.
  • .../a@d/exmdb/exchange.sqlite3: mail store with almost everything (no mail bodies)
  • .../a@d/cid/: attachments and message bodies (PR_BODY, PR_HTML, PR_RTF_COMPRESSED).
  • .../a@d/eml/mid_string: RFC5322 representation for a message.
    mid_string has no required form. Typically, there is timestamp.seqid.hostname which represents EMLs captured by delivery(8gx) on ingestion, and timestamp.seqid.midb for EMLs generated by midb(8gx) out of MAPI messages.
  • .../a@d/ext/mid_string: Digest for the RFC5322 file.
    This JSON-encoded file contains e.g. indexing information for individual MIME parts of the RFC5322 representation. Generated by midb(8gx).

fail2ban integration

Daemons emit a mostly consistent log messages on authentication failures that can be matched with (PCRE):

/rhost=\[(\S+)?\]\S* user=(\S+) .*(auth|login.*|logon) rejected:/

Operation texts can be "HTTP auth rejected" (http), "zs_logon rejected" (zcore), "zs_logon_token rejected" (zcore), "LOGIN phase0 rejected" (imap), "LOGIN phase1 rejected" (imap), "LOGIN phase2 rejeceted" (imap), "login rejected" (pop3).

Duration specifications

Duration strings must be of the form:

duration := quantum [ quantum ]*

quantum := number unit

# "number" can be whatever strtol(3) accepts. If a period is detected, parsing switches to strtod(3).

unit := "ns" | "nsec" | "µs" | "µsec" | "ms" | "msec" | "s" | "sec" | "second" | "seconds" | "min" | "minute" | "minutes" | "h" | "hour" | "hours" | "d" | "day" | "days" | "week" | "weeks" | "month" | "months" | "y" | "year" | "years"

Whitespace is ignored whereever it appears (so use as much as you need). Quanta with the same unit may be used; they are simply added together. Per this syntax, numbers can be positive or negative, integral or fractional (be mindful of precision limits of computers' floating-point math).

Examples: 1d1h1m1s, 3.5 hours, 1 hour 1 hour (2 hours), 1 hour 60 minutes (2 hours)

Note that Gromox may impose additional restrictions on specific configuration directives after the basic parse to enforce certain minimum and maximum values.

Gromox