/** * @param InputInterface $input * @param OutputInterface $output * @throws \RuntimeException * @return int|void */ protected function execute(InputInterface $input, OutputInterface $output) { $opener = ''; if (OperatingSystem::isMacOs()) { $opener = 'open'; } elseif (OperatingSystem::isWindows()) { $opener = 'start'; } else { // Linux if (exec('which xde-open')) { $opener = 'xdg-open'; } elseif (exec('which gnome-open')) { $opener = 'gnome-open'; } elseif (exec('which kde-open')) { $opener = 'kde-open'; } } if (empty($opener)) { throw new \RuntimeException('No opener command like xde-open, gnome-open, kde-open was found.'); } $this->detectContao($output); if ($this->initContao($output)) { $store = $this->getHelperSet()->get('parameter')->askStore($input, $output, 'store', true); if ($store->getId() == \Mage_Core_Model_App::ADMIN_STORE_ID) { $adminFrontName = (string) \Mage::getConfig()->getNode('admin/routers/adminhtml/args/frontName'); $url = rtrim($store->getBaseUrl(\Mage_Core_Model_Store::URL_TYPE_WEB), '/') . '/' . $adminFrontName; } else { $url = $store->getBaseUrl(\Mage_Core_Model_Store::URL_TYPE_LINK) . '?___store=' . $store->getCode(); } $output->writeln('Opening URL <comment>' . $url . '</comment> in browser'); exec(escapeshellcmd($opener . ' ' . $url)); } }
/** * @return bool */ public function isEnabled() { if (OperatingSystem::isWindows()) { return false; } if ($this->getApplication()->isPharMode()) { $pharFile = $_SERVER['argv'][0]; return substr($pharFile, -5) == '.phar'; } return true; }
/** * @param array $scriptFolders * @param string $contaoRootFolder */ public function __construct(array $scriptFolders, $contaoRootFolder = null) { $this->_contaoRootFolder = $contaoRootFolder; if (OperatingSystem::isWindows()) { $this->_homeScriptFolder = OperatingSystem::getHomeDir() . '/imi-conrun/scripts'; } else { $this->_homeScriptFolder = OperatingSystem::getHomeDir() . '/.imi-conrun/scripts'; } $this->_scriptFolders = $scriptFolders; $this->_scriptFolders[] = $this->_homeScriptFolder; foreach ($this->_scriptFolders as $key => $scriptFolder) { if (!is_dir($scriptFolder)) { unset($this->_scriptFolders[$key]); } } if (count($this->_scriptFolders)) { $this->findScripts(); } }
/** * Display a warning if a running imi-conrun as root user * * @param ConsoleEvent $event * @return void */ public function checkRunningAsRootUser(Event $event) { if ($this->_isSkipRootCheck()) { return; } $config = $event->getApplication()->getConfig(); if (!$config['application']['check-root-user']) { return; } $output = $event->getOutput(); if (OperatingSystem::isLinux() || OperatingSystem::isMacOs()) { if (function_exists('posix_getuid')) { if (posix_getuid() === 0) { $output->writeln(''); $output->writeln(self::WARNING_ROOT_USER); $output->writeln(''); } } } }
/** * Check whether pv is installed * * @return bool */ protected function hasPipeViewer() { return OperatingSystem::isProgramInstalled('pv'); }
/** * @param InputInterface $input * @param OutputInterface $output * @throws \Exception * @return array */ protected function installContao(InputInterface $input, OutputInterface $output) { $this->getApplication()->setAutoExit(false); $dialog = $this->getHelperSet()->get('dialog'); $defaults = $this->commandConfig['installation']['defaults']; $useDefaultConfigParams = $this->_parseBoolOption($input->getOption('useDefaultConfigParams')); $sessionSave = $useDefaultConfigParams ? $defaults['session_save'] : $dialog->ask($output, '<question>Please enter the session save:</question> <comment>[' . $defaults['session_save'] . ']</comment>: ', $defaults['session_save']); $adminFrontname = $useDefaultConfigParams ? $defaults['admin_frontname'] : $dialog->askAndValidate($output, '<question>Please enter the admin frontname:</question> <comment>[' . $defaults['admin_frontname'] . ']</comment> ', $this->notEmptyCallback, false, $defaults['admin_frontname']); $currency = $useDefaultConfigParams ? $defaults['currency'] : $dialog->askAndValidate($output, '<question>Please enter the default currency code:</question> <comment>[' . $defaults['currency'] . ']</comment>: ', $this->notEmptyCallback, false, $defaults['currency']); $locale = $useDefaultConfigParams ? $defaults['locale'] : $dialog->askAndValidate($output, '<question>Please enter the locale code:</question> <comment>[' . $defaults['locale'] . ']</comment>: ', $this->notEmptyCallback, false, $defaults['locale']); $timezone = $useDefaultConfigParams ? $defaults['timezone'] : $dialog->askAndValidate($output, '<question>Please enter the timezone:</question> <comment>[' . $defaults['timezone'] . ']</comment>: ', $this->notEmptyCallback, false, $defaults['timezone']); $adminUsername = $useDefaultConfigParams ? $defaults['admin_username'] : $dialog->askAndValidate($output, '<question>Please enter the admin username:</question> <comment>[' . $defaults['admin_username'] . ']</comment>: ', $this->notEmptyCallback, false, $defaults['admin_username']); $adminPassword = $useDefaultConfigParams ? $defaults['admin_password'] : $dialog->askAndValidate($output, '<question>Please enter the admin password:</question> <comment>[' . $defaults['admin_password'] . ']</comment>: ', $this->notEmptyCallback, false, $defaults['admin_password']); $adminFirstname = $useDefaultConfigParams ? $defaults['admin_firstname'] : $dialog->askAndValidate($output, '<question>Please enter the admin\'s firstname:</question> <comment>[' . $defaults['admin_firstname'] . ']</comment>: ', $this->notEmptyCallback, false, $defaults['admin_firstname']); $adminLastname = $useDefaultConfigParams ? $defaults['admin_lastname'] : $dialog->askAndValidate($output, '<question>Please enter the admin\'s lastname:</question> <comment>[' . $defaults['admin_lastname'] . ']</comment>: ', $this->notEmptyCallback, false, $defaults['admin_lastname']); $adminEmail = $useDefaultConfigParams ? $defaults['admin_email'] : $dialog->askAndValidate($output, '<question>Please enter the admin\'s email:</question> <comment>[' . $defaults['admin_email'] . ']</comment>: ', $this->notEmptyCallback, false, $defaults['admin_email']); $validateBaseUrl = function ($input) { if (!preg_match('|^http(s)?://[a-z0-9-]+(.[a-z0-9-]+)*(:[0-9]+)?(/.*)?$|i', $input)) { throw new \InvalidArgumentException('Please enter a valid URL'); } if (parse_url($input, \PHP_URL_HOST) == 'localhost') { throw new \InvalidArgumentException('localhost cause problems! Please use 127.0.0.1 or another hostname'); } return $input; }; $baseUrl = $input->getOption('baseUrl') !== null ? $input->getOption('baseUrl') : $dialog->askAndValidate($output, '<question>Please enter the base url:</question> ', $validateBaseUrl, false); $baseUrl = rtrim($baseUrl, '/') . '/'; // normalize baseUrl /** * Correct session save (common mistake) */ if ($sessionSave == 'file') { $sessionSave = 'files'; } /** * Try to create session folder */ $defaultSessionFolder = $this->config['installationFolder'] . DIRECTORY_SEPARATOR . 'var/session'; if ($sessionSave == 'files' && !is_dir($defaultSessionFolder)) { @mkdir($defaultSessionFolder); } $argv = array('license_agreement_accepted' => 'yes', 'locale' => $locale, 'timezone' => $timezone, 'db_host' => $this->config['db_host'], 'db_name' => $this->config['db_name'], 'db_user' => $this->config['db_user'], 'db_pass' => $this->config['db_pass'], 'url' => $baseUrl, 'use_rewrites' => 'yes', 'use_secure' => 'no', 'secure_base_url' => '', 'use_secure_admin' => 'no', 'admin_username' => $adminUsername, 'admin_lastname' => $adminLastname, 'admin_firstname' => $adminFirstname, 'admin_email' => $adminEmail, 'admin_password' => $adminPassword, 'session_save' => $sessionSave, 'admin_frontname' => $adminFrontname, 'backend_frontname' => $adminFrontname, 'default_currency' => $currency, 'skip_url_validation' => 'yes'); if ($useDefaultConfigParams) { if (strlen($defaults['encryption_key']) > 0) { $argv['encryption_key'] = $defaults['encryption_key']; } if (strlen($defaults['use_secure']) > 0) { $argv['use_secure'] = $defaults['use_secure']; $argv['secure_base_url'] = str_replace('http://', 'https://', $baseUrl); } if (strlen($defaults['use_rewrites']) > 0) { $argv['use_rewrites'] = $defaults['use_rewrites']; } } $installArgs = ''; foreach ($argv as $argName => $argValue) { $installArgs .= '--' . $argName . ' ' . escapeshellarg($argValue) . ' '; } $output->writeln('<info>Start installation process.</info>'); if (OperatingSystem::isWindows()) { $installCommand = 'php ' . $this->getInstallScriptPath() . ' ' . $installArgs; } else { $installCommand = '/usr/bin/env php ' . $this->getInstallScriptPath() . ' ' . $installArgs; } $output->writeln('<comment>' . $installCommand . '</comment>'); exec($installCommand, $installationOutput, $returnStatus); $installationOutput = implode(PHP_EOL, $installationOutput); if ($returnStatus !== self::EXEC_STATUS_OK) { throw new \Exception('Installation failed.' . $installationOutput); } else { $output->writeln('<info>Successfully installed Contao</info>'); $encryptionKey = trim(substr($installationOutput, strpos($installationOutput, ':') + 1)); $output->writeln('<comment>Encryption Key:</comment> <info>' . $encryptionKey . '</info>'); } $dialog = $this->getHelperSet()->get('dialog'); /** * Htaccess file */ if ($input->getOption('useDefaultConfigParams') == null || $input->getOption('replaceHtaccessFile') != null) { $replaceHtaccessFile = false; if ($this->_parseBoolOption($input->getOption('replaceHtaccessFile'))) { $replaceHtaccessFile = true; } elseif ($dialog->askConfirmation($output, '<question>Write BaseURL to .htaccess file?</question> <comment>[n]</comment>: ', false)) { $replaceHtaccessFile = true; } if ($replaceHtaccessFile) { $this->replaceHtaccessFile($baseUrl); } } \chdir($this->config['installationFolder']); $this->getApplication()->reinit(); $output->writeln('<info>Reindex all after installation</info>'); $this->getApplication()->run(new StringInput('index:reindex:all'), $output); $this->getApplication()->run(new StringInput('sys:check'), $output); $output->writeln('<info>Successfully installed contao</info>'); }
/** * @return bool */ public function isEnabled() { return function_exists('exec') && !OperatingSystem::isWindows(); }
/** * get current working directory */ public static function getCwd() { if (!Exec::allowed() || OperatingSystem::isWindows()) { return getcwd(); } Exec::run('pwd', $folder); return $folder; }
/** * Check if there is a user config file. ~/.imi-conrun.yaml * * @param array $config * @param string $contaoRootFolder * * @return array */ public function loadUserConfig($config, $contaoRootFolder = null) { if ($this->_userConfig == null) { $this->_userConfig = array(); $homeDirectory = OperatingSystem::getHomeDir(); if (OperatingSystem::isWindows()) { $personalConfigFile = $homeDirectory . DIRECTORY_SEPARATOR . $this->_customConfigFilename; } else { $personalConfigFile = $homeDirectory . DIRECTORY_SEPARATOR . '.' . $this->_customConfigFilename; } if ($homeDirectory && file_exists($personalConfigFile)) { $userConfig = $this->applyVariables(\file_get_contents($personalConfigFile), $contaoRootFolder, null); $this->_userConfig = Yaml::parse($userConfig); return $config; } } $config = ArrayFunctions::mergeArrays($config, $this->_userConfig); return $config; }
/** * @param InputInterface $input * @return string */ protected function _checkRootDirOption(InputInterface $input) { $definedRootDir = $input->getParameterOption('--root-dir'); if (!empty($definedRootDir)) { if ($definedRootDir[0] == '~') { $definedRootDir = OperatingSystem::getHomeDir() . substr($definedRootDir, 1); } $folder = realpath($definedRootDir); $this->_directRootDir = true; if (is_dir($folder)) { \chdir($folder); return; } } }