mirror of
				https://github.com/hauke68/Magallanes.git
				synced 2025-11-04 09:00:18 +01:00 
			
		
		
		
	Send mail notifications.
This commit is contained in:
		
							parent
							
								
									75a2463240
								
							
						
					
					
						commit
						f646647036
					
				@ -19,6 +19,7 @@ use Mage\Task\ErrorWithMessageException;
 | 
				
			|||||||
use Mage\Task\SkipException;
 | 
					use Mage\Task\SkipException;
 | 
				
			||||||
use Mage\Console;
 | 
					use Mage\Console;
 | 
				
			||||||
use Mage\Config;
 | 
					use Mage\Config;
 | 
				
			||||||
 | 
					use Mage\Mailer;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
use Exception;
 | 
					use Exception;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -177,7 +178,7 @@ class DeployCommand extends AbstractCommand implements RequiresEnvironment
 | 
				
			|||||||
        Console::output('Total time: <dark_gray>' . $timeText . '</dark_gray>.', 1, 2);
 | 
					        Console::output('Total time: <dark_gray>' . $timeText . '</dark_gray>.', 1, 2);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        // Send Notifications
 | 
					        // Send Notifications
 | 
				
			||||||
        $this->sendNotification();
 | 
					        $this->sendNotification(self::$failedTasks > 0 ? false : true);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        // Unlock
 | 
					        // Unlock
 | 
				
			||||||
        if (file_exists('.mage/~working.lock')) {
 | 
					        if (file_exists('.mage/~working.lock')) {
 | 
				
			||||||
@ -514,8 +515,9 @@ class DeployCommand extends AbstractCommand implements RequiresEnvironment
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					    /**
 | 
				
			||||||
     * Send Email Notification if enabled
 | 
					     * Send Email Notification if enabled
 | 
				
			||||||
 | 
					     * @param boolean $result
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    protected function sendNotification()
 | 
					    protected function sendNotification($result)
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
    	$projectName = $this->getConfig()->general('name', false);
 | 
					    	$projectName = $this->getConfig()->general('name', false);
 | 
				
			||||||
    	$projectEmail = $this->getConfig()->general('email', false);
 | 
					    	$projectEmail = $this->getConfig()->general('email', false);
 | 
				
			||||||
@ -525,6 +527,13 @@ class DeployCommand extends AbstractCommand implements RequiresEnvironment
 | 
				
			|||||||
        if (!$projectName || !$projectEmail || !$notificationsEnabled) {
 | 
					        if (!$projectName || !$projectEmail || !$notificationsEnabled) {
 | 
				
			||||||
            return false;
 | 
					            return false;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        $mailer = new Mailer;
 | 
				
			||||||
 | 
					        $mailer->setAddress($projectEmail)
 | 
				
			||||||
 | 
					               ->setProject($projectName)
 | 
				
			||||||
 | 
					               ->setLogFile(Console::getLogFile())
 | 
				
			||||||
 | 
					               ->setEnvironment($this->getConfig()->getEnvironment())
 | 
				
			||||||
 | 
					               ->send($result);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -26,6 +26,12 @@ class Console
 | 
				
			|||||||
	 */
 | 
						 */
 | 
				
			||||||
    private static $log = null;
 | 
					    private static $log = null;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * The current logfile
 | 
				
			||||||
 | 
					     * @var string
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    private static $logFile = null;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					    /**
 | 
				
			||||||
     * Enables or Disables Logging
 | 
					     * Enables or Disables Logging
 | 
				
			||||||
     * @var boolean
 | 
					     * @var boolean
 | 
				
			||||||
@ -181,7 +187,8 @@ class Console
 | 
				
			|||||||
    {
 | 
					    {
 | 
				
			||||||
        if (self::$logEnabled) {
 | 
					        if (self::$logEnabled) {
 | 
				
			||||||
            if (self::$log == null) {
 | 
					            if (self::$log == null) {
 | 
				
			||||||
                self::$log = fopen('.mage/logs/log-' . date('Ymd-His') . '.log', 'w');
 | 
					            	self::$logFile = realpath('.mage/logs') . '/log-' . date('Ymd-His') . '.log';
 | 
				
			||||||
 | 
					                self::$log = fopen(self::$logFile, 'w');
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            $message = date('Y-m-d H:i:s -- ') . $message;
 | 
					            $message = date('Y-m-d H:i:s -- ') . $message;
 | 
				
			||||||
@ -189,6 +196,24 @@ class Console
 | 
				
			|||||||
        }
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * Return the screen buffer
 | 
				
			||||||
 | 
					     * @return string
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    public static function getOutput()
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					    	return self::$screenBuffer;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * Returns the Log File
 | 
				
			||||||
 | 
					     * @return string
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    public static function getLogFile()
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					    	return self::$logFile;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					    /**
 | 
				
			||||||
     * Check Logs
 | 
					     * Check Logs
 | 
				
			||||||
     * @param \Mage\Config $config
 | 
					     * @param \Mage\Config $config
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										92
									
								
								Mage/Mailer.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										92
									
								
								Mage/Mailer.php
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,92 @@
 | 
				
			|||||||
 | 
					<?php
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * This file is part of the Magallanes package.
 | 
				
			||||||
 | 
					*
 | 
				
			||||||
 | 
					* (c) Andrés Montañez <andres@andresmontanez.com>
 | 
				
			||||||
 | 
					*
 | 
				
			||||||
 | 
					* For the full copyright and license information, please view the LICENSE
 | 
				
			||||||
 | 
					* file that was distributed with this source code.
 | 
				
			||||||
 | 
					*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					namespace Mage;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					use Mage\Console;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * Mailer Helper.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * @author Andrés Montañez <andres@andresmontanez.com>
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					class Mailer
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						const EOL = "\r\n";
 | 
				
			||||||
 | 
						const SUBJECT = '[Magallanes] Deployment of {project} to {environment}: {result}';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						protected $address;
 | 
				
			||||||
 | 
						protected $project;
 | 
				
			||||||
 | 
						protected $environment;
 | 
				
			||||||
 | 
						protected $logFile;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						public function setAddress($address)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
					        $this->address = $address;
 | 
				
			||||||
 | 
					        return $this;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						public function setProject($project)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							$this->project = $project;
 | 
				
			||||||
 | 
							return $this;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						public function setEnvironment($environment)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							$this->environment = $environment;
 | 
				
			||||||
 | 
							return $this;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						public function setLogFile($logFile)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							$this->logFile = $logFile;
 | 
				
			||||||
 | 
							return $this;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public function send($result)
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					    	$boundary = md5(date('r', time()));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    	$headers = 'From: ' . $this->address
 | 
				
			||||||
 | 
					    			 . self::EOL
 | 
				
			||||||
 | 
					    			 . 'Reply-To: ' . $this->address
 | 
				
			||||||
 | 
					    			 . self::EOL
 | 
				
			||||||
 | 
					    			 . 'MIME-Version: 1.0'
 | 
				
			||||||
 | 
							 		 . self::EOL
 | 
				
			||||||
 | 
					    	         . 'Content-Type: multipart/mixed; boundary=Mage-mixed-' . $boundary;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    	$subject = str_replace(
 | 
				
			||||||
 | 
								array('{project}', '{environment}', '{result}'),
 | 
				
			||||||
 | 
								array($this->project, $this->environment, $result ? 'SUCCESS' : 'FAILURE'),
 | 
				
			||||||
 | 
								self::SUBJECT
 | 
				
			||||||
 | 
							)
 | 
				
			||||||
 | 
					    	;
 | 
				
			||||||
 | 
					    	$attachment = chunk_split(base64_encode(file_get_contents($this->logFile)));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    	$message = 'This is a multi-part message in MIME format.' . self::EOL
 | 
				
			||||||
 | 
					    	         . '--Mage-mixed-' . $boundary . self::EOL
 | 
				
			||||||
 | 
					    	         . 'Content-Type: text/plain; charset=iso-8859-1' . self::EOL
 | 
				
			||||||
 | 
					    	         . 'Content-Transfer-Encoding: quoted-printable' . self::EOL
 | 
				
			||||||
 | 
					    	         . self::EOL
 | 
				
			||||||
 | 
					    	         . strip_tags(Console::getOutput()) . self::EOL
 | 
				
			||||||
 | 
					    	         . self::EOL
 | 
				
			||||||
 | 
					    	         . '--Mage-mixed-' . $boundary . self::EOL
 | 
				
			||||||
 | 
					    	         . 'Content-Type: text/plain; name="log.txt"' . self::EOL
 | 
				
			||||||
 | 
					    	         . 'Content-Transfer-Encoding: base64' . self::EOL
 | 
				
			||||||
 | 
					    	         . 'Content-Disposition: attachment' . self::EOL
 | 
				
			||||||
 | 
					    	         . self::EOL
 | 
				
			||||||
 | 
					    	         . $attachment . self::EOL
 | 
				
			||||||
 | 
					    	         . '--Mage-mixed-' . $boundary . '--' . self::EOL
 | 
				
			||||||
 | 
					    	         ;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    	$mail_sent = @mail($this->address, $subject, $message, $headers);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
		Loading…
	
		Reference in New Issue
	
	Block a user