Automattic\WooCommerce\Admin\API
Plugins::activate_plugins
Activate the requested plugin.
Метод класса: Plugins{}
Хуков нет.
Возвращает
\WP_Error|Массив. Plugin Status
Использование
$Plugins = new Plugins(); $Plugins->activate_plugins( $request );
- $request(WP_REST_Request) (обязательный)
- Full details about the request.
Код Plugins::activate_plugins() Plugins::activate plugins WC 10.4.3
public function activate_plugins( $request ) {
$plugins = explode( ',', $request['plugins'] );
if ( empty( $request['plugins'] ) || ! is_array( $plugins ) ) {
return new \WP_Error( 'woocommerce_rest_invalid_plugins', __( 'Plugins must be a non-empty array.', 'woocommerce' ), 404 );
}
if ( isset( $request['async'] ) && $request['async'] ) {
$job_id = PluginsHelper::schedule_activate_plugins( $plugins );
return array(
'data' => array(
'job_id' => $job_id,
'plugins' => $plugins,
),
'message' => __( 'Plugin activation has been scheduled.', 'woocommerce' ),
);
}
$data = PluginsHelper::activate_plugins( $plugins );
// Gather some plugin details for each activated plugin.
$plugin_details = array();
if ( is_array( $data['activated'] ) ) {
foreach ( $data['activated'] as $plugin_slug ) {
$plugin_data = PluginsHelper::get_plugin_data( $plugin_slug );
if ( empty( $plugin_data ) ) {
continue;
}
$plugin_details[ $plugin_slug ] = array(
'name' => $plugin_data['Name'],
'description' => $plugin_data['Description'],
'uri' => $plugin_data['PluginURI'],
'version' => $plugin_data['Version'],
);
}
}
return ( array(
'data' => array(
'activated' => $data['activated'],
'active' => $data['active'],
'plugin_details' => $plugin_details,
),
'errors' => $data['errors'],
'success' => count( $data['errors']->errors ) === 0,
'message' => count( $data['errors']->errors ) === 0
? __( 'Plugins were successfully activated.', 'woocommerce' )
: __( 'There was a problem activating some of the requested plugins.', 'woocommerce' ),
) );
}