Skip to content

Predefined Metadata

KumoMTA provides the ability to set and retrieve metadata at both the connection and message level.

By leveraging metadata, information can be made available to policy running at different phases in the life of a message, where the connection metadata is used for data that is shared in common with all messages injected over a given connection, and the message metadata is for all data related to a given individual message.

There are get and set functions available for both connection and message metadata, and when a message is received all connection metadata is also copied into the message metadata, meaning that for retrieving connection metadata the user can opt to only access message metadata for any value that doesn't change over the life of the connection.

The following metadata values are predefined by KumoMTA and are available to retrieve:

Scope Name Purpose Since
Connection reception_protocol indicates the reception protocol, such as ESMTP (Since: Version 2023.08.22-4d895015)
Connection received_via indicates the IP:port of the KumoMTA listener that is handling this session (Since: Version 2023.08.22-4d895015)
Connection received_from indicates the IP:port of the sending or peer machine in this session (Since: Version 2023.08.22-4d895015)
Connection hostname A copy of the effective value of the hostname set by kumo.start_esmtp_listener (Since: Version 2023.11.28-b5252a41)
Connection authn_id the authentication id if the message was received via authenticated SMTP
Connection authz_id the authorization id if the message was received via authenticated SMTP
Connection ehlo_domain the domain name that was passed in from the sender via the SMTP EHLO or HELO (Since: Version 2024.11.08-d383b033)
Message queue specify the name of the queue to which the message will be queued. Must be a string value.
Message tenant specify the name/identifier of the tenant, if any. Must be a string value.
Message campaign specify the name/identifier of the campaign. Must be a string value.
Message routing_domain Overrides the domain of the recipient domain for routing purposes. (Since: Version 2023.08.22-4d895015)