The Alert Forwarder adds email, SMS, Twitter, and push-notification alerts to MT5 EAs and indicators which do not offer this themselves. For example, if an EA or indicator generates an alert on screen then the Alert Forwarder can turn it into an email or a push notification.
The main purpose of the Alert Forwarder is to add email, SMS, Twitter, and push-notification alerts to MT5 EAs and indicators which do not offer this themselves. For example, if an EA or indicator generates an alert on screen then the Alert Forwarder can turn it into an email or a push notification.
The Alert Forwarder scans the MT5 Experts log, looking for entries which match the conditions you give it, and sends out any matching log entries via your choice of email, SMS etc.
The app can also be used to scan the MT5 Journal, generating alerts about events such as disconnections or failed orders.
In addition, the app can be configured to take screenshots of its chart when an event is detected, allowing later diagnosis of problems, inspection of trade set-ups etc. For example, you can use it to take a screenshot of an indicator's chart whenever that indicator writes a particular entry to the MT5 logs.
Unless otherwise specified in writing by FX Blue, this software is licensed for personal use only. You are not allowed to distribute it to other people, regardless of whether or not money is changing hands. You only have a licence to use the software if you, personally, downloaded it from our website.
The software is provided entirely at the user's risk, and you should check it thoroughly before deploying it on computers trading real money. FX Blue accepts no responsibility whatsoever for any loss of any kind caused by installation or use of the software.
The Alert Forwarder is an indicator (not an EA or script). You run the Alert Forwarder by adding the indicator to any chart. It does not have to be on the same chart as an EA which you want it to monitor, unless you want to take screenshots.
You can run multiple copies of the Alert Forwarder, to look for different events in the logs. These indicators can all be on the same chart or on different charts.
You control the settings for the Alert Forwarder using the Inputs tab when adding the indicator to its chart. You must specify some text to search for, and you must turn on at least one of the notification options such as email, SMS etc.
You must turn on the "Allow DLL imports" setting when adding the indicator to the chart. Please note that changing the setting in Tools / Options / Expert Advisors does not affect any indicators (or EAs or scripts) which are already running; this setting is only the default which is used when you next add something to a chart.
The app will not process any entries which already exist in the logs at the time that it starts up. It only processes new log entries which happen while it is running.
For visual confirmation that the Alert Forwarder is running, you can turn on an optional status marker on the chart.
You use the Inputs tab of the indicator to tell it which text to look for in the MT5 logs. You need to choose which log to look at - Experts or Journal - and what text to search for.
You can tell the indicator to look for specific text in either the Message column and/or the Source column of the log.
There are five types of text search which you can use. Please note that the text to search for is always case-sensitive.
Starts with: the entry in the log must start with the text you specify.
Contains: the entry in the log must contain the text you specify.
All words: the text you specify is treated as a list of words, separated by spaces, and each individual word must be found in the log entry.
Any word: the text you specify is treated as a list of words, separated by spaces, and at least one of the words must be found in the log entry.
Exact match: the text you specify must exactly match the whole of the log entry.
The Alert Forwarder can be configured to send emails via MT5's email settings (Tools / Options / Email). You need to specify the text to use as the email subject and body, which can include the variables described below.
The Alert Forwarder can be configured to send MT5 push notifications (Tools / Options / Notifications). You need to specify the text to use for the message, which can include the variables described below. Please note that the MT5 platform has limits on how frequently you are allowed to use push notifications; messages will be rejected by MT5 if you exceed these limits.
The Alert Forwarder can play a sound whenever it finds a matching item in the log. You enter the name of the sound to play. This can be any of the sounds installed in MT5, such as disconnect, alert, news etc (see Tools / Options / Events).
The Alert Forwarder can be configured to display a pop-up alert in MT5 when it finds a matching entry in the logs. This has two main uses: generating pop-up alerts about events in the MT5 Journal such as failed trades; and turning "normal" log entries from an EA or indicator into an alert.
For example, if an EA or indicator creates a type of log entry which you think is serious, but which the EA/indicator only writes to the log without displaying an alert, then you can use the Alert Forwarder to turn this into a pop-up alert.
The Alert Forwarder can generate SMS when it finds a matching entry in the logs. In order to send SMS you will need an account with Nexmo or Clickatell.
The values for settings such as SMS_param1 depend on which carrier you have signed up with.
Phone numbers should be in international format, e.g. 447879215460. You can enter multiple recipient numbers separated by commas.
The Alert Forwarder can send a tweet when it sends a matching entry in the logs.
If you turn on the Twitter functionality, you will be asked to log in to Twitter as soon as you start the Alert Forwarder. You sign in on the Twitter website and then copy and paste a PIN code for use by the app. You only need to do this once. After that, the Alert Forwarder will remember your details, and tweets will be sent immediately and automatically.
Please note that Twitter will not accept consecutive tweets with exactly the same text.
The Alert Forwarder can be configured to take a screenshot whenever it detects a matching entry in the logs. The screenshots are stored in the MQL4\Files directory which you can find via the File / Open Data Folder menu option in MT5. Each screenshot is stored in a separate time-stamped file.
The screenshot only includes the chart on which the Alert Forwarder is running. (MT5 does not provide facilities for taking a screenshot of the entire screen or the whole of MT5). If you want to use the Alert Forwarder to take a picture of the chart activity created by a particular EA or another indicator, then you need to run the Alert Forwarder on the same chart as that EA or indicator.
By default, the screenshot will have the same width and height as the chart. You can override this using the settings in the Screenshots section of the parameters, setting them to non-zero values. You can also override the default filename for the screenshot, by setting a value which can contain text variables such a {ACC} and {TIME}.
To provide confirmation that the Alert Forwarder is running, you can optionally turn on a status marker using the settings on the Inputs tab, creating a label on the chart. You can choose the location of this marker text, and the colour.
In all the text parameters for issuing alerts, such as the email subject or SMS text, you can use the following variables:
Variable | Description |
{TEXT} | The text of the matching item in the log |
{ACC} | Your MT5 broker account number |
{LOCALTIME} | The local time according to your computer's clock |
{BROKERTIME} | The latest reported broker time |
{CURR} | The symbol of your deposit currency |
{BALANCE} | Your current account balance |
{EQUITY} | Your current account equity |
{FREEMARGIN} | Your current free margin |
{MARGININUSE} | Your current margin usage |
{FLOATINGPL} | Your current floating P/L |
{CRLF} | Inserts a new line, for use in email |
If you want to send SMS, then you need an account with either Nexmo (www.nexmo.com) or Clickatell (www.clickatell.com). Please note that the following details are subject to change if Nexmo or Clickatell alter the layout of their websites.
In order to send SMS via Nexmo you need to register on their site at www.nexmo.com. You will need to provide an email address (a real one!) and a mobile phone number to receive a confirmation text. This phone number does not have to be the one which you subsequently want to send alerts to.
Once you have registered, the "Api Settings" section of the Nexmo Dashboard will show you an "API key" and "API secret" for sending texts via your account with them. You then enter these values as the SMS_param1 and SMS_param2 values in the EA's configuration.
If you want to send to a US or Canadian phone number, one extra step may be required because of anti-spam regulations. You may need a "virtual number" to send from, which you enter as the SMS_param3 value in the EA. For further information, please see:
The procedure for setting up an account with Clickatell is a little complicated. The following steps could potentially change if Clickatell alter their website.
You fill in your choice of username and password as the SMS_param1 and SMS_param2 values in the EA's configuration, and you fill in the "API code" as the SMS_param3 value.
The meaning of the SMS settings such as SMS_param1 depends on which carrier you are using:
Parameter | Nexmo account | Clickatell account |
SMS_Carrier | Choose either Nexmo or Clickatell, depending on which you have registered with | |
SMS_param1 | Nexmo "API key" | The username you chose when registering with Clickatell |
SMS_param2 | Nexmo "API secret" | The password you chose when registering with Clickatell |
SMS_param3 | If sending to a US or Canadian number, this needs to be a "virtual number" which you register through Nexmo. For other recipients, this is the text which you want to appear as the sender of the SMS. | The "API code" assigned after creating the HTTP "connection" within your Clickatell account |