WP_REST_Attachments_Controller::upload_from_file()protectedWP 4.7.0

Handles an upload via multipart/form-data ($_FILES).

Method of the class: WP_REST_Attachments_Controller{}

No Hooks.

Return

Array|WP_Error. Data from wp_handle_upload().

Usage

// protected - for code of main (parent) or child class
$result = $this->upload_from_file( $files, $headers, $time );
$files(array) (required)
Data from the $_FILES superglobal.
$headers(array) (required)
HTTP headers from the request.
$time(string|null)
Time formatted in 'yyyy/mm'.
Default: null

Changelog

Since 4.7.0 Introduced.
Since 6.6.0 Added the $time parameter.

WP_REST_Attachments_Controller::upload_from_file() code WP 6.6.1

protected function upload_from_file( $files, $headers, $time = null ) {
	if ( empty( $files ) ) {
		return new WP_Error(
			'rest_upload_no_data',
			__( 'No data supplied.' ),
			array( 'status' => 400 )
		);
	}

	// Verify hash, if given.
	if ( ! empty( $headers['content_md5'] ) ) {
		$content_md5 = array_shift( $headers['content_md5'] );
		$expected    = trim( $content_md5 );
		$actual      = md5_file( $files['file']['tmp_name'] );

		if ( $expected !== $actual ) {
			return new WP_Error(
				'rest_upload_hash_mismatch',
				__( 'Content hash did not match expected.' ),
				array( 'status' => 412 )
			);
		}
	}

	// Pass off to WP to handle the actual upload.
	$overrides = array(
		'test_form' => false,
	);

	// Bypasses is_uploaded_file() when running unit tests.
	if ( defined( 'DIR_TESTDATA' ) && DIR_TESTDATA ) {
		$overrides['action'] = 'wp_handle_mock_upload';
	}

	$size_check = self::check_upload_size( $files['file'] );
	if ( is_wp_error( $size_check ) ) {
		return $size_check;
	}

	// Include filesystem functions to get access to wp_handle_upload().
	require_once ABSPATH . 'wp-admin/includes/file.php';

	$file = wp_handle_upload( $files['file'], $overrides, $time );

	if ( isset( $file['error'] ) ) {
		return new WP_Error(
			'rest_upload_unknown_error',
			$file['error'],
			array( 'status' => 500 )
		);
	}

	return $file;
}