Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/pro/exchange-catchall

Exchange CatchAll Agent
https://github.com/pro/exchange-catchall

Last synced: 2 days ago
JSON representation

Exchange CatchAll Agent

Awesome Lists containing this project

README

        

Exchange CatchAll Agent [![Build Status](https://travis-ci.org/Pro/exchange-catchall.png?branch=master)](https://travis-ci.org/Pro/exchange-catchall)
=============

CatchAll Agent for Exchange Server.

This code is based on the work of http://catchallagent.codeplex.com/

You can define a domain or regex (regular expression) and redirect all E-Mails sent to this domain to forward them to another address.
This only works if the email is received from an external mail server. Internal mails currently can't be forwarded. See issue [#13](https://github.com/Pro/exchange-catchall/issues/13) for further info.

Using MySQL (not required for basic functionality) you get additional features:
- you can block E-Mails sent to specific addresses of such a catchall domain.
- the number of blocked hits will be logged
- each forwarded E-Mail will be logged

**Updating to Version >=1.6.0:** Please read the following section before updating: [Updating to Version 1.6.0](#updating-to-version-160)!

## Supported versions

The .dll is compiled for .NET 3.5 (Exchange 2007 and 2010) or .NET 4 (Exchange 2013 & 2016)

* Exchange 2007 SP3 (8.3.*)
* Exchange 2010 (14.0.*)
* Exchange 2010 SP1 (14.1.*)
* Exchange 2010 SP2 (14.2.*)
* Exchange 2010 SP3 (14.3.*)
* Exchange 2013 (15.0.516.32)
* Exchange 2013 CU1 (15.0.620.29)
* Exchange 2013 CU2 (15.0.712.24)
* Exchange 2013 CU3 (15.0.775.38)
* Exchange 2013 SP1 (15.0.847.32)
* Exchange 2013 CU5 (15.0.913.22)
* Exchange 2013 CU6 (15.0.995.29)
* Exchange 2013 CU7 (15.0.1044.25)
* Exchange 2013 CU8 (15.0.1076.9)
* Exchange 2013 CU9 (15.0.1104.5)
* Exchange 2013 CU10 (15.0.1130.7)
* Exchange 2013 CU11 (15.0.1156.6)
* Exchange 2013 CU12 (15.0.1178.4)
* Exchange 2013 CU13 (15.0.1210.3)
* Exchange 2013 CU14 (15.0.1236.3)
* Exchange 2013 CU15 (15.0.1263.5)
* Exchange 2016 Preview (15.1.225.17)
* Exchange 2016 RTM (15.1.225.42)
* Exchange 2016 CU1 (15.1.396.30)
* Exchange 2016 CU2 (15.1.466.34)
* Exchange 2016 CU3 (15.1.544.27)
* Exchange 2016 CU4 (15.1.669.32)

## Installing the Receive Agent

1. Download the .zip and extract it e.g. on the Desktop: [Exchange CatchAll Master.zip](https://github.com/Pro/exchange-catchall/archive/master.zip)
2. If you want to use MySQL, then install MySQL Server and execute the commands from `database.sql` to create the corresponding tables (modify the commands if needed). Don't forget to grant permissions to the user.
3. Open "Exchange Management Shell" from the Startmenu
4. Execute the following command to allow execution of local scripts (will be reset at last step): `Set-ExecutionPolicy Unrestricted`
5. Cd into the folder where the zip has been extracted.
6. Execute the install script `.\install.ps1`
7. Follow the instructions. For the configuration see next section.
8. Reset the execution policy: `Set-ExecutionPolicy Restricted`
9. Check EventLog for errors or warnings.
Hint: you can create a user defined view in EventLog and then select "Per Source" and as the value "Exchange CatchAll"

Make sure that the priority of the CatchAll Agent is quite high (best is to set it directly after any Antivirus system).
To get a list of all the Export Agents use the Command `Get-TransportAgent`

To change the priority use `Set-TransportAgent -Identity "Exchange CatchAll" -Priority 3`

If you have any problems installing, please check out the [troubleshooting guideline](https://github.com/Pro/exchange-catchall/blob/master/TROUBLESHOOT.md)

### Configuring the agent
Edit the .config file to fit your needs.

The `domainSection` defines the CatchAll domains.
The destination address must be handled by the local exchange server and cannot be an external E-Mail address. Don't forget to add the cathch all domain to Exchange.
The Agent first checks if the recipient address is assigned to an existing user. If not, it checks if the address should be rewritten by the agent to a catchall address.

The `customSection` defines different application settings:

* `database`: the settings for MySQL logging and blocked check. If you don't need it, set `enabled` to false. Currently only `mysql` is supported but feel free to create a pull request for other databases.
* `general`: Set LogLevel (See Logging section below). Enable/Disable 'X-OrigTo' header by setting `AddOrigToHeader` accordingly. `RejectIfBlocked` defines, if a blocked E-Mail address in MySQL causes a '550 5.1.1 Recipient rejected' response.

```xml















```

#### Logging
The CatchAll agent logs by default all errors and warnings into EventLog.
You can set the LogLevel in the .config file:

Possible values:
* 0 = no logging
* 1 = Error only
* 2 = Warn+Error
* 3 = Info+Warn+Error

## Updating the Transport Agent

If you want to update the Exchange CatchAll Transport Agent simply re-download the .zip file and follow the steps in the installation section.

### Updating to Version 1.6.0

If you have a version prior to 1.6.0 installed and are updating the CatchAll Agent please change the following line in you config file:

```

```
to
```

```

Additional Information on Connection Strings for MySQL can be found here: https://www.connectionstrings.com/mysql/

You also need to rename the Database Table `cought` into `caught` and the column `idCought` to `idCaught`:

```
RENAME TABLE cought TO caught;
ALTER TABLE caught CHANGE idCought idCaught int(11) NOT NULL AUTO_INCREMENT;
```

## Uninstalling the Transport Agent

Follow the install instructions but execute `.\uninstall.ps1` instead.

## Notes for developers

### Required DLLs for developing

It isn't allowed to distribute the .dll required for development of this transport agent.
http://blogs.msdn.com/b/webdav_101/archive/2009/04/02/don-t-redistribute-product-dlls-unless-you-know-its-safe-and-legal-to-do-so.aspx

Therefore you have to copy all files from


C:\Program Files\Microsoft\Exchange Server\V14\Public
Microsoft.Exchange.Data.Common.dll
Microsoft.Exchange.Data.Common.xml
Microsoft.Exchange.Data.Transport.dll
Microsoft.Exchange.Data.Transport.xml

into the corresponding subdirectory from the Lib directory of this project.

#### Debugging
If you want to debug the .dll on your Exchange Server, you need to install [Visual Studio Remote Debugging](http://msdn.microsoft.com/en-us/library/vstudio/bt727f1t.aspx) on the Server.

1. After the Remote Debugging Tools are installed on the Server, open Visual Studio
2. Compile the .dll with Debug information
3. Copy the recompiled .dll to the server
4. In Visual Studio select Debug->Attach to Process
5. Under 'Qualifier' input the server IP or Host Name
6. Select "Show processes from all users"
7. Select the process `EdgeTransport.exe` and then press 'Attach'
8. When reached, the process should stop at the breakpoint

## Changelog

* 22.12.2016 [1.6.9]:
- New: Support for Exchange 2013 CU14, CU15 and 2016 CU4

* 25.09.2016 [1.6.8]:
- New: Support for Exchange 2016 CU3

* 01.08.2016 [1.6.7]:
- New: Support for Exchange 2013 SP1 CU13 & Exchange 2016 CU2

* 24.04.2016 [1.6.6]:
- Fix: Use MySQL charset for better unicode support: utf8mb4

* 29.03.2016 [1.6.5]:
- New: Support for Exchange 2013 SP1 CU11, CU12 & Exchange 2016 CU1

* 01.11.2015 [1.6.4]:
- New: Support for Exchange 2013 SP1 CU10 & Exchange 2016 RTM

* 09.09.2015 [1.6.3]:
- New: Support for all current Exchange Versions
- Fix: Install script now unlocking files (#8)

* 11.03.2014 [1.6.2]:
- Fixed Issue #7 (Exchange 2013 Null Pointer if database disabled)

* 10.03.2014 [1.6.0]:
- Added MSSQL database support (Thanks to @AlexLaroche)
- Fixed Issue #3 (Same message ID's in Dictionary for Orig-To Header)

* 24.01.2014 [1.5.2]:
- Fixed database disable config (not correctly evaluated)
- Added additional supported Exchange versions (2007, 2010, 2013)

* 27.11.2013 [1.5.1]:
- Support for regex domains

* 25.11.2013 [1.5.0.0]:
- Added custom X-OrigTo header.
- Added install and uninstall script.
- Added build for all Exchange 2010 Versions with different SPs.