modules = array(); $status->plugins = array(); $src = $parent->getParent()->getPath('source'); $manifest = $parent->getParent()->manifest; $plugins = $manifest->xpath('plugins/plugin'); foreach ($plugins as $plugin) { $name = (string)$plugin->attributes()->plugin; $group = (string)$plugin->attributes()->group; $path = $src.'/plugins/'.$group; if (JFolder::exists($src.'/plugins/'.$group.'/'.$name)) { $path = $src.'/plugins/'.$group.'/'.$name; } $installer = new JInstaller; $result = $installer->install($path); if ($result && $group != 'finder' && $group != 'josetta_ext') { if (JFile::exists(JPATH_SITE.'/plugins/'.$group.'/'.$name.'/'.$name.'.xml')) { JFile::delete(JPATH_SITE.'/plugins/'.$group.'/'.$name.'/'.$name.'.xml'); } JFile::move(JPATH_SITE.'/plugins/'.$group.'/'.$name.'/'.$name.'.j25.xml', JPATH_SITE.'/plugins/'.$group.'/'.$name.'/'.$name.'.xml'); } $query = "UPDATE #__extensions SET enabled=1 WHERE type='plugin' AND element=".$db->Quote($name)." AND folder=".$db->Quote($group); $db->setQuery($query); $db->query(); $status->plugins[] = array('name' => $name, 'group' => $group, 'result' => $result); } $modules = $manifest->xpath('modules/module'); foreach ($modules as $module) { $name = (string)$module->attributes()->module; $client = (string)$module->attributes()->client; if (is_null($client)) { $client = 'site'; } ($client == 'administrator') ? $path = $src.'/administrator/modules/'.$name : $path = $src.'/modules/'.$name; if($client == 'administrator') { $db->setQuery("SELECT id FROM #__modules WHERE `module` = ".$db->quote($name)); $isUpdate = (int)$db->loadResult(); } $installer = new JInstaller; $result = $installer->install($path); if ($result) { $root = $client == 'administrator' ? JPATH_ADMINISTRATOR : JPATH_SITE; if (JFile::exists($root.'/modules/'.$name.'/'.$name.'.xml')) { JFile::delete($root.'/modules/'.$name.'/'.$name.'.xml'); } JFile::move($root.'/modules/'.$name.'/'.$name.'.j25.xml', $root.'/modules/'.$name.'/'.$name.'.xml'); } $status->modules[] = array('name' => $name, 'client' => $client, 'result' => $result); if($client == 'administrator' && !$isUpdate) { $position = version_compare(JVERSION, '3.0', '<') && $name == 'mod_k2_quickicons'? 'icon' : 'cpanel'; $db->setQuery("UPDATE #__modules SET `position`=".$db->quote($position).",`published`='1' WHERE `module`=".$db->quote($name)); $db->query(); $db->setQuery("SELECT id FROM #__modules WHERE `module` = ".$db->quote($name)); $id = (int)$db->loadResult(); $db->setQuery("INSERT IGNORE INTO #__modules_menu (`moduleid`,`menuid`) VALUES (".$id.", 0)"); $db->query(); } } if (JFile::exists(JPATH_ADMINISTRATOR.'/components/com_k2/admin.k2.php')) { JFile::delete(JPATH_ADMINISTRATOR.'/components/com_k2/admin.k2.php'); } if (JFile::exists(JPATH_ADMINISTRATOR.'/components/com_k2/models/cpanel.php')) { JFile::delete(JPATH_ADMINISTRATOR.'/components/com_k2/models/cpanel.php'); } if (version_compare(JVERSION, '3.0', 'lt') && JFolder::exists(JPATH_ADMINISTRATOR.'/components/com_joomfish/contentelements')) { $elements = $manifest->xpath('joomfish/file'); foreach ($elements as $element) { JFile::copy($src.'/administrator/components/com_joomfish/contentelements/'.$element->data(), JPATH_ADMINISTRATOR.'/components/com_joomfish/contentelements/'.$element->data()); } } // Clean up empty entries in #__k2_users table caused by an issue in the K2 user plugin. Fix details: http://code.google.com/p/getk2/source/detail?r=1966 $query = "DELETE FROM #__k2_users WHERE userID = 0"; $db->setQuery($query); $db->query(); $this->installationResults($status); } public function uninstall($parent) { $db = JFactory::getDBO(); $status = new stdClass; $status->modules = array(); $status->plugins = array(); $manifest = $parent->getParent()->manifest; $plugins = $manifest->xpath('plugins/plugin'); foreach ($plugins as $plugin) { $name = (string)$plugin->attributes()->plugin; $group = (string)$plugin->attributes()->group; $query = "SELECT `extension_id` FROM #__extensions WHERE `type`='plugin' AND element = ".$db->Quote($name)." AND folder = ".$db->Quote($group); $db->setQuery($query); $extensions = $db->loadColumn(); if (count($extensions)) { foreach ($extensions as $id) { $installer = new JInstaller; $result = $installer->uninstall('plugin', $id); } $status->plugins[] = array('name' => $name, 'group' => $group, 'result' => $result); } } $modules = $manifest->xpath('modules/module'); foreach ($modules as $module) { $name = (string)$module->attributes()->module; $client = (string)$module->attributes()->client; $db = JFactory::getDBO(); $query = "SELECT `extension_id` FROM `#__extensions` WHERE `type`='module' AND element = ".$db->Quote($name).""; $db->setQuery($query); $extensions = $db->loadColumn(); if (count($extensions)) { foreach ($extensions as $id) { $installer = new JInstaller; $result = $installer->uninstall('module', $id); } $status->modules[] = array('name' => $name, 'client' => $client, 'result' => $result); } } $this->uninstallationResults($status); } public function update($type) { $db = JFactory::getDBO(); $fields = $db->getTableColumns('#__k2_categories'); if (!array_key_exists('language', $fields)) { $query = "ALTER TABLE #__k2_categories ADD `language` CHAR(7) NOT NULL"; $db->setQuery($query); $db->query(); $query = "ALTER TABLE #__k2_categories ADD INDEX (`language`)"; $db->setQuery($query); $db->query(); } $fields = $db->getTableColumns('#__k2_items'); if (!array_key_exists('featured_ordering', $fields)) { $query = "ALTER TABLE #__k2_items ADD `featured_ordering` INT(11) NOT NULL default '0' AFTER `featured`"; $db->setQuery($query); $db->query(); } if (!array_key_exists('language', $fields)) { $query = "ALTER TABLE #__k2_items ADD `language` CHAR(7) NOT NULL"; $db->setQuery($query); $db->query(); $query = "ALTER TABLE #__k2_items ADD INDEX (`language`)"; $db->setQuery($query); $db->query(); } if ($fields['video'] != 'text') { $query = "ALTER TABLE #__k2_items MODIFY `video` TEXT"; $db->setQuery($query); $db->query(); } if ($fields['introtext'] == 'text') { $query = "ALTER TABLE #__k2_items MODIFY `introtext` MEDIUMTEXT"; $db->setQuery($query); $db->query(); } if ($fields['fulltext'] == 'text') { $query = "ALTER TABLE #__k2_items MODIFY `fulltext` MEDIUMTEXT"; $db->setQuery($query); $db->query(); } $query = "SHOW INDEX FROM #__k2_items"; $db->setQuery($query); $indexes = $db->loadObjectList(); $indexExists = false; foreach ($indexes as $index) { if ($index->Key_name == 'search') $indexExists = true; } if (!$indexExists) { $query = "ALTER TABLE #__k2_items ADD FULLTEXT `search` (`title`,`introtext`,`fulltext`,`extra_fields_search`,`image_caption`,`image_credits`,`video_caption`,`video_credits`,`metadesc`,`metakey`)"; $db->setQuery($query); $db->query(); $query = "ALTER TABLE #__k2_items ADD FULLTEXT (`title`)"; $db->setQuery($query); $db->query(); } $query = "SHOW INDEX FROM #__k2_tags"; $db->setQuery($query); $indexes = $db->loadObjectList(); $indexExists = false; foreach ($indexes as $index) { if ($index->Key_name == 'name') $indexExists = true; } if (!$indexExists) { $query = "ALTER TABLE #__k2_tags ADD FULLTEXT (`name`)"; $db->setQuery($query); $db->query(); } $query = "SELECT COUNT(*) FROM #__k2_user_groups"; $db->setQuery($query); $num = $db->loadResult(); if ($num == 0) { $query = "INSERT INTO #__k2_user_groups (`id`, `name`, `permissions`) VALUES('', 'Registered', '{\"comment\":\"1\",\"frontEdit\":\"0\",\"add\":\"0\",\"editOwn\":\"0\",\"editAll\":\"0\",\"publish\":\"0\",\"inheritance\":0,\"categories\":\"all\"}')"; $db->setQuery($query); $db->Query(); $query = "INSERT INTO #__k2_user_groups (`id`, `name`, `permissions`) VALUES('', 'Site Owner', '{\"comment\":\"1\",\"frontEdit\":\"1\",\"add\":\"1\",\"editOwn\":\"1\",\"editAll\":\"1\",\"publish\":\"1\",\"inheritance\":1,\"categories\":\"all\"}')"; $db->setQuery($query); $db->Query(); } $fields = $db->getTableColumns('#__k2_users'); if (!array_key_exists('ip', $fields)) { $query = "ALTER TABLE `#__k2_users` ADD `ip` VARCHAR( 15 ) NOT NULL , ADD `hostname` VARCHAR( 255 ) NOT NULL , ADD `notes` TEXT NOT NULL"; $db->setQuery($query); $db->query(); } } private function installationResults($status) { $language = JFactory::getLanguage(); $language->load('com_k2'); $rows = 0; ?>