diff options
Diffstat (limited to 'actions/admin')
| -rw-r--r-- | actions/admin/plugins/activate.php | 7 | ||||
| -rw-r--r-- | actions/admin/plugins/activate_all.php | 20 | ||||
| -rw-r--r-- | actions/admin/plugins/deactivate.php | 7 | ||||
| -rw-r--r-- | actions/admin/plugins/deactivate_all.php | 20 | 
4 files changed, 36 insertions, 18 deletions
diff --git a/actions/admin/plugins/activate.php b/actions/admin/plugins/activate.php index e04ee6298..feb986b27 100644 --- a/actions/admin/plugins/activate.php +++ b/actions/admin/plugins/activate.php @@ -39,7 +39,12 @@ elgg_invalidate_simplecache();  elgg_filepath_cache_reset();  if (count($activated_guids) === 1) { -	forward("admin/plugins/advanced#elgg-plugin-" . $plugin_guids[0]); +	$url = 'admin/plugins'; +	$query = (string)parse_url($_SERVER['HTTP_REFERER'], PHP_URL_QUERY); +	if ($query) { +		$url .= "?$query"; +	} +	forward($url . '#elgg-plugin-' . $plugin_guids[0]);  } else {  	forward(REFERER);  }
\ No newline at end of file diff --git a/actions/admin/plugins/activate_all.php b/actions/admin/plugins/activate_all.php index 0f0352877..19eb82142 100644 --- a/actions/admin/plugins/activate_all.php +++ b/actions/admin/plugins/activate_all.php @@ -1,21 +1,25 @@  <?php  /** - * Activates all installed and inactive plugins. + * Activates all specified installed and inactive plugins.   * - * All plugins in the mod/ directory are that aren't active are activated and the views + * All specified plugins in the mod/ directory are that aren't active are activated and the views   * cache and simplecache are invalidated.   *   * @package Elgg.Core   * @subpackage Administration.Plugins   */ -$plugins = elgg_get_plugins('inactive'); +$guids = get_input('guids'); +$guids = explode(',', $guids); -foreach ($plugins as $plugin) { -	if ($plugin->activate()) { -		//system_message(elgg_echo('admin:plugins:activate:yes', array($plugin->getManifest()->getName()))); -	} else { -		register_error(elgg_echo('admin:plugins:activate:no', array($plugin->getManifest()->getName()))); +foreach ($guids as $guid) { +	$plugin = get_entity($guid); +	if (!$plugin->isActive()) { +		if ($plugin->activate()) { +			//system_message(elgg_echo('admin:plugins:activate:yes', array($plugin->getManifest()->getName()))); +		} else { +			register_error(elgg_echo('admin:plugins:activate:no', array($plugin->getManifest()->getName()))); +		}  	}  } diff --git a/actions/admin/plugins/deactivate.php b/actions/admin/plugins/deactivate.php index 9ec620e13..6c9a55c15 100644 --- a/actions/admin/plugins/deactivate.php +++ b/actions/admin/plugins/deactivate.php @@ -38,7 +38,12 @@ elgg_invalidate_simplecache();  elgg_filepath_cache_reset();  if (count($plugin_guids) == 1) { -	forward("admin/plugins/advanced#elgg-plugin-" . $plugin_guids[0]); +	$url = 'admin/plugins'; +	$query = (string)parse_url($_SERVER['HTTP_REFERER'], PHP_URL_QUERY); +	if ($query) { +		$url .= "?$query"; +	} +	forward($url . '#elgg-plugin-' . $plugin_guids[0]);  } else {  	forward(REFERER);  } diff --git a/actions/admin/plugins/deactivate_all.php b/actions/admin/plugins/deactivate_all.php index 446cad8c0..436a3ad30 100644 --- a/actions/admin/plugins/deactivate_all.php +++ b/actions/admin/plugins/deactivate_all.php @@ -1,21 +1,25 @@  <?php  /** - * Disable all installed plugins. + * Disable all specified installed plugins.   * - * All plugins in the mod/ directory are disabled and the views cache and simplecache + * Specified plugins in the mod/ directory are disabled and the views cache and simplecache   * are reset.   *   * @package Elgg.Core   * @subpackage Administration.Plugins   */ -$plugins = elgg_get_plugins('active'); +$guids = get_input('guids'); +$guids = explode(',', $guids); -foreach ($plugins as $plugin) { -	if ($plugin->deactivate()) { -		//system_message(elgg_echo('admin:plugins:deactivate:yes', array($plugin->getManifest()->getName()))); -	} else { -		register_error(elgg_echo('admin:plugins:deactivate:no', array($plugin->getManifest()->getName()))); +foreach ($guids as $guid) { +	$plugin = get_entity($guid); +	if ($plugin->isActive()) { +		if ($plugin->deactivate()) { +			//system_message(elgg_echo('admin:plugins:activate:yes', array($plugin->getManifest()->getName()))); +		} else { +			register_error(elgg_echo('admin:plugins:deactivate:no', array($plugin->getManifest()->getName()))); +		}  	}  }  | 
