Detect Email Forwarding Rule in Elastic Security
Adversaries may set up email forwarding rules to covertly collect and monitor victim email communications. By creating inbox rules, mailbox-level SMTP forwarding configurations, or Exchange transport rules, adversaries can silently redirect all or targeted messages to attacker-controlled accounts — internal or external — without the victim's awareness. This technique provides persistent intelligence access even after compromised credentials are reset, because forwarding rules survive password changes. Adversaries may also use the Microsoft Messaging API (MAPI) to create hidden inbox rules not visible through Outlook, OWA, or standard Exchange administration tools, enabling long-term covert collection. Threat groups including LAPSUS$, Scattered Spider, Kimsuky, Star Blizzard, and Silent Librarian have actively abused this technique. LAPSUS$ notably created tenant-level Exchange transport rules to forward all organizational email to newly created attacker-controlled accounts, achieving org-wide collection with a single rule.
MITRE ATT&CK
- Tactic
- Collection
- Technique
- T1114 Email Collection
- Sub-technique
- T1114.003 Email Forwarding Rule
- Canonical reference
- https://attack.mitre.org/techniques/T1114/003/
Elastic Detection Query
sequence by user.name with maxspan=5m
[any where event.dataset == "o365.audit" and event.provider == "Exchange"
and event.action in~ ("New-InboxRule", "Set-InboxRule", "Enable-InboxRule",
"New-TransportRule", "Set-TransportRule", "Enable-TransportRule",
"Set-Mailbox")
and (
o365.audit.Parameters.ForwardTo != null or
o365.audit.Parameters.ForwardAsAttachmentTo != null or
o365.audit.Parameters.RedirectTo != null or
o365.audit.Parameters.ForwardingSmtpAddress != null or
o365.audit.Parameters.ForwardingAddress != null or
o365.audit.Parameters.DeliverToMailboxAndForward != null or
o365.audit.Parameters.RedirectMessageTo != null or
o365.audit.Parameters.BlindCopyTo != null
)
] Detects creation or modification of email forwarding rules in Microsoft 365 Exchange via Elastic EQL, targeting inbox rules, transport rules, and mailbox-level SMTP forwarding. Flags external forwarding targets, transport-level rules (org-wide impact), and hidden rules with severity scoring.
Data Sources
Required Tables
False Positives & Tuning
- IT administrators legitimately configuring email forwarding for shared mailboxes or distribution lists during onboarding or offboarding workflows
- Business users setting up forwarding to personal devices or secondary work accounts with explicit IT approval (e.g., mobile email sync rules)
- Automated systems or SaaS integrations (e.g., Zapier, Power Automate) programmatically managing inbox rules for workflow automation
Other platforms for T1114.003
Testing Methodology
Validate this detection against 4 adversary techniques from Atomic Red Team. Each test below lists the behaviour to exercise and the telemetry you should expect to see. Executable commands and cleanup steps are available with Pro.
- Test 1Create Inbox Forwarding Rule via Exchange Online PowerShell
Expected signal: OfficeActivity (Sentinel) and o365:management:activity (Splunk): Operation=New-InboxRule, [email protected], [email protected], Parameters array contains {Name:ForwardTo, Value:[email protected]}. Event appears in Unified Audit Log within 15-60 minutes. Azure AD Sign-In Logs will record the Exchange Online session from the admin account.
- Test 2Set Mailbox-Level SMTP Forwarding via Set-Mailbox
Expected signal: OfficeActivity: Operation=Set-Mailbox, Parameters array contains {Name:ForwardingSmtpAddress, Value:[email protected]} and {Name:DeliverToMailboxAndForward, Value:True}. This forwarding is NOT visible via Get-InboxRule — only via Get-Mailbox -Identity victim | fl ForwardingSmtpAddress, ForwardingAddress, DeliverToMailboxAndForward.
- Test 3Create Org-Wide Transport Rule to Blind-Copy All Mail (LAPSUS$ Pattern)
Expected signal: OfficeActivity: Operation=New-TransportRule, [email protected], Parameters contains {Name:BlindCopyTo, Value:[email protected]} and {Name:FromScope, Value:InOrganization}. This is NOT logged to individual mailbox audit logs — only appears in Exchange Admin Audit Log and the Unified Audit Log at the tenant level. Transport rule changes take effect within minutes.
- Test 4Bulk Enumerate All Mailbox Forwarding Configurations (Reconnaissance Phase)
Expected signal: OfficeActivity: Multiple Operation=Get-InboxRule events from admin account accessing many mailboxes in rapid succession. High-volume Exchange admin read operations within a short time window generate multiple OfficeActivity records. Azure AD Sign-In Logs record the session. This pattern can be detected with anomaly-based analytics on Exchange admin read volume.
References (10)
- https://attack.mitre.org/techniques/T1114/003/
- https://blog.compass-security.com/2018/09/hidden-inbox-rules-in-microsoft-exchange/
- https://blogs.technet.microsoft.com/timmcmic/2015/06/08/exchange-and-office-365-mail-forwarding-2/
- https://learn.microsoft.com/en-us/exchange/security-and-compliance/mail-flow-rules/mail-flow-rules
- https://www.us-cert.gov/ncas/alerts/TA18-086A
- https://www.microsoft.com/en-us/security/blog/2022/03/22/dev-0537-criminal-actor-targeting-organizations-for-data-exfiltration-and-destruction/
- https://learn.microsoft.com/en-us/microsoft-365/security/office-365-security/external-email-forwarding
- https://github.com/sensepost/ruler
- https://learn.microsoft.com/en-us/powershell/module/exchange/new-inboxrule
- https://learn.microsoft.com/en-us/powershell/module/exchange/new-transportrule
Unlock Pro Content
Get the full detection package for T1114.003 including response playbook, investigation guide, and atomic red team tests.