OwlCyberSecurity - MANAGER
Edit File: ImageController.php
<?php /** * Image Controller */ namespace Extendify\Draft\Controllers; defined('ABSPATH') || die('No direct access.'); use Extendify\Shared\Services\Sanitizer; /** * The controller for uploading images to the Media Library. */ class ImageController { /** * Upload the provided image * * @param \WP_REST_Request $request - The request. * @return \WP_REST_Response */ public static function uploadMedia(\WP_REST_Request $request) { if (! function_exists('\media_sideload_image')) { require_once ABSPATH . 'wp-admin/includes/media.php'; require_once ABSPATH . 'wp-admin/includes/file.php'; require_once ABSPATH . 'wp-admin/includes/image.php'; } $imageId = \media_sideload_image($request->get_param('source'), 0, null, 'id'); if ($request->get_param('alt_text')) { update_post_meta($imageId, '_wp_attachment_image_alt', Sanitizer::sanitizeText($request->get_param('alt_text'))); } if ($request->get_param('caption')) { wp_update_post( Sanitizer::sanitizeArray([ 'ID' => $imageId, 'post_excerpt' => $request->get_param('caption'), ]) ); } $imageObject = \get_post($imageId); $altText = (get_post_meta($imageId, '_wp_attachment_image_alt', true)) ? get_post_meta($imageId, '_wp_attachment_image_alt', true) : ''; return new \WP_REST_Response( [ 'id' => $imageId, // phpcs:ignore Squiz.NamingConventions.ValidVariableName.MemberNotCamelCaps 'caption' => ['raw' => $imageObject->post_excerpt], 'source_url' => wp_get_attachment_url($imageId), 'alt_text' => $altText, ] ); } }