| 
									
										
										
										
											2021-06-30 08:00:00 +01:00
										 |  |  | --- | 
					
						
							|  |  |  | title: Configuring the Reroute Email Module | 
					
						
							|  |  |  | date: 2014-12-22 | 
					
						
							|  |  |  | excerpt: | 
					
						
							| 
									
										
										
										
											2021-07-09 17:32:30 +01:00
										 |  |  |     How to configure the Reroute Email module, to prevent sending emails to real | 
					
						
							|  |  |  |     users from your pre-production sites! | 
					
						
							| 
									
										
										
										
											2021-06-30 08:00:00 +01:00
										 |  |  | tags: | 
					
						
							| 
									
										
										
										
											2021-07-09 17:32:30 +01:00
										 |  |  |     - drupal | 
					
						
							|  |  |  |     - drupal-6 | 
					
						
							|  |  |  |     - drupal-7 | 
					
						
							|  |  |  |     - drupal-planet | 
					
						
							|  |  |  |     - email | 
					
						
							| 
									
										
										
										
											2021-06-30 08:00:00 +01:00
										 |  |  | draft: true | 
					
						
							|  |  |  | --- | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [Reroute Email](https://www.drupal.org/project/reroute_email) module uses | 
					
						
							|  |  |  | `hook_mail_alter()` to prevent emails from being sent to users from | 
					
						
							|  |  |  | non-production sites. It allows you to enter one or more email addresses that | 
					
						
							|  |  |  | will receive the emails instead of delivering them to the original user. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | > This is useful in case where you do not want email sent from a Drupal site to
 | 
					
						
							|  |  |  | > reach the users. For example, if you copy a live site to a test site for the
 | 
					
						
							|  |  |  | > purpose of development, and you do not want any email sent to real users of
 | 
					
						
							|  |  |  | > the original site. Or you want to check the emails sent for uniform
 | 
					
						
							|  |  |  | > formatting, footers, ...etc.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | As we don't need the module configured on production (we don't need to reroute | 
					
						
							|  |  |  | any emails there), it's best to do this in code using settings.local.php (if you | 
					
						
							|  |  |  | have one) or the standard settings.php file. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The first thing that we need to do is to enable rerouting. Without doing this, | 
					
						
							|  |  |  | nothing will happen. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ```language-php | 
					
						
							|  |  |  | $conf['reroute_email_enable'] = TRUE; | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The next option is to whether to show rerouting description in mail body. I | 
					
						
							|  |  |  | usually have this enabled. Set this to TRUE or FALSE depending on your | 
					
						
							|  |  |  | preference. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ```language-php | 
					
						
							|  |  |  | $conf['reroute_email_enable_message'] = TRUE; | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The last setting is the email address to use. If you're entering a single | 
					
						
							|  |  |  | address, you can add it as a simple string. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ```language-php | 
					
						
							|  |  |  | $conf['reroute_email_address'] = 'person1@example.com'; | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | In this example, all emails from the site will be rerouted to | 
					
						
							|  |  |  | person1@example.com. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | If you want to add multiple addresses, these should be added in a | 
					
						
							|  |  |  | semicolon-delimited list. Whilst you could add these also as a string, I prefer | 
					
						
							|  |  |  | to use an array of addresses and the `implode()` function. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ```language-php | 
					
						
							|  |  |  | $conf['reroute_email_address'] = implode(';', array( | 
					
						
							|  |  |  |   'person1@example.com', | 
					
						
							|  |  |  |   'person2@example.com', | 
					
						
							|  |  |  |   'person3@example.com', | 
					
						
							|  |  |  | )); | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | In this example, person2@example.com and person3@example.com would receive their | 
					
						
							|  |  |  | emails from the site as normal. Any emails to addresses not in the array would | 
					
						
							|  |  |  | continue to be redirected to person1@example.com. |