emailrelay/doc/windows.txt
Graeme Walker b0a0cb1b42 v2.1
2019-09-27 12:00:00 +00:00

151 lines
6.9 KiB
Plaintext

E-MailRelay Windows
===================
Setup program
-------------
Installing E-MailRelay on Windows should be straightforward if you have the
setup program "emailrelay-setup.exe" and its associated "payload" files.
Run "emailrelay-setup.exe" as an administrator if you are going to be installing
into protected directories like "Program Files".
The setup GUI will take you through the installation options and then install
the run-time files into your chosen locations.
If anything goes wrong with the installation process then you can still just
run the main E-MailRelay executable straight out of the distribution zip file.
Follow the "Manual installation" section below for more help.
Running the program
-------------------
After a successful installation you should see E-MailRelay listed in the Windows
Start Menu. This will run the "emailrelay-start.bat" batch file to start
the E-MailRelay server, and you should then see an icon appear in the Windows
system tray.
Configuration
-------------
E-MailRelay is configured though command-line options like "--verbose" or
"--spool-dir=c:/temp" in the "emailrelay-startup.bat" batch file.
These options are all documented in the reference document, although there are
some Windows-specific variations:
* The "--syslog" option refers to the Windows Event Viewer's Application log.
* The "--no-daemon" option is used for a normal window rather than an icon in the system tray.
* The "--minimise" option, used with "--no-daemon", makes the window start minimised.
* The "--hidden" option with "--no-daemon" hides all windows and suppresses message boxes.
The Windows-only "--show" option can be used as a more flexible alternative
to "--no-daemon" and "--hidden" using "--show=popup" and "--show=hidden"
respectively, or "--show=window" for a minimisable window, "--show=tray"
for the default system-tray icon or "--show=window,tray" for both.
Account information can be configured by editing the E-MailRelay "secrets" file.
Look for the "--client-auth" or "--server-auth" options in the startup batch
file to find out where this is.
Manual installation
-------------------
The manual installation process for when you do not have the self-extracting
setup program, goes something like this:
* Create a new program directory "c:\Program Files\E-MailRelay"
* Copy the packaged files into "c:\Program Files\E-MailRelay"
* Create a new spool directory "c:\ProgramData\E-MailRelay\spool"
* Create a new text file, eg. "c:\ProgramData\E-MailRelay\emailrelay-auth.txt", to contain account details
* Add your account details to "emailrelay-auth.txt" with a line like "client plain myaccount mypassword"
* Right-drag "emailrelay.exe" onto the desktop to create a shortcut for the server.
* Add "--as-server --verbose" to the server shortcut properties in the "target" box.
* Right-drag again to create a shortcut to do the forwarding.
* Add "--as-client example.com:smtp --client-auth c:\ProgramData\E-MailRelay\emailrelay-auth.txt" to the client shortcut.
Copy the shortcuts to "Start Menu" and "Startup" folders as necessary.
Running as a service
--------------------
E-MailRelay can be set up as a service so that it starts up automatically at
boot-time. If you are setting this up manually you must first have a one-line
batch file called "emailrelay-start.bat" that contains all the command-line
options for running the E-MailRelay server, and you must have a simple
configuration file called "emailrelay-service.cfg" that points to it. The
configuration file must be in the same directory as the
"emailrelay-service.exe" executable.
The batch file should contain a single line, something like this:
start "emailrelay" "C:\Program Files\E-MailRelay\emailrelay.exe" --forward-to smtp.example.com:25 ...
There is no need to use "--no-daemon" and "--hidden"; these are added
automatically.
The contents of the configuration file can be a single line like this:
dir-config="C:\ProgramData\E-MailRelay"
Then just run "emailrelay-service --install" from an Administrator command
prompt to install the service.
Every time the service starts it reads the configuration file and the startup
batch file in order to run the E-MailRelelay program.
If you need to run multiple E-MailRelay services then put a unique service
name and display name on the "emailrelay-service --install <name> <display-name>"
command-line. The service name you give is used to derive the name of the
"<name>-start.bat" batch file that contains the E-MailRelay server's
command-line options, so you will need to create that first.
Uninstall
---------
To uninstall:
* Stop the program and/or the service ("ControlPanel"->"SystemAndSecurity"->"AdministrativeTools"->"Services").
* Uninstall the service, if installed ("emailrelay-service --remove").
* Delete the files from the E-MailRelay "program files" folder (eg. "C:\Program Files\E-MailRelay").
* Delete the files from the E-MailRelay "program data" folder (eg. "C:\ProgramData\E-MailRelay").
* Delete any desktop shortcuts (eg. "%USERPROFILE%\Desktop\E-MailRelay.lnk").
* Delete any start menu shortcuts (eg. "%APPDATA%\Microsoft\Windows\Start Menu\Programs\E-MailRelay.lnk").
* Delete any auto-start shortcuts (eg. "%APPDATA%\Microsoft\Windows\Start Menu\Programs\Startup\E-MailRelay.lnk").
* Clean up the registry under "HKLM\System\CurrentControlSet\Services\EventLog\Application\emailrelay".
Diagnostics
-----------
E-MailRelay logging is sent to the Windows Event Log and/or written to a log
file, and individual failed mail messages will have the failure reason recorded
inside the ".bad" envelope file.
The Windows Event Log can be accessed by running "eventvwr.exe" or going to
"ControlPanel"->"SystemAndSecurity"->"AdministrativeTools"->"EventViewer"; from
there look under "Windows Logs" and "Application".
You can increase the verbosity of the logging by adding the "--verbose" option
to the E-MailRelay command-line, typically by editing the "emailrelay-start.bat"
batch script.
Testing with telnet
-------------------
The "telnet" program can be used for testing an E-MailRelay server. You should
start by enabling the Windows telnet client using
"ControlPanel"->"Programs"->"TurnWindowsFeaturesOnAndOff".
Then run telnet from a command prompt, using "localhost" and the E-MailRelay
port number as command-line parameters:
telnet localhost 25
This should show a greeting from the E-MailRelay server and then you can
start typing SMTP commands like "EHLO", "MAIL FROM:<..>", "RCPT TO:<...>"
and "DATA".
Building from source
--------------------
E-MailRelay can be compiled on Windows using Microsoft Visual Studio C++ (MSVC)
or mingw-w64. For MSVC builds there is a perl script ("winbuild") that creates
"cmake" files from the autotools makefiles, runs "cmake" to create the MSVC
project files and then runs "msbuild" to compile E-MailRelay. If perl, cmake,
MSVC, Qt and mbedTLS source are installed in the right way then the
"winbuild.bat" batch file should be able to do a complete MSVC release build
in one go.
_____________________________________
Copyright (C) 2001-2019 Graeme Walker