コード例 #1
0
ファイル: update.php プロジェクト: LeeGlendenning/formulize
/**
 * Automatic update of the system module
 *
 * @param object $module reference to the module object
 * @param int $oldversion The old version of the database
 * @param int $dbVersion The database version
 * @return mixed
 */
function xoops_module_update_system(&$module, $oldversion = NULL, $dbVersion = NULL)
{
    global $icmsConfig, $xoTheme;
    $from_112 = $abortUpdate = FALSE;
    $oldversion = $module->getVar('version');
    if ($oldversion < 120) {
        $result = icms::$xoopsDB->query("SELECT t1.tpl_id FROM " . icms::$xoopsDB->prefix('tplfile') . " t1, " . icms::$xoopsDB->prefix('tplfile') . " t2 WHERE t1.tpl_module = t2.tpl_module AND t1.tpl_tplset=t2.tpl_tplset AND t1.tpl_file = t2.tpl_file AND t1.tpl_id > t2.tpl_id");
        $tplids = array();
        while (list($tplid) = icms::$xoopsDB->fetchRow($result)) {
            $tplids[] = $tplid;
        }
        if (count($tplids) > 0) {
            $tplfile_handler = icms::handler('icms_view_template_file');
            $duplicate_files = $tplfile_handler->getObjects(new icms_db_criteria_Item('tpl_id', "(" . implode(',', $tplids) . ")", "IN"));
            if (count($duplicate_files) > 0) {
                foreach (array_keys($duplicate_files) as $i) {
                    $tplfile_handler->delete($duplicate_files[$i]);
                }
            }
        }
    }
    $icmsDatabaseUpdater = icms_db_legacy_Factory::getDatabaseUpdater();
    //$dbVersion  = $module->getDBVersion();
    //$oldversion  = $module->getVar('version');
    ob_start();
    $dbVersion = $module->getDBVersion();
    echo sprintf(_DATABASEUPDATER_CURRENTVER, icms_conv_nr2local($dbVersion)) . '<br />';
    echo "<code>" . sprintf(_DATABASEUPDATER_UPDATE_TO, icms_conv_nr2local(ICMS_SYSTEM_DBVERSION)) . "<br />";
    /*
     * DEVELOPER, PLEASE NOTE !!!
     *
     * Everytime we add a new upgrade block here, the dbversion of the System Module will get
     * incremented. It is very important to modify the ICMS_SYSTEM_DBVERSION accordingly
     * in htdocs/include/version.php
     *
     * When we start a new major release, move all the previous version's upgrade scripts to
     * a separate file, to minimize file size and memory usage
     */
    $CleanWritingFolders = FALSE;
    if ($dbVersion < 40) {
        include 'update-112-to-122.php';
    }
    /*  Begin upgrade to version 1.3 */
    if (!$abortUpdate) {
        $newDbVersion = 41;
    }
    if ($dbVersion < $newDbVersion) {
        /* Add new tables and data for the help suggestions and quick search */
        $table = new icms_db_legacy_updater_Table('autosearch_cat');
        if (!$table->exists()) {
            $table->setStructure("`cid` int(11) NOT NULL auto_increment,\n\t\t\t\t `cat_name` varchar(255) NOT NULL,\n\t\t\t\t `cat_url` text NOT NULL,\n\t\t\t\t PRIMARY KEY (`cid`)");
            if (!$table->createTable()) {
                $abortUpdate = TRUE;
                $newDbVersion = 40;
            }
            if (!$abortUpdate) {
                icms_loadLanguageFile('system', 'admin');
                $search_cats = array("NULL, '" . _MD_AM_ADSENSES . "', '/modules/system/admin.php?fct=adsense'", "NULL, '" . _MD_AM_AUTOTASKS . "', '/modules/system/admin.php?fct=autotasks'", "NULL, '" . _MD_AM_AVATARS . "', '/modules/system/admin.php?fct=avatars'", "NULL, '" . _MD_AM_BANS . "', '/modules/system/admin.php?fct=banners'", "NULL, '" . _MD_AM_BKPOSAD . "', '/modules/system/admin.php?fct=blockspadmin'", "NULL, '" . _MD_AM_BKAD . "', '/modules/system/admin.php?fct=blocksadmin'", "NULL, '" . _MD_AM_COMMENTS . "', '/modules/system/admin.php?fct=comments'", "NULL, '" . _MD_AM_CUSTOMTAGS . "', '/modules/system/admin.php?fct=customtag'", "NULL, '" . _MD_AM_USER . "', '/modules/system/admin.php?fct=users'", "NULL, '" . _MD_AM_FINDUSER . "', '/modules/system/admin.php?fct=finduser'", "NULL, '" . _MD_AM_ADGS . "', '/modules/system/admin.php?fct=groups'", "NULL, '" . _MD_AM_IMAGES . "', '/modules/system/admin.php?fct=images'", "NULL, '" . _MD_AM_MLUS . "', '/modules/system/admin.php?fct=mailusers'", "NULL, '" . _MD_AM_MIMETYPES . "', '/modules/system/admin.php?fct=mimetype'", "NULL, '" . _MD_AM_MDAD . "', '/modules/system/admin.php?fct=modulesadmin'", "NULL, '" . _MD_AM_PREF . "', '/modules/system/admin.php?fct=preferences'", "NULL, '" . _MD_AM_RATINGS . "', '/modules/system/admin.php?fct=rating'", "NULL, '" . _MD_AM_SMLS . "', '/modules/system/admin.php?fct=smilies'", "NULL, '" . _MD_AM_PAGES . "', '/modules/system/admin.php?fct=pages'", "NULL, '" . _MD_AM_TPLSETS . "', '/modules/system/admin.php?fct=tplsets'", "NULL, '" . _MD_AM_RANK . "', '/modules/system/admin.php?fct=userrank'", "NULL, '" . _MD_AM_VERSION . "', '/modules/system/admin.php?fct=version'");
                foreach ($search_cats as $cat) {
                    $table->setData($cat);
                }
                $table->addData();
            }
            unset($table);
        }
        $table = new icms_db_legacy_updater_Table('autosearch_list');
        if (!$table->exists() && !$abortUpdate) {
            $table->setStructure("`id` int(11) NOT NULL auto_increment,\n\t\t\t\t `cat_id` int(11) NOT NULL,\n\t\t\t\t `name` varchar(255) NOT NULL,\n\t\t\t\t `img` varchar(255) NOT NULL,\n\t\t\t\t `desc` text NOT NULL,\n\t\t\t\t `url` text NOT NULL,\n\t\t\t\t PRIMARY KEY (`id`)");
            if (!$table->createTable()) {
                $abortUpdate = TRUE;
                $newDbVersion = 40;
            }
            if (!$abortUpdate) {
                icms_loadLanguageFile('system', 'admin');
                icms_loadLanguageFile('system', 'preferences', TRUE);
                $search_items = array("NULL, 1, '" . _MD_AM_ADSENSES . "', '/modules/system/admin/adsense/images/adsense_small.png', '" . _MD_AM_ADSENSES_DSC . "', '/modules/system/admin.php?fct=adsense'", "NULL, 2, '" . _MD_AM_AUTOTASKS . "', '/modules/system/admin/autotasks/images/autotasks_small.png', '" . _MD_AM_AUTOTASKS_DSC . "', '/modules/system/admin.php?fct=autotasks'", "NULL, 3, '" . _MD_AM_AVATARS . "', '/modules/system/admin/avatars/images/avatars_small.png', '" . _MD_AM_AVATARS_DSC . "', '/modules/system/admin.php?fct=avatars'", "NULL, 4, '" . _MD_AM_BANS . "', '/modules/system/admin/banners/images/banners_small.png', '" . _MD_AM_BANS_DSC . "', '/modules/system/admin.php?fct=banners'", "NULL, 5, '" . _MD_AM_BKPOSAD . "', '/modules/system/admin/blockspadmin/images/blockspadmin_small.png', '" . _MD_AM_BKPOSAD_DSC . "', '/modules/system/admin.php?fct=blockspadmin'", "NULL, 6, '" . _MD_AM_BKAD . "', '/modules/system/admin/blocksadmin/images/blocksadmin_small.png', '" . _MD_AM_BKAD_DSC . "', '/modules/system/admin.php?fct=blocksadmin'", "NULL, 7, '" . _MD_AM_COMMENTS . "', '/modules/system/admin/comments/images/comments_small.png', '" . _MD_AM_COMMENTS_DSC . "', '/modules/system/admin.php?fct=comments'", "NULL, 8, '" . _MD_AM_CUSTOMTAGS . "', '/modules/system/admin/customtag/images/customtag_small.png', '" . _MD_AM_CUSTOMTAGS_DSC . "', '/modules/system/admin.php?fct=customtag'", "NULL, 9, '" . _MD_AM_USER . "', '/modules/system/admin/users/images/users_small.png', '" . _MD_AM_USER_DSC . "', '/modules/system/admin.php?fct=users'", "NULL, 10, '" . _MD_AM_FINDUSER . "', '/modules/system/admin/findusers/images/findusers_small.png', '" . _MD_AM_FINDUSER_DSC . "', '/modules/system/admin.php?fct=findusers'", "NULL, 11, '" . _MD_AM_ADGS . "', '/modules/system/admin/groups/images/groups_small.png', '" . _MD_AM_ADGS_DSC . "', '/modules/system/admin.php?fct=groups'", "NULL, 12, '" . _MD_AM_IMAGES . "', '/modules/system/admin/images/images/images_small.png', '" . _MD_AM_IMAGES_DSC . "', '/modules/system/admin.php?fct=images'", "NULL, 13, '" . _MD_AM_MLUS . "', '/modules/system/admin/mailusers/images/mailusers_small.png', '" . _MD_AM_MLUS_DSC . "', '/modules/system/admin.php?fct=mailusers'", "NULL, 14, '" . _MD_AM_MIMETYPES . "', '/modules/system/admin/mimetype/images/mimetype_small.png', '" . _MD_AM_MIMETYPES_DSC . "', '/modules/system/admin.php?fct=mimetype'", "NULL, 15, '" . _MD_AM_MDAD . "', '/modules/system/admin/modulesadmin/images/modulesadmin_small.png', '" . _MD_AM_MDAD_DSC . "', '/modules/system/admin.php?fct=modulesadmin'", "NULL, 16, '" . _MD_AM_PREF . " - " . _MD_AM_AUTHENTICATION . "', '/modules/system/admin/preferences/images/preferences_small.png', '" . _MD_AM_AUTHENTICATION_DSC . "', '/modules/system/admin.php?fct=preferences&op=show&confcat_id=7'", "NULL, 16, '" . _MD_AM_PREF . " - " . _MD_AM_AUTOTASKS . "', '/modules/system/admin/preferences/images/preferences_small.png', '" . _MD_AM_AUTOTASKS_PREF_DSC . "', '/modules/system/admin.php?fct=preferences&op=show&confcat_id=13'", "NULL, 16, '" . _MD_AM_PREF . " - " . _MD_AM_CAPTCHA . "', '/modules/system/admin/preferences/images/preferences_small.png', '" . _MD_AM_CAPTCHA_DSC . "', '/modules/system/admin.php?fct=preferences&op=show&confcat_id=11'", "NULL, 16, '" . _MD_AM_PREF . " - " . _MD_AM_GENERAL . "', '/modules/system/admin/preferences/images/preferences_small.png', '" . _MD_AM_GENERAL_DSC . "', '/modules/system/admin.php?fct=preferences&op=show&confcat_id=1'", "NULL, 16, '" . _MD_AM_PREF . " - " . _MD_AM_PURIFIER . "', '/modules/system/admin/preferences/images/preferences_small.png', '" . _MD_AM_PURIFIER_DSC . "', '/modules/system/admin.php?fct=preferences&op=show&confcat_id=14'", "NULL, 16, '" . _MD_AM_PREF . " - " . _MD_AM_MAILER . "', '/modules/system/admin/preferences/images/preferences_small.png', '" . _MD_AM_MAILER_DSC . "', '/modules/system/admin.php?fct=preferences&op=show&confcat_id=6'", "NULL, 16, '" . _MD_AM_PREF . " - " . _MD_AM_METAFOOTER . "', '/modules/system/admin/preferences/images/preferences_small.png', '" . _MD_AM_METAFOOTER_DSC . "', '/modules/system/admin/preferences/images/preferences_small.png'", "NULL, 16, '" . _MD_AM_PREF . " - " . _MD_AM_MULTILANGUAGE . "', '/modules/system/admin/preferences/images/preferences_small.png', '" . _MD_AM_MULTILANGUAGE_DSC . "', '/modules/system/admin.php?fct=preferences&op=show&confcat_id=8'", "NULL, 16, '" . _MD_AM_PREF . " - " . _MD_AM_PERSON . "', '/modules/system/admin/preferences/images/preferences_small.png', '" . _MD_AM_PERSON_DSC . "', '/modules/system/admin.php?fct=preferences&op=show&confcat_id=10'", "NULL, 16, '" . _MD_AM_PREF . " - " . _MD_AM_PLUGINS . "', '/modules/system/admin/preferences/images/preferences_small.png', '" . _MD_AM_PLUGINS_DSC . "', '/modules/system/admin.php?fct=preferences&op=show&confcat_id=12'", "NULL, 16, '" . _MD_AM_PREF . " - " . _MD_AM_SEARCH . "', '/modules/system/admin/preferences/images/preferences_small.png', '" . _MD_AM_SEARCH_DSC . "', '/modules/system/admin.php?fct=preferences&op=show&confcat_id=5'", "NULL, 16, '" . _MD_AM_PREF . " - " . _MD_AM_USERSETTINGS . "', '/modules/system/admin/preferences/images/preferences_small.png', '" . _MD_AM_USERSETTINGS_DSC . "', '/modules/system/admin.php?fct=preferences&op=show&confcat_id=2'", "NULL, 16, '" . _MD_AM_PREF . " - " . _MD_AM_CENSOR . "', '/modules/system/admin/preferences/images/preferences_small.png', '" . _MD_AM_CENSOR_DSC . "', '/modules/system/admin.php?fct=preferences&op=show&confcat_id=4'", "NULL, 17, '" . _MD_AM_RATINGS . "', '/modules/system/admin/rating/images/rating_small.png', '" . _MD_AM_RATINGS_DSC . "', '/modules/system/admin.php?fct=rating'", "NULL, 18, '" . _MD_AM_SMLS . "', '/modules/system/admin/smilies/images/smilies_small.png', '" . _MD_AM_SMLS_DSC . "', '/modules/system/admin.php?fct=smilies'", "NULL, 19, '" . _MD_AM_PAGES . "', '/modules/system/admin/pages/images/pages_small.png', '" . _MD_AM_PAGES_DSC . "', '/modules/system/admin.php?fct=pages'", "NULL, 20, '" . _MD_AM_TPLSETS . "', '/modules/system/admin/tplsets/images/tplsets_small.png', '" . _MD_AM_TPLSETS_DSC . "', '/modules/system/admin.php?fct=tplsets'", "NULL, 21, '" . _MD_AM_RANK . "', '/modules/system/admin/userrank/images/userrank_small.png', '" . _MD_AM_RANK_DSC . "', '/modules/system/admin.php?fct=userrank'", "NULL, 22, '" . _MD_AM_VRSN . "', '/modules/system/admin/version/images/version_small.png', '" . _MD_AM_VRSN_DSC . "', '/modules/system/admin.php?fct=version'");
                foreach ($search_items as $item) {
                    $table->setData($item);
                }
                $table->addData();
            }
            unset($table);
        }
        /* Optimize old tables and fix data structures */
        $table = new icms_db_legacy_updater_Table('config');
        $icmsDatabaseUpdater->runQuery("ALTER TABLE `" . $table->name() . "` DROP INDEX conf_mod_cat_id, ADD INDEX mod_cat_order(conf_modid, conf_catid, conf_order)", 'Successfully altered the indexes on table config', '');
        unset($table);
        $table = new icms_db_legacy_updater_Table('group_permission');
        $table->addAlteredField('gperm_modid', "SMALLINT(5) UNSIGNED NOT NULL DEFAULT '0'", 'gperm_modid');
        $table->alterTable();
        $icmsDatabaseUpdater->runQuery("ALTER TABLE `" . $table->name() . "` DROP INDEX itemid, DROP INDEX groupid, DROP INDEX gperm_modid", 'Successfully dropped the indexes on table group_permission', '');
        $icmsDatabaseUpdater->runQuery("ALTER TABLE `" . $table->name() . "` ADD INDEX name_mod_group (gperm_name(10), gperm_modid, gperm_groupid)", 'Successfully added the indexes on table group_permission', '');
        unset($table);
        $table = new icms_db_legacy_updater_Table('modules');
        $icmsDatabaseUpdater->runQuery("ALTER TABLE `" . $table->name() . "` DROP INDEX hasmain, DROP INDEX hasadmin, DROP INDEX hassearch, DROP INDEX hasnotification, DROP INDEX name, DROP INDEX dirname", 'Successfully dropped the indexes on table modules', '');
        $icmsDatabaseUpdater->runQuery("ALTER TABLE `" . $table->name() . "` ADD INDEX dirname (dirname(5)), ADD INDEX active_main_weight (isactive, hasmain, weight)", 'Successfully added the indexes on table modules', '');
        unset($table);
        $table = new icms_db_legacy_updater_Table('users');
        $icmsDatabaseUpdater->runQuery("ALTER TABLE `" . $table->name() . "` DROP INDEX email, DROP INDEX uiduname, DROP INDEX unamepass", 'Successfully dropped the indexes on table users', '');
        $icmsDatabaseUpdater->runQuery("ALTER TABLE `" . $table->name() . "` DROP INDEX login_name, ADD UNIQUE INDEX login_name (login_name)", 'Successfully added the indexes on table users', '');
        unset($table);
        $table = new icms_db_legacy_updater_Table('priv_msgs');
        $icmsDatabaseUpdater->runQuery("ALTER TABLE `" . $table->name() . "` DROP INDEX to_userid", 'Successfully dropped the indexes on table priv_msgs', '');
        unset($table);
        $table = new icms_db_legacy_updater_Table('ranks');
        $icmsDatabaseUpdater->runQuery("ALTER TABLE `" . $table->name() . "` DROP INDEX rank_min", 'Successfully dropped the indexes on table ranks', '');
        unset($table);
        /* Corrects an error from db version 4 */
        $table = new icms_db_legacy_updater_Table('users');
        if ($table->fieldExists('pass')) {
            $table->addAlteredField('pass', "varchar(255) NOT NULL default ''", 'pass');
            $table->alterTable();
        }
        unset($table);
        /* change IP address to varchar(64) in session to accomodate IPv6 addresses */
        $table = new icms_db_legacy_updater_Table('session');
        if ($table->fieldExists('sess_ip')) {
            $table->addAlteredField('sess_ip', "varchar(64) NOT NULL default ''", 'sess_ip');
            $table->alterTable();
        }
        unset($table);
        /* add modname and ipf to modules table */
        $table = new icms_db_legacy_updater_Table("modules");
        $alter = FALSE;
        if (!$table->fieldExists("modname")) {
            $table->addNewField("modname", "varchar(25) NOT NULL default ''");
            $alter = TRUE;
        }
        if (!$table->fieldExists("ipf")) {
            $table->addNewField("ipf", "tinyint(1) unsigned NOT NULL default '0'");
            $alter = TRUE;
        }
        if ($alter) {
            $table->addNewFields();
        }
        unset($table, $alter);
        $module_handler = icms::handler('icms_module');
        $modules = $module_handler->getObjects();
        foreach ($modules as $module) {
            if ($module->getInfo("modname") !== FALSE) {
                $module->setVar("modname", $module->getInfo("modname"));
            }
            if ($module->getInfo("object_items") !== FALSE) {
                $module->setVar("ipf", 1);
            }
            $module_handler->insert($module);
        }
        unset($module_handler, $modules);
        /* add slot for adsense and rename fields */
        $table = new icms_db_legacy_updater_Table('system_adsense');
        if (!$table->fieldExists("slot")) {
            $table->addNewField("slot", "varchar(12) NOT NULL default ''");
            $table->addNewFields();
        }
        if ($table->fieldExists("border_color")) {
            $icmsDatabaseUpdater->runQuery("ALTER TABLE `" . $table->name() . "` CHANGE border_color color_border varchar(6) NOT NULL default ''");
        }
        if ($table->fieldExists("background_color")) {
            $icmsDatabaseUpdater->runQuery("ALTER TABLE `" . $table->name() . "` CHANGE background_color color_background varchar(6) NOT NULL default ''");
        }
        if ($table->fieldExists("link_color")) {
            $icmsDatabaseUpdater->runQuery("ALTER TABLE `" . $table->name() . "` CHANGE link_color color_link varchar(6) NOT NULL default ''");
        }
        if ($table->fieldExists("url_color")) {
            $icmsDatabaseUpdater->runQuery("ALTER TABLE `" . $table->name() . "` CHANGE url_color color_url varchar(6) NOT NULL default ''");
        }
        if ($table->fieldExists("text_color")) {
            $icmsDatabaseUpdater->runQuery("ALTER TABLE `" . $table->name() . "` CHANGE text_color color_text varchar(6) NOT NULL default ''");
        }
        unset($table);
        /* rename content field for customtag */
        $table = new icms_db_legacy_updater_Table("system_customtag");
        if ($table->fieldExists("content")) {
            $icmsDatabaseUpdater->runQuery("ALTER TABLE `" . $table->name() . "` CHANGE content customtag_content text NOT NULL");
        }
        unset($table);
        /* rename gperm_name from view to view_customtag for system module */
        $table = new icms_db_legacy_updater_Table("group_permission");
        $icmsDatabaseUpdater->runQuery("UPDATE `" . $table->name() . "` SET gperm_name = 'view_customtag' WHERE gperm_name = 'view' AND gperm_modid = 1", "", "");
        unset($table);
        /* reset default source editor if jsvi is used */
        $configs = icms::$config->getConfigs(icms_buildCriteria(array("conf_name" => "sourceeditor_default")));
        if (count($configs) == 1 && $configs[0]->getVar("conf_value") == "jsvi") {
            $configs[0]->setVar("conf_value", "editarea");
            icms::$config->insertConfig($configs[0]);
        }
        unset($configs);
        /* New HTML Purifier options -
         * purifier_HTML_FlashAllowFullScreen, after purifier_HTML_AttrNameUseCDATA
         * purifier_Output_FlashCompat, after purifier_HTML_FlashAllowFullScreen
         * purifier_Filter_AllowCustom, after purifier_Filter_YouTube
         * purifier_Core_NormalizeNewlines, after purifier_Core_RemoveInvalidImg
         */
        $table = new icms_db_legacy_updater_Table("config");
        // retrieve the value of the position before the config to be inserted.
        $configs = icms::$config->getConfigs(icms_buildCriteria(array("conf_name" => "purifier_HTML_AttrNameUseCDATA")));
        $p = $configs[0]->getVar('conf_order') + 1;
        //move all the other options down
        $icmsDatabaseUpdater->runQuery("UPDATE `" . $table->name() . "` SET conf_order = conf_order + 2 WHERE conf_order >= " . $p . " AND conf_catid = " . ICMS_CONF_PURIFIER, "", "");
        $icmsDatabaseUpdater->insertConfig(ICMS_CONF_PURIFIER, 'purifier_HTML_FlashAllowFullScreen', '_MD_AM_PURIFIER_HTML_FLASHFULLSCRN', '0', '_MD_AM_PURIFIER_HTML_FLASHFULLSCRNDSC', 'yesno', 'int', $p);
        $icmsDatabaseUpdater->insertConfig(ICMS_CONF_PURIFIER, 'purifier_Output_FlashCompat', '_MD_AM_PURIFIER_OUTPUT_FLASHCOMPAT', '0', '_MD_AM_PURIFIER_OUTPUT_FLASHCOMPATDSC', 'yesno', 'int', $p++);
        // retrieve the value of the position before the config to be inserted.
        $configs = icms::$config->getConfigs(icms_buildCriteria(array("conf_name" => "purifier_Filter_YouTube")));
        $p = $configs[0]->getVar('conf_order') + 1;
        //move all the other options down
        $icmsDatabaseUpdater->runQuery("UPDATE `" . $table->name() . "` SET conf_order = conf_order + 1 WHERE conf_order >= " . $p . " AND conf_catid = " . ICMS_CONF_PURIFIER, "", "");
        $icmsDatabaseUpdater->insertConfig(ICMS_CONF_PURIFIER, 'purifier_Filter_AllowCustom', '_MD_AM_PURIFIER_FILTER_ALLOWCUSTOM', '0', '_MD_AM_PURIFIER_FILTER_ALLOWCUSTOMDSC', 'yesno', 'int', $p);
        // retrieve the value of the position before the config to be inserted.
        $configs = icms::$config->getConfigs(icms_buildCriteria(array("conf_name" => "purifier_Core_RemoveInvalidImg")));
        $p = $configs[0]->getVar('conf_order') + 1;
        //move all the other options down
        $icmsDatabaseUpdater->runQuery("UPDATE `" . $table->name() . "` SET conf_order = conf_order + 1 WHERE conf_order >= " . $p . " AND conf_catid = " . ICMS_CONF_PURIFIER, "", "");
        $icmsDatabaseUpdater->insertConfig(ICMS_CONF_PURIFIER, 'purifier_Core_NormalizeNewlines', '_MD_AM_PURIFIER_CORE_NORMALNEWLINES', '1', '_MD_AM_PURIFIER_CORE_NORMALNEWLINESDSC', 'yesno', 'int', $p);
        unset($table);
        /* Finish up this portion of the db update */
        if (!$abortUpdate) {
            $icmsDatabaseUpdater->updateModuleDBVersion($newDbVersion, 'system');
            echo sprintf(_DATABASEUPDATER_UPDATE_OK, icms_conv_nr2local($newDbVersion)) . '<br />';
        }
    }
    /*  1.3 beta|rc|final release  */
    /*
     * This portion of the upgrade must remain as the last section of code to execute
     * Place all release upgrade steps above this point
     */
    echo "</code>";
    if ($abortUpdate) {
        icms_core_Message::error(sprintf(_DATABASEUPDATER_UPDATE_ERR, icms_conv_nr2local($newDbVersion)), _DATABASEUPDATER_UPDATE_DB, TRUE);
    }
    if ($from_112 && !$abortUpdate) {
        /**
         * @todo create a language constant for this text
         */
        echo _DATABASEUPDATER_MSG_FROM_112;
        echo '<script>setTimeout("window.location.href=\'' . ICMS_MODULES_URL . '/system/admin.php?fct=modulesadmin&op=install&module=content&from_112=1\'",20000);</script>';
    }
    $feedback = ob_get_clean();
    if (method_exists($module, "setMessage")) {
        $module->messages = $module->setMessage($feedback);
    } else {
        echo $feedback;
    }
    $icmsDatabaseUpdater->updateModuleDBVersion($newDbVersion, 'system');
    return icms_core_Filesystem::cleanFolders(array('templates_c' => ICMS_COMPILE_PATH . "/", 'cache' => ICMS_CACHE_PATH . "/"), $CleanWritingFolders);
}
コード例 #2
0
function icms_module_update_content($module)
{
    $content_handler = icms_getModuleHandler('content', basename(dirname(dirname(__FILE__))), 'content');
    $gperm_handler = icms::handler('icms_member_groupperm');
    $table = new icms_db_legacy_updater_Table('icmscontent');
    if ($table->exists()) {
        echo '<code><b>Importing data from the core content manager</b></code><br />';
        $sql = "SELECT * FROM " . icms::$xoopsDB->prefix('icmscontent');
        $result = icms::$xoopsDB->query($sql);
        echo '<code>';
        while ($row = icms::$xoopsDB->fetchArray($result)) {
            $obj = $content_handler->create(true);
            $obj->setVar('content_pid', $row['content_supid']);
            $obj->setVar('content_uid', $row['content_uid']);
            $obj->setVar('content_title', $row['content_title']);
            $obj->setVar('content_body', $row['content_body']);
            $obj->setVar('content_css', $row['content_css']);
            $obj->setVar('content_tags', $row['content_tags']);
            $obj->setVar('content_visibility', $row['content_visibility']);
            $obj->setVar('content_published_date', (int) $row['content_created']);
            $obj->setVar('content_updated_date', date(_DATESTRING));
            $obj->setVar('content_weight', $row['content_weight']);
            $obj->setVar('short_url', $row['content_menu']);
            $obj->setVar('counter', $row['content_reads']);
            $obj->setVar('content_status', $row['content_status']);
            $obj->setVar('content_makesymlink', 0);
            $obj->setVar('content_showsubs', 1);
            $obj->setVar('content_cancomment', 1);
            $obj->setVar('dohtml', 1);
            $obj->setVar('dobr', 1);
            $obj->setVar('doimage', 1);
            $obj->setVar('dosmiley', 1);
            $obj->setVar('doxcode', 1);
            $content_handler->insert($obj, true);
            /**
             * Importing the permissions from the old page to add to the new one and deleting the old permissions
             */
            //Getting the groups that have read permission to this content page
            $groups = $gperm_handler->getGroupIds('content_read', $row['content_id']);
            //Deleting the permissions to the old page
            $criteria = new icms_db_criteria_Compo();
            $crit = new icms_db_criteria_Compo(new icms_db_criteria_Item('gperm_name', 'content_read'));
            $crit->add(new icms_db_criteria_Item('gperm_name', 'content_admin'), 'OR');
            $criteria->add($crit);
            $criteria->add(new icms_db_criteria_Item('gperm_itemid', $row['content_id']));
            $criteria->add(new icms_db_criteria_Item('gperm_modid', 1));
            $gperm_handler->deleteAll($criteria);
            //Adding permissions to allow the groups allowed to read the old content page to read the new content page
            foreach ($groups as $group) {
                $gperm_handler->addRight('content_read', $obj->getVar('content_id'), $group, $module->getVar("mid"));
            }
            /**
             * Deleting the symlinks from the old page
             */
            $seo = $obj->handler->makelink($obj);
            $url = str_replace(ICMS_URL . '/', '', $obj->handler->_moduleUrl . $obj->handler->_itemname . '.php?page=' . $seo);
            $old_seo = str_replace("-", "_", $seo);
            $symlink_handler = icms_getModuleHandler('pages', 'system');
            $criteria = new icms_db_criteria_Compo(new icms_db_criteria_Item('page_url', '%' . $old_seo, 'LIKE'));
            $criteria->add(new icms_db_criteria_Item('page_moduleid', 1));
            $symlinks_remove = $symlink_handler->getObjects($criteria);
            $criteria = new icms_db_criteria_Compo(new icms_db_criteria_Item('page_url', '%' . $url, 'LIKE'));
            $criteria->add(new icms_db_criteria_Item('page_moduleid', $module->getVar("mid")));
            $symlinks_added = $symlink_handler->getObjects($criteria);
            foreach ($symlinks_added as $symlink) {
                $symlinks_added = $symlink;
                break;
            }
            /**
             * If needed, changing the startpage to use the new symlink created
             */
            if (count($symlinks_remove) > 0) {
                foreach ($symlinks_remove as $symlink) {
                    $sql_preferences = 'SELECT * FROM ' . icms::$xoopsDB->prefix('config') . ' WHERE conf_name = "startpage" AND conf_value LIKE \'%"1-' . $symlink->getVar('page_id') . '"%\'';
                    $result_preferences = icms::$xoopsDB->query($sql_preferences);
                    if (icms::$xoopsDB->getRowsNum($result_preferences) > 0) {
                        $row_preferences = icms::$xoopsDB->fetchArray($result_preferences);
                        $arr = unserialize($row_preferences['conf_value']);
                        foreach ($arr as $k => $v) {
                            if ($v == '1-' . $symlink->getVar('page_id')) {
                                $arr[$k] = $module->getVar("mid") . '-' . $symlinks_added->getVar('page_id');
                            }
                        }
                        $value = serialize($arr);
                        icms::$xoopsDB->queryF('UPDATE ' . icms::$xoopsDB->prefix('config') . ' SET conf_value = \'' . $value . '\' WHERE conf_name = "startpage"');
                    }
                    $symlink_handler->delete($symlink, true);
                }
            }
            echo '&nbsp;&nbsp;-- <b>' . $row['content_title'] . '</b> successfully imported!<br />';
        }
        echo '</code>';
        echo '<code><b>Core Content Manager table successfully dropped.</b></code><br />';
        $table->dropTable();
        /**
         * Importing the core content manager blocks
         */
        echo '<code><b>Importing the core content manager blocks and configurations.</b></code><br />';
        $icms_block_handler = icms_getModuleHandler('blocksadmin');
        //Content Block
        $criteria = new icms_db_criteria_Compo(new icms_db_criteria_Item('show_func', 'content_content_display_show'));
        $content_content_block = $icms_block_handler->getObjects($criteria, false, true);
        $content_content_block = $content_content_block[0] ? $content_content_block[0] : false;
        $criteria = new icms_db_criteria_Compo(new icms_db_criteria_Item('show_func', 'b_content_show'));
        $content_blocks = $icms_block_handler->getObjects($criteria, true, true);
        foreach ($content_blocks as $block) {
            $nb = $content_content_block;
            $nb->setVar('visiblein', $block->getVar('visiblein', 'e'));
            $nb->setVar('options', $block->getVar('options', 'e'));
            $nb->setVar('title', $block->getVar('title', 'e'));
            $nb->setVar('side', $block->getVar('side', 'e'));
            $nb->setVar('weight', $block->getVar('weight', 'e'));
            $nb->setVar('visible', $block->getVar('visible', 'e'));
            $nb->setVar('isactive', $block->getVar('isactive', 'e'));
            $nb->setVar('last_modified', time());
            if ($block->getVar('block_type', 'D')) {
                //Cloned Version of the Block
                $nb->setVar('block_type', 'K');
                $nb->setVar('bid', 0);
                $nb->setNew();
            }
            if ($icms_block_handler->insert($nb, true)) {
                $criteria = new icms_db_criteria_Compo(new icms_db_criteria_Item('gperm_name', 'block_read'));
                $criteria->add(new icms_db_criteria_Item('gperm_itemid', $block->getVar('bid', 'e')));
                $criteria->add(new icms_db_criteria_Item('gperm_modid', 1));
                $perms = $gperm_handler->getObjects($criteria, true);
                foreach ($perms as $perm) {
                    $gperm_handler->addRight('block_read', $nb->getVar('bid'), $perm->getVar('gperm_groupid'), $module->getVar("mid"));
                    $gperm_handler->delete($perm);
                }
                echo '<code>Block <b>' . $block->getVar('title', 'e') . '</b> successfully imported.</code><br />';
            } else {
                echo '<code>Error while importing block <b>' . $block->getVar('title', 'e') . '</b>.</code><br />';
            }
            $icms_block_handler->delete($block, true);
        }
        //Content Menu Block
        $criteria = new icms_db_criteria_Compo(new icms_db_criteria_Item('show_func', 'content_content_menu_show'));
        $content_menu_block = $icms_block_handler->getObjects($criteria, false, true);
        $content_menu_block = $content_menu_block[0] ? $content_menu_block[0] : false;
        $criteria = new icms_db_criteria_Compo(new icms_db_criteria_Item('show_func', 'b_content_menu_show'));
        $criteria->add(new icms_db_criteria_Item('show_func', 'b_content_relmenu_show'), 'OR');
        $content_menu_blocks = $icms_block_handler->getObjects($criteria, true, true);
        foreach ($content_menu_blocks as $block) {
            $nb = $content_menu_block;
            $nb->setVar('visiblein', $block->getVar('visiblein', 'e'));
            $nb->setVar('options', $block->getVar('options', 'e') . '|0');
            $nb->setVar('title', $block->getVar('title', 'e'));
            $nb->setVar('side', $block->getVar('side', 'e'));
            $nb->setVar('weight', $block->getVar('weight', 'e'));
            $nb->setVar('visible', $block->getVar('visible', 'e'));
            $nb->setVar('isactive', $block->getVar('isactive', 'e'));
            $nb->setVar('last_modified', time());
            if ($block->getVar('block_type', 'D')) {
                //Cloned Version of the Block
                $nb->setVar('block_type', 'K');
                $nb->setVar('bid', 0);
                $nb->setNew();
            }
            if ($icms_block_handler->insert($nb, true)) {
                $criteria = new icms_db_criteria_Compo(new icms_db_criteria_Item('gperm_name', 'block_read'));
                $criteria->add(new icms_db_criteria_Item('gperm_itemid', $block->getVar('bid', 'e')));
                $criteria->add(new icms_db_criteria_Item('gperm_modid', 1));
                $perms = $gperm_handler->getObjects($criteria, true);
                foreach ($perms as $perm) {
                    $gperm_handler->addRight('block_read', $nb->getVar('bid'), $perm->getVar('gperm_groupid'), $module->getVar("mid"));
                    $gperm_handler->delete($perm);
                }
                echo '<code>Block <b>' . $block->getVar('title', 'e') . '</b> successfully imported.</code><br />';
            } else {
                echo '<code>Error while importing block <b>' . $block->getVar('title', 'e') . '</b>.</code><br />';
            }
            $icms_block_handler->delete($block, true);
        }
        if (is_dir(ICMS_ROOT_PATH . '/modules/system/admin/content')) {
            icms_unlinkRecursive(ICMS_ROOT_PATH . '/modules/system/admin/content');
            echo '<code>Folder removed successfully.</code><br />';
        }
        if (is_file(ICMS_ROOT_PATH . '/kernel/content.php')) {
            icms_deleteFile(ICMS_ROOT_PATH . '/kernel/content.php');
            echo '<code>File removed successfully.</code><br />';
        }
        /*if (is_file(ICMS_ROOT_PATH . '/content.php')) {
        		icms_deleteFile(ICMS_ROOT_PATH . '/content.php');
        		echo '<code>File removed successfully.</code><br />';
        		}*/
        if (is_file(ICMS_ROOT_PATH . '/modules/system/templates/system_content.html')) {
            icms_deleteFile(ICMS_ROOT_PATH . '/modules/system/templates/system_content.html');
            echo '<code>File removed successfully.</code><br />';
        }
        if (is_file(ICMS_ROOT_PATH . '/modules/system/templates/system_content_list.html')) {
            icms_deleteFile(ICMS_ROOT_PATH . '/modules/system/templates/system_content_list.html');
            echo '<code>File removed successfully.</code><br />';
        }
        icms_clean_folders(array('templates_c' => ICMS_ROOT_PATH . "/templates_c/", 'cache' => ICMS_ROOT_PATH . "/cache/"), true);
        $sql = sprintf("DELETE FROM %s WHERE confcat_name= '_MD_AM_CONTMANAGER'", icms::$xoopsDB->prefix('configcategory'));
        if (!($result = icms::$xoopsDB->queryF($sql))) {
            echo 'Error while removing category.';
        }
        $sql = sprintf("DELETE FROM %s WHERE (conf_modid = '0' AND conf_catid = '9')", icms::$xoopsDB->prefix('config'));
        if (!($result = icms::$xoopsDB->queryF($sql))) {
            echo 'Error while removing category items.';
        }
        echo '<code>Data from Core Content Manager successfully imported.</code><br />';
    }
    unset($table);
    $feedback = ob_get_clean();
    if (method_exists($module, "setMessage")) {
        $module->messages = $module->setMessage($feedback);
    } else {
        echo $feedback;
    }
    return true;
}
コード例 #3
0
ファイル: Handler.php プロジェクト: LeeGlendenning/formulize
 function upgradeObjectItem($dirname, $item)
 {
     $module_handler = icms_getModuleHandler($item, $dirname);
     if (!$module_handler) {
         return false;
     }
     $table = new icms_db_legacy_updater_Table($dirname . '_' . $item);
     $object = $module_handler->create();
     $objectVars = $object->getVars();
     if (!$table->exists()) {
         // table was never created, let's do it
         $structure = "";
         foreach ($objectVars as $key => $var) {
             if ($var['persistent']) {
                 $type = $this->getFieldTypeFromVar($var);
                 if ($key == $module_handler->keyName) {
                     $extra = "auto_increment";
                 } else {
                     $default = $this->getFieldDefaultFromVar($var);
                     if ($default != 'nodefault') {
                         $extra = "default '{$default}'";
                     } else {
                         $extra = false;
                     }
                 }
                 if ($extra) {
                     $structure .= "`{$key}` {$type} not null {$extra},";
                 } else {
                     $structure .= "`{$key}` {$type} not null,";
                 }
             }
         }
         $ModKeyNames = $module_handler->keyName;
         $structure .= "PRIMARY KEY  (";
         if (is_array($ModKeyNames)) {
             $structure .= "`" . $ModKeyNames[0] . "`";
             foreach ($ModKeyNames as $ModKeyName) {
                 $structure .= $ModKeyName != $ModKeyNames[0] ? ", `" . $ModKeyName . "`" : "";
             }
         } else {
             $structure .= "`" . $ModKeyNames . "`";
         }
         $structure .= ")";
         $table->setStructure($structure);
         if (!$this->updateTable($table)) {
             /**
              * @todo trap the errors
              */
         }
         foreach ($table->_messages as $msg) {
             $this->_messages[] = $msg;
         }
     } else {
         $existingFieldsArray = $table->getExistingFieldsArray();
         foreach ($objectVars as $key => $var) {
             if ($var['persistent']) {
                 if (!isset($existingFieldsArray[$key])) {
                     // the fiels does not exist, let's create it
                     $type = $this->getFieldTypeFromVar($var);
                     $default = $this->getFieldDefaultFromVar($var);
                     if ($default != 'nodefault') {
                         $extra = "default '{$default}'";
                     } else {
                         $extra = false;
                     }
                     $table->addNewField($key, "{$type} not null " . $extra);
                 } else {
                     // if field already exists, let's check if the definition is correct
                     $definition = strtolower($existingFieldsArray[$key]);
                     $type = $this->getFieldTypeFromVar($var);
                     if ($key == $module_handler->keyName) {
                         $extra = "auto_increment";
                     } else {
                         $default = $this->getFieldDefaultFromVar($var, $key);
                         if ($default != 'nodefault') {
                             $extra = "default '{$default}'";
                         } else {
                             $extra = false;
                         }
                     }
                     $actual_definition = "{$type} not null";
                     if ($extra) {
                         $actual_definition .= " {$extra}";
                     }
                     if ($definition != $actual_definition) {
                         $table->addAlteredField($key, $actual_definition);
                     }
                 }
             }
         }
         // check to see if there are some unused fields left in the table
         foreach ($existingFieldsArray as $key => $v) {
             if (!isset($objectVars[$key]) || !$objectVars[$key]['persistent']) {
                 $table->addDropedField($key);
             }
         }
         if (!$this->updateTable($table)) {
             /**
              * @todo trap the errors
              */
         }
     }
 }
コード例 #4
0
}
if (!$abortUpdate) {
    $newDbVersion = 27;
}
if ($dbVersion < $newDbVersion) {
    $handler = icms_getModulehandler('userrank', 'system');
    $handler->MoveAllRanksImagesToProperPath();
    $icmsDatabaseUpdater->updateModuleDBVersion($newDbVersion, 'system');
    echo sprintf(_DATABASEUPDATER_UPDATE_OK, icms_conv_nr2local($newDbVersion)) . '<br />';
}
if (!$abortUpdate) {
    $newDbVersion = 28;
}
if ($dbVersion < $newDbVersion) {
    $table = new icms_db_legacy_updater_Table('system_autotasks');
    if (!$table->exists()) {
        $table->setStructure("sat_id int(10) unsigned NOT NULL AUTO_INCREMENT,\n\t\t\t\t\tsat_name varchar(255) NOT NULL,\n\t\t\t\t\tsat_code text NOT NULL,\n\t\t\t\t\tsat_repeat int(11) NOT NULL,\n\t\t\t\t\tsat_interval int(11) NOT NULL,\n\t\t\t\t\tsat_onfinish smallint(2) NOT NULL,\n\t\t\t\t\tsat_enabled INT(1) NOT NULL,\n\t\t\t\t\tsat_lastruntime int(15) unsigned NOT NULL,\n\t\t\t\t\tsat_type varchar(100) NOT NULL DEFAULT 'custom',\n\t\t\t\t\tsat_addon_id int(2) unsigned zerofill DEFAULT NULL,\n\t\t\t\t\tPRIMARY KEY (sat_id),\n\t\t\t\t\tKEY sat_interval (sat_interval),\n\t\t\t\t\tKEY sat_lastruntime (sat_lastruntime),\n\t\t\t\t\tKEY sat_type (sat_type)\n\t\t\t\t\t");
        $table->createTable();
    }
    unset($table);
    if (getDbValue(icms::$xoopsDB, 'configcategory', 'confcat_name', 'confcat_name="_MD_AM_AUTOTASKS"') == FALSE) {
        icms::$xoopsDB->queryF(" INSERT INTO " . icms::$xoopsDB->prefix("configcategory") . " (confcat_id, confcat_name) VALUES (13, '_MD_AM_AUTOTASKS')");
    }
    $icmsDatabaseUpdater->insertConfig(ICMS_CONF, 'sourceeditor_default', '_MD_AM_SRCEDITOR_DEFAULT', 'editarea', '_MD_AM_SRCEDITOR_DEFAULT_DESC', 'editor_source', 'text', 16);
    $icmsDatabaseUpdater->insertConfig(IM_CONF_AUTOTASKS, 'autotasks_system', '_MD_AM_AUTOTASKS_SYSTEM', 'internal', '_MD_AM_AUTOTASKS_SYSTEMDSC', 'autotasksystem', 'text', 1);
    $icmsDatabaseUpdater->insertConfig(IM_CONF_AUTOTASKS, 'autotasks_helper', '_MD_AM_AUTOTASKS_HELPER', 'wget %url%', '_MD_AM_AUTOTASKS_HELPERDSC', 'select', 'text', 2);
    $config_id = icms::$xoopsDB->getInsertId();
    $sql = "INSERT INTO " . icms::$xoopsDB->prefix('configoption') . " (confop_id, confop_name, confop_value, conf_id)" . " VALUES" . " (NULL, 'PHP-CGI', 'php -f %path%', {$config_id}), " . " (NULL, 'wget', 'wget %url%', {$config_id}), " . " (NULL, 'Lynx', 'lynx --dump %url%', {$config_id})";
    if (!icms::$xoopsDB->queryF($sql)) {
        return false;
    }