Skip to content

Instantly share code, notes, and snippets.

@esimonetti
Last active November 20, 2023 13:17
Show Gist options
  • Star 3 You must be signed in to star a gist
  • Fork 2 You must be signed in to fork a gist
  • Save esimonetti/9ca21b15dc47565b12ee73e2352da549 to your computer and use it in GitHub Desktop.
Save esimonetti/9ca21b15dc47565b12ee73e2352da549 to your computer and use it in GitHub Desktop.
Sugar CLI Repair - Instance as script argument - USE TOOTHPASTE INSTEAD! https://github.com/esimonetti/toothpaste
<?php
// Enrico Simonetti
// enricosimonetti.com
//
// 2017-11-01 on Sugar 7.9.2.0
function usage($error = '') {
if (!empty($error)) print(PHP_EOL . 'Error: ' . $error . PHP_EOL);
print(' php ' . __FILE__ . ' --instance /full/path' . PHP_EOL);
exit(1);
}
// only allow CLI
$sapi_type = php_sapi_name();
if (substr($sapi_type, 0, 3) != 'cli') {
die(__FILE__ . ' is CLI only.');
}
// get command line params
$o = getopt('', array('instance:'));
if (!$o) usage();
// find directory
if (!empty($o['instance']) && is_dir($o['instance'])) {
print('Debug: Entering directory ' . $o['instance'] . PHP_EOL);
chdir($o['instance']);
} else {
chdir(dirname(__FILE__));
}
if (!file_exists('config.php') || !file_exists('sugar_version.php')) {
usage('The provided directory is not a Sugar system');
}
// sugar basic setup
define('sugarEntry', true);
require_once('include/entryPoint.php');
if (extension_loaded('xdebug')) {
echo 'Xdebug is enabled on this system. It is highly recommended to disable Xdebug on PHP CLI before running this script. Xdebug will cause unwanted slowness.'.PHP_EOL;
}
// temporarily stop xdebug, xhprof and tideways if enabled
if (function_exists('xdebug_disable')) {
xdebug_disable();
}
if (function_exists('xhprof_disable')) {
xhprof_disable();
xhprof_sample_disable();
}
if (function_exists('tideways_disable')) {
tideways_disable();
}
if (empty($current_language)) {
$current_language = $sugar_config['default_language'];
}
$app_list_strings = return_app_list_strings_language($current_language);
$app_strings = return_application_language($current_language);
$mod_strings = return_module_language($current_language, 'Administration');
global $current_user;
$current_user = BeanFactory::getBean('Users');
$current_user->getSystemUser();
$start_time = microtime(true);
echo 'Repairing...' . PHP_EOL;
if (SugarCache::instance()->useBackend()) {
// clear cache
SugarCache::instance()->reset();
SugarCache::instance()->resetFull();
}
SugarCache::cleanOpcodes();
// clear opcache before #79804
if (function_exists('opcache_reset')) {
opcache_reset();
}
require_once('modules/Administration/QuickRepairAndRebuild.php');
// remove team cache files
$files_to_remove = array(
'cache/modules/Teams/TeamSetMD5Cache.php',
'cache/modules/Teams/TeamSetCache.php'
);
foreach ($files_to_remove as $file) {
$file = SugarAutoloader::normalizeFilePath($file);
if (SugarAutoloader::fileExists($file)) {
SugarAutoloader::unlink($file);
}
}
// rebuild the autoloader once first, to be aware of new files
SugarAutoLoader::buildCache();
// repair
$repair = new RepairAndClear();
$repair->repairAndClearAll(array('clearAll'), array($mod_strings['LBL_ALL_MODULES']), true, false, '');
// remove some stuff
LanguageManager::removeJSLanguageFiles();
LanguageManager::clearLanguageCache();
// rebuild some stuff
SugarAutoLoader::buildCache();
// quick load of all beans
global $beanList;
$full_module_list = array_merge($beanList, $app_list_strings['moduleList']);
foreach ($full_module_list as $module => $label) {
$bean = BeanFactory::newBean($module);
// load language too
LanguageManager::createLanguageFile($module, array('default'), true);
$mod_strings = return_module_language($current_language, $module);
}
// load app strings
$app_list_strings = return_app_list_strings_language($current_language);
$app_strings = return_application_language($current_language);
// load api
$sd = new ServiceDictionary();
$sd->buildAllDictionaries();
// when the other register shutdown functionalities complete, exit this script
register_shutdown_function(
function($start) {
print('Repair completed in ' . (int)(microtime(true) - $start) . ' seconds.' . PHP_EOL);
},
$start_time
);
@esimonetti
Copy link
Author

Thank you @hatimalam!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment