mirror of
https://github.com/andres-montanez/Magallanes
synced 2024-06-26 01:00:17 +02: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 a new issue