Browse Source

Reorganize common Deployment code.

1.0
Andrés Montañez 11 years ago
parent
commit
4528788d49
  1. 64
      Mage/Task/BuiltIn/Deployment/Strategy/BaseStrategyTaskAbstract.php
  2. 28
      Mage/Task/BuiltIn/Deployment/Strategy/RsyncTask.php
  3. 27
      Mage/Task/BuiltIn/Deployment/Strategy/TarGzTask.php
  4. 2
      docs/example-config/.mage/config/environment/staging.yml

64
Mage/Task/BuiltIn/Deployment/Strategy/BaseStrategyTaskAbstract.php

@ -0,0 +1,64 @@
<?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\Task\BuiltIn\Deployment\Strategy;
use Mage\Task\AbstractTask;
use Mage\Task\Releases\IsReleaseAware;
/**
* Abstract Base task to concentrate common code for Deployment Tasks
*
* @author Andrés Montañez <andres@andresmontanez.com>
*/
abstract class BaseStrategyTaskAbstract extends AbstractTask implements IsReleaseAware
{
/**
* Checks if there is an override underway
*
* @return bool
*/
protected function checkOverrideRelease()
{
$overrideRelease = $this->getParameter('overrideRelease', false);
if ($overrideRelease == true) {
$releaseToOverride = false;
$resultFetch = $this->runCommandRemote('ls -ld current | cut -d"/" -f2', $releaseToOverride);
if ($resultFetch && is_numeric($releaseToOverride)) {
$this->getConfig()->setReleaseId($releaseToOverride);
}
}
return $overrideRelease;
}
/**
* Gathers the files to exclude
*
* @return array
*/
protected function getExcludes()
{
$excludes = array(
'.git',
'.svn',
'.mage',
'.gitignore',
'.gitkeep',
'nohup.out'
);
// Look for User Excludes
$userExcludes = $this->getConfig()->deployment('excludes', array());
return array_merge($excludes, $userExcludes);
}
}

28
Mage/Task/BuiltIn/Deployment/Strategy/RsyncTask.php

@ -10,7 +10,7 @@
namespace Mage\Task\BuiltIn\Deployment\Strategy; namespace Mage\Task\BuiltIn\Deployment\Strategy;
use Mage\Task\AbstractTask; use Mage\Task\BuiltIn\Deployment\Strategy\BaseStrategyTaskAbstract;
use Mage\Task\Releases\IsReleaseAware; use Mage\Task\Releases\IsReleaseAware;
/** /**
@ -18,7 +18,7 @@ use Mage\Task\Releases\IsReleaseAware;
* *
* @author Andrés Montañez <andres@andresmontanez.com> * @author Andrés Montañez <andres@andresmontanez.com>
*/ */
class RsyncTask extends AbstractTask implements IsReleaseAware class RsyncTask extends BaseStrategyTaskAbstract implements IsReleaseAware
{ {
/** /**
* (non-PHPdoc) * (non-PHPdoc)
@ -48,27 +48,9 @@ class RsyncTask extends AbstractTask implements IsReleaseAware
*/ */
public function run() public function run()
{ {
$overrideRelease = $this->getParameter('overrideRelease', false); $this->checkOverrideRelease();
if ($overrideRelease == true) { $excludes = $this->getExcludes();
$releaseToOverride = false;
$resultFetch = $this->runCommandRemote('ls -ld current | cut -d"/" -f2', $releaseToOverride);
if ($resultFetch && is_numeric($releaseToOverride)) {
$this->getConfig()->setReleaseId($releaseToOverride);
}
}
$excludes = array(
'.git',
'.svn',
'.mage',
'.gitignore',
'.gitkeep',
'nohup.out'
);
// Look for User Excludes
$userExcludes = $this->getConfig()->deployment('excludes', array());
// If we are working with releases // If we are working with releases
$deployToDirectory = $this->getConfig()->deployment('to'); $deployToDirectory = $this->getConfig()->deployment('to');
@ -95,7 +77,7 @@ class RsyncTask extends AbstractTask implements IsReleaseAware
$command = 'rsync -avz ' $command = 'rsync -avz '
. '--rsh="ssh ' . $this->getConfig()->getHostIdentityFileOption() . '-p' . $this->getConfig()->getHostPort() . '" ' . '--rsh="ssh ' . $this->getConfig()->getHostIdentityFileOption() . '-p' . $this->getConfig()->getHostPort() . '" '
. $this->excludes(array_merge($excludes, $userExcludes)) . ' ' . $this->excludes($excludes) . ' '
. $this->getConfig()->deployment('from') . ' ' . $this->getConfig()->deployment('from') . ' '
. $this->getConfig()->deployment('user') . '@' . $this->getConfig()->getHostName() . ':' . $deployToDirectory; . $this->getConfig()->deployment('user') . '@' . $this->getConfig()->getHostName() . ':' . $deployToDirectory;

27
Mage/Task/BuiltIn/Deployment/Strategy/TarGzTask.php

@ -10,7 +10,7 @@
namespace Mage\Task\BuiltIn\Deployment\Strategy; namespace Mage\Task\BuiltIn\Deployment\Strategy;
use Mage\Task\AbstractTask; use Mage\Task\BuiltIn\Deployment\Strategy\BaseStrategyTaskAbstract;
use Mage\Task\Releases\IsReleaseAware; use Mage\Task\Releases\IsReleaseAware;
/** /**
@ -18,7 +18,7 @@ use Mage\Task\Releases\IsReleaseAware;
* *
* @author Andrés Montañez <andres@andresmontanez.com> * @author Andrés Montañez <andres@andresmontanez.com>
*/ */
class TarGzTask extends AbstractTask implements IsReleaseAware class TarGzTask extends BaseStrategyTaskAbstract implements IsReleaseAware
{ {
/** /**
* (non-PHPdoc) * (non-PHPdoc)
@ -43,27 +43,9 @@ class TarGzTask extends AbstractTask implements IsReleaseAware
*/ */
public function run() public function run()
{ {
$overrideRelease = $this->getParameter('overrideRelease', false); $this->checkOverrideRelease();
if ($overrideRelease == true) { $excludes = $this->getExcludes();
$releaseToOverride = false;
$resultFetch = $this->runCommandRemote('ls -ld current | cut -d"/" -f2', $releaseToOverride);
if ($resultFetch && is_numeric($releaseToOverride)) {
$this->getConfig()->setReleaseId($releaseToOverride);
}
}
$excludes = array(
'.git',
'.svn',
'.mage',
'.gitignore',
'.gitkeep',
'nohup.out'
);
// Look for User Excludes
$userExcludes = $this->getConfig()->deployment('excludes', array());
// If we are working with releases // If we are working with releases
$deployToDirectory = $this->getConfig()->deployment('to'); $deployToDirectory = $this->getConfig()->deployment('to');
@ -79,7 +61,6 @@ class TarGzTask extends AbstractTask implements IsReleaseAware
// Create Tar Gz // Create Tar Gz
$localTarGz = tempnam(sys_get_temp_dir(), 'mage'); $localTarGz = tempnam(sys_get_temp_dir(), 'mage');
$remoteTarGz = basename($localTarGz); $remoteTarGz = basename($localTarGz);
$excludes = array_merge($excludes, $userExcludes);
$excludeCmd = ''; $excludeCmd = '';
foreach ($excludes as $excludeFile) { foreach ($excludes as $excludeFile) {
$excludeCmd .= ' --exclude=' . $excludeFile; $excludeCmd .= ' --exclude=' . $excludeFile;

2
docs/example-config/.mage/config/environment/staging.yml

@ -2,7 +2,7 @@
deployment: deployment:
user: root user: root
from: ./ from: ./
to: /var/www/ to: /var/vvv
scm: scm:
branch: master branch: master
releases: releases:

Loading…
Cancel
Save