Source of file Task.php
Size: 9,083 Bytes - Last Modified: 2020-07-03T12:08:09+00:00
/var/www/docs.ssmods.com/process/src/src/Tasks/Task.php
| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299 | <?php/** * mu stands for Module Object */namespace Sunnysideup\UpgradeToSilverstripe4\Tasks; use Sunnysideup\UpgradeToSilverstripe4\ModuleUpgrader; use Sunnysideup\UpgradeToSilverstripe4\Tasks\Helpers\Git; abstract class Task {/**      * Are we running in debug mode?     * @var bool     */protected $debug = false; /**      * set a specific task name if needed     * @var string     */protected $taskName = ''; protected $taskStep = 's99'; /**      * Array of params that define this task, holds information such as its taskName etc.     * @var mixed     */protected $params = []; /**      * @var ModuleUpgrader|null the 'Manager' of all the modules responsible for holding Meta data and runtime     * specific runtime arguments.     */protected $mu = null; /**      * What to write in the commit message after the task is run, only useful if hasCommitAndPush() returns true     * @var string message     */protected $commitMessage = ''; /**      * A static array for holding all the different Tasks that are running     * @var Task[]     */private static $singletons = []; /**      * On instantiation sets the parameters and a refernece to the parent ModuleUpgrader     * @param ModuleUpgrader $mu Reference to the master ModuleUpgrader     * @param array  $params All parameters that define this task or are required at any stage during its execution     */public function __construct($mu, $params = []) { $this->mu = $mu; $this->params = $params; $this->mu = ModuleUpgrader::create(); } public function getTaskName() { return $this->taskName; } public function getTaskStepCode() { return $this->taskStep; } public function getTaskStep($currentStepCode = '') { $taskSteps = $this->mu()->getTaskSteps(); if (! $currentStepCode) { $currentStepCode = $this->getTaskStepCode(); } return $taskSteps[$currentStepCode]; } /**      * Creates all the singletons and puts them in the array of singletons. Depending on if they exist already or not.     * While creating the new instances it also passes a reference to the ModuleUpgrader or MU for short.     *     * @param  ModuleUpgrader $mu A reference to the ModuleUpgrader; to be passed on to all instantiated singletons     * @param  array  $params Params that should be passed on to the given Task once it is instantiated     * @return Task Returns the newly created task     */public static function create($mu, $params = []) { $className = static::class; if (empty(self::$singletons[$params['taskName']])) { self::$singletons[$params['taskName']] = new $className($mu, $params); } return self::$singletons[$params['taskName']]; } /**      * Deletes reference to given task and removes it from list of tasks     *     * @param array $params array containing the 'taskName' of target task to delete     */public static function deleteTask($params) { unset(self::$singletons[$params['taskName']]); return null; } public function mu() { if (! $this->mu) { $this->mu = ModuleUpgrader::create(); } return $this->mu; } /**      * returns title of the task at hand ...     *     * @return string     */abstract public function getTitle(); /**      * @return string     */abstract public function getDescription(); /**      * remove white space from description and add # at the end     * lines are also wordwrapped     *     * @return string     */public function getDescriptionNice() { $des = $this->getDescription(); $des = trim(preg_replace('/\s+/', ' ', $des)); $des = trim(wordwrap($des)); return str_replace("\n", "\n" . '# ', $des); } /**      * Executes the seperate stages of this task in chronological ordering     */public function run() { $this->starter($this->params); $error = $this->runActualTask($this->params); if (is_string($error) && strlen($error) > 0) { $this->mu()->colourPrint("\n\n" . '------------------- EXIT WITH ERROR -------------------------', 'red'); $this->mu()->colourPrint($error, 'red'); $this->mu()->colourPrint("\n\n" . '------------------- EXIT WITH ERROR -------------------------', 'red'); die("\n\n\n---"); } $this->ender($this->params); } /**      * runs the actual task and needs to be defined in any class that extends     * this class.     *     * When it returns a string, we regard this to be a description of a fatal error!     *     * @return string|null     */abstract public function runActualTask($params = []); public function setCommitMessage($s) { $this->commitMessage = $s; return $this; } /**      * Runs everything that should be run and begining of execution, I.e commiting everything to get or creating a     * backup branch before making changes     */protected function starter($params = []) { $this->setParams($params); } protected function setParams($params = []) { foreach ($params as $paramKey => $paramValue) { $method = 'set' . $paramKey; if (method_exists($this, $method)) { $this->{$method}($paramValue); } else { $paramKey = lcfirst($paramKey); if (property_exists($this, $paramKey)) { $this->{$paramKey} = $paramValue; } else { user_error( 'You are trying to set ' . $paramKey . ' but it is meaninguless to this class: ' . static::class ); } } } } /**      * Executed as the last step of a task. Used primarily for finishing off of changes made during execution of task.     * I.e Making a git commit or tagging the new branch etc etc after all changes are made     */protected function ender($params = []) { if ($this->hasCommitAndPush()) { $this->commitAndPush(); } } /**      * Does the task require the module changes to be committed after the task has run.     * @return bool Defaults to true     */abstract protected function hasCommitAndPush(); /**      * The commit message that is used for the final git commit after running this task. IF none are set it will     * return a default message     * @return string commit message     */protected function getCommitMessage() { if (! $this->commitMessage) { $this->commitMessage = 'MAJOR: upgrade to new version of Silverstripe - step: ' . $this->getTitle(); } return $this->commitMessage; } /**      * Adds all files to Git staging and commits them with set commit message after execution and pushes it via git     */protected function commitAndPush() { if ($this->mu()->getIsModuleUpgrade()) { $moduleDirs = $this->mu()->getExistingModuleDirLocations(); } else { $moduleDirs = [$this->mu()->getWebRootDirLocation()]; } foreach ($moduleDirs as $moduleDir) { return Git::inst($this->mu()) ->commitAndPush( $moduleDir, $this->getCommitMessage(), $this->mu()->getNameOfTempBranch() ); } } /**      * Runs the SilverStripe made upgrader     * @param  string $task     * @param  string $param1     * @param  string $param2     * @param  string $rootDirForCommand  modules root directory     * @param  string $settings     * @param  string  $keyNotesLogFileLocation     */protected function runSilverstripeUpgradeTask( $task, $param1 = '', $param2 = '', $rootDirForCommand = '', $settings = '', $keyNotesLogFileLocation = '' ) { if (! $rootDirForCommand) { $rootDirForCommand = $this->mu()->getWebRootDirLocation(); } if (! $keyNotesLogFileLocation) { $fileName = '/upgrade_notes.md'; if (file_exists($param1)) { $keyNotesLogFileLocation = $param1 . $fileName; } else { $keyNotesLogFileLocation = $rootDirForCommand . $fileName; } } $dir = $this->mu()->getLocationOfSSUpgradeModule(); $this->mu()->execMe( $this->mu()->getWebRootDirLocation(), 'php ' . $dir . ' ' . $task . ' ' . $param1 . ' ' . $param2 . ' --root-dir=' . $rootDirForCommand . ' --write -vvv ' . $settings, 'running php upgrade ' . $task . ' see: https://github.com/silverstripe/silverstripe-upgrader', false, $keyNotesLogFileLocation ); } } |