WP_REST_Plugins_Controller::delete_item_permissions_check()publicWP 5.5.0

Checks if a given request has access to delete a specific plugin.

Method of the class: WP_REST_Plugins_Controller{}

No Hooks.

Return

true|WP_Error. True if the request has access to delete the item, WP_Error object otherwise.

Usage

$WP_REST_Plugins_Controller = new WP_REST_Plugins_Controller();
$WP_REST_Plugins_Controller->delete_item_permissions_check( $request );
$request(WP_REST_Request) (required)
Full details about the request.

Changelog

Since 5.5.0 Introduced.

WP_REST_Plugins_Controller::delete_item_permissions_check() code WP 6.5.2

public function delete_item_permissions_check( $request ) {
	if ( ! current_user_can( 'activate_plugins' ) ) {
		return new WP_Error(
			'rest_cannot_manage_plugins',
			__( 'Sorry, you are not allowed to manage plugins for this site.' ),
			array( 'status' => rest_authorization_required_code() )
		);
	}

	if ( ! current_user_can( 'delete_plugins' ) ) {
		return new WP_Error(
			'rest_cannot_manage_plugins',
			__( 'Sorry, you are not allowed to delete plugins for this site.' ),
			array( 'status' => rest_authorization_required_code() )
		);
	}

	$can_read = $this->check_read_permission( $request['plugin'] );

	if ( is_wp_error( $can_read ) ) {
		return $can_read;
	}

	return true;
}