|
|
@ -56,7 +56,7 @@ class EncryptTask extends AbstractTask |
|
|
|
* |
|
|
|
* |
|
|
|
* @var array |
|
|
|
* @var array |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
private $default = array (); |
|
|
|
private $default = array(); |
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
/** |
|
|
|
* Array of YAML Ioncube |
|
|
|
* Array of YAML Ioncube |
|
|
@ -64,7 +64,7 @@ class EncryptTask extends AbstractTask |
|
|
|
* |
|
|
|
* |
|
|
|
* @var array |
|
|
|
* @var array |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
private $yaml = array (); |
|
|
|
private $yaml = array(); |
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
/** |
|
|
|
* Array of file Ioncube |
|
|
|
* Array of file Ioncube |
|
|
@ -73,7 +73,7 @@ class EncryptTask extends AbstractTask |
|
|
|
* |
|
|
|
* |
|
|
|
* @var array |
|
|
|
* @var array |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
private $file = array (); |
|
|
|
private $file = array(); |
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
/** |
|
|
|
* Source directory as used by |
|
|
|
* Source directory as used by |
|
|
@ -106,7 +106,7 @@ class EncryptTask extends AbstractTask |
|
|
|
* |
|
|
|
* |
|
|
|
* @var array |
|
|
|
* @var array |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
private $mageConfig = array (); |
|
|
|
private $mageConfig = array(); |
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
/** |
|
|
|
* Final version of the IonCube |
|
|
|
* Final version of the IonCube |
|
|
@ -115,7 +115,7 @@ class EncryptTask extends AbstractTask |
|
|
|
* |
|
|
|
* |
|
|
|
* @var array |
|
|
|
* @var array |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
private $ionCubeConfig = array (); |
|
|
|
private $ionCubeConfig = array(); |
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
/** |
|
|
|
* Default encoder version to use |
|
|
|
* Default encoder version to use |
|
|
@ -171,7 +171,8 @@ class EncryptTask extends AbstractTask |
|
|
|
* |
|
|
|
* |
|
|
|
* @see \Mage\Task\AbstractTask::getName() |
|
|
|
* @see \Mage\Task\AbstractTask::getName() |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
public function getName() { |
|
|
|
public function getName() |
|
|
|
|
|
|
|
{ |
|
|
|
return $this->name; |
|
|
|
return $this->name; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -180,9 +181,10 @@ class EncryptTask extends AbstractTask |
|
|
|
* |
|
|
|
* |
|
|
|
* @see \Mage\Task\AbstractTask::init() |
|
|
|
* @see \Mage\Task\AbstractTask::init() |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
public function init() { |
|
|
|
public function init() |
|
|
|
|
|
|
|
{ |
|
|
|
// Set the default extensions to ignore |
|
|
|
// Set the default extensions to ignore |
|
|
|
$this->checkIgnoreExtens = array ( |
|
|
|
$this->checkIgnoreExtens = array( |
|
|
|
'jpg', |
|
|
|
'jpg', |
|
|
|
'jpeg', |
|
|
|
'jpeg', |
|
|
|
'png', |
|
|
|
'png', |
|
|
@ -196,7 +198,7 @@ class EncryptTask extends AbstractTask |
|
|
|
|
|
|
|
|
|
|
|
); |
|
|
|
); |
|
|
|
// Get any options specfic to this task |
|
|
|
// Get any options specfic to this task |
|
|
|
$this->mageConfig = $this->getConfig()->environmentConfig( 'ioncube' ); |
|
|
|
$this->mageConfig = $this->getConfig()->environmentConfig('ioncube'); |
|
|
|
/* |
|
|
|
/* |
|
|
|
* Get all our IonCube config options |
|
|
|
* Get all our IonCube config options |
|
|
|
*/ |
|
|
|
*/ |
|
|
@ -204,12 +206,12 @@ class EncryptTask extends AbstractTask |
|
|
|
/* |
|
|
|
/* |
|
|
|
* get the source code location |
|
|
|
* get the source code location |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
$this->source = $this->getConfig ()->deployment ( 'from' ); |
|
|
|
$this->source = $this->getConfig()->deployment('from'); |
|
|
|
/* |
|
|
|
/* |
|
|
|
* remove trailing slash if present |
|
|
|
* remove trailing slash if present |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
if (substr ( $this->source, - 1 ) == DIRECTORY_SEPARATOR) { |
|
|
|
if (substr($this->source, -1) == DIRECTORY_SEPARATOR) { |
|
|
|
$this->source = substr ( $this->source, 0, - 1 ); |
|
|
|
$this->source = substr($this->source, 0, -1); |
|
|
|
} |
|
|
|
} |
|
|
|
/* |
|
|
|
/* |
|
|
|
* Set the name of the folder that the un-encrypted |
|
|
|
* Set the name of the folder that the un-encrypted |
|
|
@ -224,7 +226,7 @@ class EncryptTask extends AbstractTask |
|
|
|
* Check if we have been given an encoder script |
|
|
|
* Check if we have been given an encoder script |
|
|
|
* If not then we will just use the default |
|
|
|
* If not then we will just use the default |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
if (isset ( $this->mageConfig ['encoder'] )) { |
|
|
|
if (isset ($this->mageConfig ['encoder'])) { |
|
|
|
$this->encoder = $this->mageConfig ['encoder']; |
|
|
|
$this->encoder = $this->mageConfig ['encoder']; |
|
|
|
} |
|
|
|
} |
|
|
|
/* |
|
|
|
/* |
|
|
@ -232,15 +234,15 @@ class EncryptTask extends AbstractTask |
|
|
|
* supplied, this defines how the 3 differant |
|
|
|
* supplied, this defines how the 3 differant |
|
|
|
* config files will be merged together. |
|
|
|
* config files will be merged together. |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
if (isset ( $this->mageConfig ['override'] )) { |
|
|
|
if (isset ($this->mageConfig ['override'])) { |
|
|
|
$this->ionOverRide = $this->mageConfig ['override']; |
|
|
|
$this->ionOverRide = $this->mageConfig ['override']; |
|
|
|
} |
|
|
|
} |
|
|
|
/* |
|
|
|
/* |
|
|
|
* Check if we have been asked to |
|
|
|
* Check if we have been asked to |
|
|
|
* confirm all encodings |
|
|
|
* confirm all encodings |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
if (isset ( $this->mageConfig ['checkencoding'])) { |
|
|
|
if (isset ($this->mageConfig ['checkencoding'])) { |
|
|
|
$this->checkEncoding=true; |
|
|
|
$this->checkEncoding = true; |
|
|
|
} |
|
|
|
} |
|
|
|
/* |
|
|
|
/* |
|
|
|
* Check if we have been passed any extra |
|
|
|
* Check if we have been passed any extra |
|
|
@ -248,8 +250,8 @@ class EncryptTask extends AbstractTask |
|
|
|
* encrypt/encode file check |
|
|
|
* encrypt/encode file check |
|
|
|
* |
|
|
|
* |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
if (isset ( $this->mageConfig ['checkignoreextens'])) { |
|
|
|
if (isset ($this->mageConfig ['checkignoreextens'])) { |
|
|
|
$this->checkIgnoreExtens=array_merge($this->ignoreExtens, $this->mageConfig['ignoreextens']); |
|
|
|
$this->checkIgnoreExtens = array_merge($this->ignoreExtens, $this->mageConfig['ignoreextens']); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/* |
|
|
|
/* |
|
|
@ -258,15 +260,15 @@ class EncryptTask extends AbstractTask |
|
|
|
* encrypt/encode file check |
|
|
|
* encrypt/encode file check |
|
|
|
* |
|
|
|
* |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
if (isset ( $this->mageConfig ['checkignorepaths'])) { |
|
|
|
if (isset ($this->mageConfig ['checkignorepaths'])) { |
|
|
|
$this->checkIgnorePaths=array_merge($this->checkIgnorePaths, $this->mageConfig['checkignorepaths']); |
|
|
|
$this->checkIgnorePaths = array_merge($this->checkIgnorePaths, $this->mageConfig['checkignorepaths']); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* |
|
|
|
/* |
|
|
|
* now merge all the config options together |
|
|
|
* now merge all the config options together |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
$this->ionCubeConfig = $this->mergeConfigFiles (); |
|
|
|
$this->ionCubeConfig = $this->mergeConfigFiles(); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
/** |
|
|
@ -283,29 +285,29 @@ class EncryptTask extends AbstractTask |
|
|
|
/* |
|
|
|
/* |
|
|
|
* Get a set of default IonCube options |
|
|
|
* Get a set of default IonCube options |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
$this->default = $this->getOptionsDefault (); |
|
|
|
$this->default = $this->getOptionsDefault(); |
|
|
|
/* |
|
|
|
/* |
|
|
|
* Check if there is a 'project' section, |
|
|
|
* Check if there is a 'project' section, |
|
|
|
* if so then get the options from there |
|
|
|
* if so then get the options from there |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
if (isset ( $this->mageConfig ['project'] )) { |
|
|
|
if (isset ($this->mageConfig ['project'])) { |
|
|
|
$this->yaml = $this->getOptionsFromYaml ( $this->mageConfig ['project'] ); |
|
|
|
$this->yaml = $this->getOptionsFromYaml($this->mageConfig ['project']); |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
$this->yaml = array ( |
|
|
|
$this->yaml = array( |
|
|
|
's' => array (), |
|
|
|
's' => array(), |
|
|
|
'p' => array () |
|
|
|
'p' => array() |
|
|
|
); |
|
|
|
); |
|
|
|
} |
|
|
|
} |
|
|
|
/* |
|
|
|
/* |
|
|
|
* Check if a seperate projectfile has been specified, and if so |
|
|
|
* Check if a seperate projectfile has been specified, and if so |
|
|
|
* then read the options from there. |
|
|
|
* then read the options from there. |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
if (isset ( $this->mageConfig ['projectfile'] )) { |
|
|
|
if (isset ($this->mageConfig ['projectfile'])) { |
|
|
|
$this->file = $this->getOptionsFromFile ( $this->mageConfig ['projectfile'] ); |
|
|
|
$this->file = $this->getOptionsFromFile($this->mageConfig ['projectfile']); |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
$this->file = array ( |
|
|
|
$this->file = array( |
|
|
|
's' => array (), |
|
|
|
's' => array(), |
|
|
|
'p' => array () |
|
|
|
'p' => array() |
|
|
|
); |
|
|
|
); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
@ -324,20 +326,21 @@ class EncryptTask extends AbstractTask |
|
|
|
* @return bool |
|
|
|
* @return bool |
|
|
|
* @throws \Mage\Task\ErrorWithMessageException |
|
|
|
* @throws \Mage\Task\ErrorWithMessageException |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
public function run() { |
|
|
|
public function run() |
|
|
|
$this->switchSrcToTmp (); |
|
|
|
{ |
|
|
|
$this->writeProjectFile (); |
|
|
|
$this->switchSrcToTmp(); |
|
|
|
$result = $this->runIonCube (); |
|
|
|
$this->writeProjectFile(); |
|
|
|
Console::output("Encoding result :".($result ? '<green>OK</green>' : '<red>Bad!</red>')."\n", 0, 2); |
|
|
|
$result = $this->runIonCube(); |
|
|
|
|
|
|
|
Console::output("Encoding result :" . ($result ? '<green>OK</green>' : '<red>Bad!</red>') . "\n", 0, 2); |
|
|
|
if (!$result) { |
|
|
|
if (!$result) { |
|
|
|
$this->deleteTmpFiles (); |
|
|
|
$this->deleteTmpFiles(); |
|
|
|
throw new ErrorWithMessageException('Ioncube failed to encode your project :'.$result); |
|
|
|
throw new ErrorWithMessageException('Ioncube failed to encode your project :' . $result); |
|
|
|
} |
|
|
|
} |
|
|
|
if (($this->checkEncoding) && (!$this->checkEncoding())) { |
|
|
|
if (($this->checkEncoding) && (!$this->checkEncoding())) { |
|
|
|
$this->deleteTmpFiles(); |
|
|
|
$this->deleteTmpFiles(); |
|
|
|
throw new ErrorWithMessageException('Operation canceled by user.'); |
|
|
|
throw new ErrorWithMessageException('Operation canceled by user.'); |
|
|
|
} |
|
|
|
} |
|
|
|
$this->deleteTmpFiles (); |
|
|
|
$this->deleteTmpFiles(); |
|
|
|
return $result; |
|
|
|
return $result; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -351,33 +354,34 @@ class EncryptTask extends AbstractTask |
|
|
|
* |
|
|
|
* |
|
|
|
* @return bool |
|
|
|
* @return bool |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
private function checkEncoding() { |
|
|
|
private function checkEncoding() |
|
|
|
|
|
|
|
{ |
|
|
|
$src = $this->source; |
|
|
|
$src = $this->source; |
|
|
|
// $ask holds flag to indicate we need to prompt the end user |
|
|
|
// $ask holds flag to indicate we need to prompt the end user |
|
|
|
$ask = false; |
|
|
|
$ask = false; |
|
|
|
// scan through the directory |
|
|
|
// scan through the directory |
|
|
|
$rit = new \RecursiveDirectoryIterator ( $src ); |
|
|
|
$rit = new \RecursiveDirectoryIterator ($src); |
|
|
|
foreach ( new \RecursiveIteratorIterator ( $rit ) as $filename => $cur ) { |
|
|
|
foreach (new \RecursiveIteratorIterator ($rit) as $filename => $cur) { |
|
|
|
// get the 'base dir' for the project, eg. relative to the temp folder |
|
|
|
// get the 'base dir' for the project, eg. relative to the temp folder |
|
|
|
$srcFileName = (str_replace ( $this->source, '', $filename )); |
|
|
|
$srcFileName = (str_replace($this->source, '', $filename)); |
|
|
|
/* |
|
|
|
/* |
|
|
|
* Scan through the ignor directorys array |
|
|
|
* Scan through the ignor directorys array |
|
|
|
* and if it matches the current path/filename |
|
|
|
* and if it matches the current path/filename |
|
|
|
* then mark the file to be skipped from testing |
|
|
|
* then mark the file to be skipped from testing |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
$skip = false; |
|
|
|
$skip = false; |
|
|
|
foreach ( $this->checkIgnorePaths as $path ) { |
|
|
|
foreach ($this->checkIgnorePaths as $path) { |
|
|
|
if (fnmatch ( $path, $srcFileName )) { |
|
|
|
if (fnmatch($path, $srcFileName)) { |
|
|
|
$skip = true; |
|
|
|
$skip = true; |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
// check if we should test this file |
|
|
|
// check if we should test this file |
|
|
|
if (! $skip) { |
|
|
|
if (!$skip) { |
|
|
|
// get the file exten for this file and compare to our fileexten exclude array |
|
|
|
// get the file exten for this file and compare to our fileexten exclude array |
|
|
|
$exten = pathinfo ( $filename, PATHINFO_EXTENSION ); |
|
|
|
$exten = pathinfo($filename, PATHINFO_EXTENSION); |
|
|
|
if (! in_array ( strtolower ( $exten ), $this->checkIgnoreExtens )) { |
|
|
|
if (!in_array(strtolower($exten), $this->checkIgnoreExtens)) { |
|
|
|
// ok, this extension needs to be checked |
|
|
|
// ok, this extension needs to be checked |
|
|
|
if ($this->checkFileCoding ( $filename )) { |
|
|
|
if ($this->checkFileCoding($filename)) { |
|
|
|
// file was encrypted/encoded |
|
|
|
// file was encrypted/encoded |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
// file was not encrypted/encoded |
|
|
|
// file was not encrypted/encoded |
|
|
@ -390,7 +394,7 @@ class EncryptTask extends AbstractTask |
|
|
|
if ($ask) { |
|
|
|
if ($ask) { |
|
|
|
// ok lets ask the user if they want to procede |
|
|
|
// ok lets ask the user if they want to procede |
|
|
|
Console::output("\n\nDo you wish to procede (y/N):", 0, 0); |
|
|
|
Console::output("\n\nDo you wish to procede (y/N):", 0, 0); |
|
|
|
if (! $this->promptYn ()) { |
|
|
|
if (!$this->promptYn()) { |
|
|
|
return false; |
|
|
|
return false; |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
@ -407,10 +411,11 @@ class EncryptTask extends AbstractTask |
|
|
|
* |
|
|
|
* |
|
|
|
* @return bool True if 'y' pressed |
|
|
|
* @return bool True if 'y' pressed |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
private function promptYn() { |
|
|
|
private function promptYn() |
|
|
|
$handle = fopen ("php://stdin","r"); |
|
|
|
{ |
|
|
|
|
|
|
|
$handle = fopen("php://stdin", "r"); |
|
|
|
$line = strtolower(fgets($handle)); |
|
|
|
$line = strtolower(fgets($handle)); |
|
|
|
if(trim($line) != 'y'){ |
|
|
|
if (trim($line) != 'y') { |
|
|
|
return false; |
|
|
|
return false; |
|
|
|
} |
|
|
|
} |
|
|
|
return true; |
|
|
|
return true; |
|
|
@ -428,23 +433,24 @@ class EncryptTask extends AbstractTask |
|
|
|
* |
|
|
|
* |
|
|
|
* @return boolean True if file was encoded/encrypted |
|
|
|
* @return boolean True if file was encoded/encrypted |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
private function checkFileCoding($filename) { |
|
|
|
private function checkFileCoding($filename) |
|
|
|
|
|
|
|
{ |
|
|
|
// check to see if this is an encrypted file |
|
|
|
// check to see if this is an encrypted file |
|
|
|
$ioncube = ioncube_read_file($filename, $ioncubeType); |
|
|
|
$ioncube = ioncube_read_file($filename, $ioncubeType); |
|
|
|
if (is_int ( $ioncube )) { |
|
|
|
if (is_int($ioncube)) { |
|
|
|
// we got an error from ioncube, so its encrypted |
|
|
|
// we got an error from ioncube, so its encrypted |
|
|
|
return true; |
|
|
|
return true; |
|
|
|
} |
|
|
|
} |
|
|
|
// read first line of file |
|
|
|
// read first line of file |
|
|
|
$f = fopen ( $filename, 'r' ); |
|
|
|
$f = fopen($filename, 'r'); |
|
|
|
$line = trim ( fgets ( $f, 32 ) ); |
|
|
|
$line = trim(fgets($f, 32)); |
|
|
|
fclose ( $f ); |
|
|
|
fclose($f); |
|
|
|
// if first line is longer than 30, then this isnt a php file |
|
|
|
// if first line is longer than 30, then this isnt a php file |
|
|
|
if (strlen ( $line ) > 30) { |
|
|
|
if (strlen($line) > 30) { |
|
|
|
return false; |
|
|
|
return false; |
|
|
|
} |
|
|
|
} |
|
|
|
// if first line starts '<?php //0' then we can be pretty certain its encoded
|
|
|
|
// if first line starts '<?php //0' then we can be pretty certain its encoded
|
|
|
|
if (substr ( $line, 0, 9 ) == '<?php //0') {
|
|
|
|
if (substr($line, 0, 9) == '<?php //0') {
|
|
|
|
return true; |
|
|
|
return true; |
|
|
|
} |
|
|
|
} |
|
|
|
// otherwise its most likley un-encrypted/encoded |
|
|
|
// otherwise its most likley un-encrypted/encoded |
|
|
@ -461,17 +467,18 @@ class EncryptTask extends AbstractTask |
|
|
|
* |
|
|
|
* |
|
|
|
* @return void |
|
|
|
* @return void |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
private function deleteTmpFiles() { |
|
|
|
private function deleteTmpFiles() |
|
|
|
if (isset ( $this->mageConfig ['keeptemp'] )) { |
|
|
|
{ |
|
|
|
|
|
|
|
if (isset ($this->mageConfig ['keeptemp'])) { |
|
|
|
return; |
|
|
|
return; |
|
|
|
} |
|
|
|
} |
|
|
|
Console::log('Deleting tempory files :', 1); |
|
|
|
Console::log('Deleting tempory files :', 1); |
|
|
|
$ret1 = Console::executeCommand ( 'rm -Rf ' . $this->ionSource, $out1 ); |
|
|
|
$ret1 = Console::executeCommand('rm -Rf ' . $this->ionSource, $out1); |
|
|
|
$ret2 = Console::executeCommand ( 'rm ' . $this->projectFile, $out2 ); |
|
|
|
$ret2 = Console::executeCommand('rm ' . $this->projectFile, $out2); |
|
|
|
if ($ret1 && $ret2) { |
|
|
|
if ($ret1 && $ret2) { |
|
|
|
return; |
|
|
|
return; |
|
|
|
} |
|
|
|
} |
|
|
|
throw new ErrorWithMessageException ( 'Error deleting temp files :' . $out1 . ' : ' . $out2, 40 ); |
|
|
|
throw new ErrorWithMessageException ('Error deleting temp files :' . $out1 . ' : ' . $out2, 40); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
/** |
|
|
@ -480,9 +487,10 @@ class EncryptTask extends AbstractTask |
|
|
|
* |
|
|
|
* |
|
|
|
* @return bool |
|
|
|
* @return bool |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
private function runIonCube() { |
|
|
|
private function runIonCube() |
|
|
|
$cli = $this->encoder . ' --project-file ' . $this->projectFile . ' ' . $this->ionSource . DIRECTORY_SEPARATOR.'*'; |
|
|
|
{ |
|
|
|
$ret = Console::executeCommand ( $cli, $out ); |
|
|
|
$cli = $this->encoder . ' --project-file ' . $this->projectFile . ' ' . $this->ionSource . DIRECTORY_SEPARATOR . '*'; |
|
|
|
|
|
|
|
$ret = Console::executeCommand($cli, $out); |
|
|
|
return $ret; |
|
|
|
return $ret; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -495,37 +503,38 @@ class EncryptTask extends AbstractTask |
|
|
|
* |
|
|
|
* |
|
|
|
* @return void |
|
|
|
* @return void |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
private function writeProjectFile() { |
|
|
|
private function writeProjectFile() |
|
|
|
|
|
|
|
{ |
|
|
|
// array used to build config file into |
|
|
|
// array used to build config file into |
|
|
|
$out = array (); |
|
|
|
$out = array(); |
|
|
|
// set the project destination |
|
|
|
// set the project destination |
|
|
|
$out [] = '--into ' . $this->source . PHP_EOL; |
|
|
|
$out [] = '--into ' . $this->source . PHP_EOL; |
|
|
|
// output the switches |
|
|
|
// output the switches |
|
|
|
foreach ( $this->ionCubeConfig ['s'] as $key => $value ) { |
|
|
|
foreach ($this->ionCubeConfig ['s'] as $key => $value) { |
|
|
|
if ($value) { |
|
|
|
if ($value) { |
|
|
|
// switch was set to true, so output it |
|
|
|
// switch was set to true, so output it |
|
|
|
$out [] = '--' . $key . PHP_EOL; |
|
|
|
$out [] = '--' . $key . PHP_EOL; |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
// output the options |
|
|
|
// output the options |
|
|
|
foreach ( $this->ionCubeConfig ['p'] as $key => $value ) { |
|
|
|
foreach ($this->ionCubeConfig ['p'] as $key => $value) { |
|
|
|
// check if we have an array of values |
|
|
|
// check if we have an array of values |
|
|
|
if (is_array ( $value )) { |
|
|
|
if (is_array($value)) { |
|
|
|
foreach ( $value as $entry ) { |
|
|
|
foreach ($value as $entry) { |
|
|
|
$out [] = '--' . $key . ' "' . $entry . '"' . PHP_EOL; |
|
|
|
$out [] = '--' . $key . ' "' . $entry . '"' . PHP_EOL; |
|
|
|
} |
|
|
|
} |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
// ok just a normal single option |
|
|
|
// ok just a normal single option |
|
|
|
if (strlen ( $value ) > 0) { |
|
|
|
if (strlen($value) > 0) { |
|
|
|
$out [] = '--' . $key . ' "' . $value . '"' . PHP_EOL; |
|
|
|
$out [] = '--' . $key . ' "' . $value . '"' . PHP_EOL; |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
$ret = file_put_contents ( $this->projectFile, $out ); |
|
|
|
$ret = file_put_contents($this->projectFile, $out); |
|
|
|
if (! $ret) { |
|
|
|
if (!$ret) { |
|
|
|
// something went wrong |
|
|
|
// something went wrong |
|
|
|
$this->deleteTmpFiles (); |
|
|
|
$this->deleteTmpFiles(); |
|
|
|
throw new ErrorWithMessageException ( 'Unable to create project file.', 20 ); |
|
|
|
throw new ErrorWithMessageException ('Unable to create project file.', 20); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -535,7 +544,8 @@ class EncryptTask extends AbstractTask |
|
|
|
* |
|
|
|
* |
|
|
|
* @return array Final config array |
|
|
|
* @return array Final config array |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
private function mergeConfigFiles() { |
|
|
|
private function mergeConfigFiles() |
|
|
|
|
|
|
|
{ |
|
|
|
/* |
|
|
|
/* |
|
|
|
* Options are the order the arrays are in |
|
|
|
* Options are the order the arrays are in |
|
|
|
* F - Project File |
|
|
|
* F - Project File |
|
|
@ -546,24 +556,24 @@ class EncryptTask extends AbstractTask |
|
|
|
* @todo I'm sure this could be combined into a loop to make it easier and shorter |
|
|
|
* @todo I'm sure this could be combined into a loop to make it easier and shorter |
|
|
|
* |
|
|
|
* |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
$s = array (); |
|
|
|
$s = array(); |
|
|
|
$p = array (); |
|
|
|
$p = array(); |
|
|
|
switch (strtolower ( $this->ionOverRide )) { |
|
|
|
switch (strtolower($this->ionOverRide)) { |
|
|
|
case 'fyd' : |
|
|
|
case 'fyd' : |
|
|
|
// FILE / YAML / DEFAULT |
|
|
|
// FILE / YAML / DEFAULT |
|
|
|
$s = array_merge ( $this->file ['s'], $this->yaml ['s'], $this->default ['s'] ); |
|
|
|
$s = array_merge($this->file ['s'], $this->yaml ['s'], $this->default ['s']); |
|
|
|
$p = array_merge ( $this->file ['p'], $this->yaml ['p'], $this->default ['p'] ); |
|
|
|
$p = array_merge($this->file ['p'], $this->yaml ['p'], $this->default ['p']); |
|
|
|
break; |
|
|
|
break; |
|
|
|
|
|
|
|
|
|
|
|
case 'yfd' : |
|
|
|
case 'yfd' : |
|
|
|
// YAML / FILE / DEFAULT |
|
|
|
// YAML / FILE / DEFAULT |
|
|
|
$s = array_merge ( $this->yaml ['s'], $this->file ['s'], $this->default ['s'] ); |
|
|
|
$s = array_merge($this->yaml ['s'], $this->file ['s'], $this->default ['s']); |
|
|
|
$p = array_merge ( $this->yaml ['p'], $this->file ['p'], $this->default ['p'] ); |
|
|
|
$p = array_merge($this->yaml ['p'], $this->file ['p'], $this->default ['p']); |
|
|
|
break; |
|
|
|
break; |
|
|
|
case 'dyf' : |
|
|
|
case 'dyf' : |
|
|
|
// DEFAULT / YAML / FILE |
|
|
|
// DEFAULT / YAML / FILE |
|
|
|
$s = array_merge ( $this->default ['s'], $this->yaml ['s'], $this->file ['s'] ); |
|
|
|
$s = array_merge($this->default ['s'], $this->yaml ['s'], $this->file ['s']); |
|
|
|
$p = array_merge ( $this->default ['p'], $this->yaml ['p'], $this->file ['p'] ); |
|
|
|
$p = array_merge($this->default ['p'], $this->yaml ['p'], $this->file ['p']); |
|
|
|
break; |
|
|
|
break; |
|
|
|
case 'd' : |
|
|
|
case 'd' : |
|
|
|
default : |
|
|
|
default : |
|
|
@ -572,7 +582,7 @@ class EncryptTask extends AbstractTask |
|
|
|
$p = $this->default ['p']; |
|
|
|
$p = $this->default ['p']; |
|
|
|
break; |
|
|
|
break; |
|
|
|
} |
|
|
|
} |
|
|
|
return array ( |
|
|
|
return array( |
|
|
|
's' => $s, |
|
|
|
's' => $s, |
|
|
|
'p' => $p |
|
|
|
'p' => $p |
|
|
|
); |
|
|
|
); |
|
|
@ -591,14 +601,15 @@ class EncryptTask extends AbstractTask |
|
|
|
* |
|
|
|
* |
|
|
|
* @return bool |
|
|
|
* @return bool |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
private function switchSrcToTmp() { |
|
|
|
private function switchSrcToTmp() |
|
|
|
$ret = Console::executeCommand ( 'mv ' . $this->source . ' ' . $this->ionSource, $out ); |
|
|
|
{ |
|
|
|
if (! $ret) { |
|
|
|
$ret = Console::executeCommand('mv ' . $this->source . ' ' . $this->ionSource, $out); |
|
|
|
throw new ErrorWithMessageException ( 'Cant create tmp dir :' . $out, $ret ); |
|
|
|
if (!$ret) { |
|
|
|
|
|
|
|
throw new ErrorWithMessageException ('Cant create tmp dir :' . $out, $ret); |
|
|
|
} |
|
|
|
} |
|
|
|
$ret = Console::executeCommand ( 'mkdir -p ' . $this->source, $out ); |
|
|
|
$ret = Console::executeCommand('mkdir -p ' . $this->source, $out); |
|
|
|
if (! $ret) { |
|
|
|
if (!$ret) { |
|
|
|
throw new ErrorWithMessageException ( 'Cant re-create dir :' . $out, $ret ); |
|
|
|
throw new ErrorWithMessageException ('Cant re-create dir :' . $out, $ret); |
|
|
|
} |
|
|
|
} |
|
|
|
return true; |
|
|
|
return true; |
|
|
|
} |
|
|
|
} |
|
|
@ -611,18 +622,19 @@ class EncryptTask extends AbstractTask |
|
|
|
* |
|
|
|
* |
|
|
|
* return array |
|
|
|
* return array |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
private function getOptionsFromYaml($options) { |
|
|
|
private function getOptionsFromYaml($options) |
|
|
|
$s = array (); |
|
|
|
{ |
|
|
|
$p = array (); |
|
|
|
$s = array(); |
|
|
|
foreach ( $options as $key => $value ) { |
|
|
|
$p = array(); |
|
|
|
if (array_key_exists ( $key, $this->default ['s'] )) { |
|
|
|
foreach ($options as $key => $value) { |
|
|
|
|
|
|
|
if (array_key_exists($key, $this->default ['s'])) { |
|
|
|
$s [$key] = true; |
|
|
|
$s [$key] = true; |
|
|
|
} |
|
|
|
} |
|
|
|
if (array_key_exists ( $key, $this->default ['p'] )) { |
|
|
|
if (array_key_exists($key, $this->default ['p'])) { |
|
|
|
$p [$key] = $value; |
|
|
|
$p [$key] = $value; |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
return array ( |
|
|
|
return array( |
|
|
|
's' => $s, |
|
|
|
's' => $s, |
|
|
|
'p' => $p |
|
|
|
'p' => $p |
|
|
|
); |
|
|
|
); |
|
|
@ -635,48 +647,49 @@ class EncryptTask extends AbstractTask |
|
|
|
* @param $fileName |
|
|
|
* @param $fileName |
|
|
|
* @return array |
|
|
|
* @return array |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
private function getOptionsFromFile($fileName) { |
|
|
|
private function getOptionsFromFile($fileName) |
|
|
|
$s = array (); |
|
|
|
{ |
|
|
|
$p = array (); |
|
|
|
$s = array(); |
|
|
|
$fileContents = file_get_contents ( $fileName ); |
|
|
|
$p = array(); |
|
|
|
|
|
|
|
$fileContents = file_get_contents($fileName); |
|
|
|
/* |
|
|
|
/* |
|
|
|
* split the config file on every occurance of '--' at start of a line |
|
|
|
* split the config file on every occurance of '--' at start of a line |
|
|
|
* Adds a PHP_EOL at the start, so we can catch the first '--' |
|
|
|
* Adds a PHP_EOL at the start, so we can catch the first '--' |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
$entrys = explode ( PHP_EOL . '--', PHP_EOL . $fileContents ); |
|
|
|
$entrys = explode(PHP_EOL . '--', PHP_EOL . $fileContents); |
|
|
|
foreach ( $entrys as $line ) { |
|
|
|
foreach ($entrys as $line) { |
|
|
|
$line = trim ( $line ); |
|
|
|
$line = trim($line); |
|
|
|
if ($line != '') { |
|
|
|
if ($line != '') { |
|
|
|
/* |
|
|
|
/* |
|
|
|
* get position of first space |
|
|
|
* get position of first space |
|
|
|
* so we can split the options out |
|
|
|
* so we can split the options out |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
$str = strpos ( $line, ' ' ); |
|
|
|
$str = strpos($line, ' '); |
|
|
|
if ($str === false) { |
|
|
|
if ($str === false) { |
|
|
|
/* |
|
|
|
/* |
|
|
|
* Ok, no spaces found, so take this as a single line |
|
|
|
* Ok, no spaces found, so take this as a single line |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
$str = strlen ( $line ); |
|
|
|
$str = strlen($line); |
|
|
|
} |
|
|
|
} |
|
|
|
$key = substr ( $line, $str ); |
|
|
|
$key = substr($line, $str); |
|
|
|
$value = substr ( $line, $str + 1 ); |
|
|
|
$value = substr($line, $str + 1); |
|
|
|
if ((array_key_exists ( $key, $this->default ['s'] ))) { |
|
|
|
if ((array_key_exists($key, $this->default ['s']))) { |
|
|
|
/* |
|
|
|
/* |
|
|
|
* ok this key appears in the switch config |
|
|
|
* ok this key appears in the switch config |
|
|
|
* so store it as a switch |
|
|
|
* so store it as a switch |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
$s [$key] = true; |
|
|
|
$s [$key] = true; |
|
|
|
} |
|
|
|
} |
|
|
|
if ((array_key_exists ( $key, $this->default ['p'] ))) { |
|
|
|
if ((array_key_exists($key, $this->default ['p']))) { |
|
|
|
/* |
|
|
|
/* |
|
|
|
* Ok this key exists in the parameter section, |
|
|
|
* Ok this key exists in the parameter section, |
|
|
|
* So store it allong with its value |
|
|
|
* So store it allong with its value |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
$p [$key] = $this->splitParam ( $value ); |
|
|
|
$p [$key] = $this->splitParam($value); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
return array ( |
|
|
|
return array( |
|
|
|
's' => $s, |
|
|
|
's' => $s, |
|
|
|
'p' => $p |
|
|
|
'p' => $p |
|
|
|
); |
|
|
|
); |
|
|
@ -693,13 +706,14 @@ class EncryptTask extends AbstractTask |
|
|
|
* |
|
|
|
* |
|
|
|
* @return mixed |
|
|
|
* @return mixed |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
private function splitParam($string) { |
|
|
|
private function splitParam($string) |
|
|
|
$split = explode ( PHP_EOL, $string ); |
|
|
|
{ |
|
|
|
|
|
|
|
$split = explode(PHP_EOL, $string); |
|
|
|
if ($split === false) { |
|
|
|
if ($split === false) { |
|
|
|
// nothing found, so return a blank string |
|
|
|
// nothing found, so return a blank string |
|
|
|
return ''; |
|
|
|
return ''; |
|
|
|
} |
|
|
|
} |
|
|
|
if (count ( $split ) == 1) { |
|
|
|
if (count($split) == 1) { |
|
|
|
return $split [0]; |
|
|
|
return $split [0]; |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
return $split; |
|
|
|
return $split; |
|
|
@ -715,9 +729,10 @@ class EncryptTask extends AbstractTask |
|
|
|
* |
|
|
|
* |
|
|
|
* @return array |
|
|
|
* @return array |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
private function getOptionsDefault() { |
|
|
|
private function getOptionsDefault() |
|
|
|
$s = array (); |
|
|
|
{ |
|
|
|
$p = array (); |
|
|
|
$s = array(); |
|
|
|
|
|
|
|
$p = array(); |
|
|
|
// Set the switches |
|
|
|
// Set the switches |
|
|
|
$s ['allow-encoding-into-source'] = false; |
|
|
|
$s ['allow-encoding-into-source'] = false; |
|
|
|
|
|
|
|
|
|
|
@ -751,9 +766,9 @@ class EncryptTask extends AbstractTask |
|
|
|
|
|
|
|
|
|
|
|
// Now set the params |
|
|
|
// Now set the params |
|
|
|
$p ['encrypt'] [] = '*.tpl.html'; |
|
|
|
$p ['encrypt'] [] = '*.tpl.html'; |
|
|
|
$p ['encode'] = array (); |
|
|
|
$p ['encode'] = array(); |
|
|
|
$p ['copy'] = array (); |
|
|
|
$p ['copy'] = array(); |
|
|
|
$p ['ignore'] = array ( |
|
|
|
$p ['ignore'] = array( |
|
|
|
'.git', |
|
|
|
'.git', |
|
|
|
'.svn', |
|
|
|
'.svn', |
|
|
|
getcwd() . '/.mage', |
|
|
|
getcwd() . '/.mage', |
|
|
@ -761,7 +776,7 @@ class EncryptTask extends AbstractTask |
|
|
|
'.gitkeep', |
|
|
|
'.gitkeep', |
|
|
|
'nohup.out' |
|
|
|
'nohup.out' |
|
|
|
); |
|
|
|
); |
|
|
|
$p ['keep'] = array (); |
|
|
|
$p ['keep'] = array(); |
|
|
|
$p ['obfuscate'] = ''; |
|
|
|
$p ['obfuscate'] = ''; |
|
|
|
$p ['obfuscation-key'] = ''; |
|
|
|
$p ['obfuscation-key'] = ''; |
|
|
|
$p ['obfuscation-exclusion-file'] = ''; |
|
|
|
$p ['obfuscation-exclusion-file'] = ''; |
|
|
@ -773,23 +788,23 @@ class EncryptTask extends AbstractTask |
|
|
|
$p ['license-check'] = ''; |
|
|
|
$p ['license-check'] = ''; |
|
|
|
$p ['apply-file-user'] = ''; |
|
|
|
$p ['apply-file-user'] = ''; |
|
|
|
$p ['apply-file-group'] = ''; |
|
|
|
$p ['apply-file-group'] = ''; |
|
|
|
$p ['register-autoglobal'] = array (); |
|
|
|
$p ['register-autoglobal'] = array(); |
|
|
|
$p ['message-if-no-loader'] = ''; |
|
|
|
$p ['message-if-no-loader'] = ''; |
|
|
|
$p ['action-if-no-loader'] = ''; |
|
|
|
$p ['action-if-no-loader'] = ''; |
|
|
|
$p ['loader-path'] = ''; |
|
|
|
$p ['loader-path'] = ''; |
|
|
|
$p ['preamble-file'] = ''; |
|
|
|
$p ['preamble-file'] = ''; |
|
|
|
$p ['add-comment'] = array (); |
|
|
|
$p ['add-comment'] = array(); |
|
|
|
$p ['add-comments'] = ''; |
|
|
|
$p ['add-comments'] = ''; |
|
|
|
$p ['loader-event'] = array (); |
|
|
|
$p ['loader-event'] = array(); |
|
|
|
$p ['callback-file'] = ''; |
|
|
|
$p ['callback-file'] = ''; |
|
|
|
$p ['property'] = ''; |
|
|
|
$p ['property'] = ''; |
|
|
|
$p ['propertys'] = ''; |
|
|
|
$p ['propertys'] = ''; |
|
|
|
$p ['include-if-property'] = array (); |
|
|
|
$p ['include-if-property'] = array(); |
|
|
|
$p ['optimise'] = 'max'; |
|
|
|
$p ['optimise'] = 'max'; |
|
|
|
$p ['shell-script-line'] = ''; |
|
|
|
$p ['shell-script-line'] = ''; |
|
|
|
$p ['min-loader-version'] = ''; |
|
|
|
$p ['min-loader-version'] = ''; |
|
|
|
|
|
|
|
|
|
|
|
return array ( |
|
|
|
return array( |
|
|
|
's' => $s, |
|
|
|
's' => $s, |
|
|
|
'p' => $p |
|
|
|
'p' => $p |
|
|
|
); |
|
|
|
); |
|
|
|