Skip to content

Instantly share code, notes, and snippets.

@viankakrisna
Last active January 3, 2017 08:27
Show Gist options
  • Save viankakrisna/ef5912e7f6908429b3fcf0418a3f0b03 to your computer and use it in GitHub Desktop.
Save viankakrisna/ef5912e7f6908429b3fcf0418a3f0b03 to your computer and use it in GitHub Desktop.
<?php
/*
Plugin Name: Unauthorized Media Upload
*/
add_action('rest_api_init', function () {
register_rest_route('unauthorized-upload/v1', '/media', array(
'methods' => 'POST',
'callback' => 'unauthorized_upload',
));
});
function unauthorized_upload() {
if (!function_exists('wp_handle_upload')) {
require_once ABSPATH . 'wp-admin/includes/file.php';
}
$upload_overrides = array('test_form' => false);
$data = array();
foreach ($_FILES as $key => $uploadedfile) {
$movefile = wp_handle_upload($uploadedfile, $upload_overrides);
$data[$key] = $movefile;
}
// Create the response object
$response = new WP_REST_Response($data);
// Add a custom status code
$response->set_status(201);
return $response;
}
function insert_to_media($filename, $parent_post_id) {
// Check the type of file. We'll use this as the 'post_mime_type'.
$filetype = wp_check_filetype(basename($filename), null);
// Get the path to the upload directory.
$wp_upload_dir = wp_upload_dir();
// Prepare an array of post data for the attachment.
$attachment = array(
'guid' => $wp_upload_dir['url'] . '/' . basename($filename),
'post_mime_type' => $filetype['type'],
'post_title' => preg_replace('/\.[^.]+$/', '', basename($filename)),
'post_content' => '',
'post_status' => 'inherit',
);
// Insert the attachment.
$attach_id = wp_insert_attachment($attachment, $filename, $parent_post_id);
if ($parent_post_id) {
// Make sure that this file is included, as wp_generate_attachment_metadata() depends on it.
require_once ABSPATH . 'wp-admin/includes/image.php';
// Generate the metadata for the attachment, and update the database record.
$attach_data = wp_generate_attachment_metadata($attach_id, $filename);
wp_update_attachment_metadata($attach_id, $attach_data);
set_post_thumbnail($parent_post_id, $attach_id);
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment