%PDF- %PDF-
Direktori : /home/l/a/n/langpiergz/www/wp-content/plugins/wpdiscuz/utils/ |
Current File : /home/l/a/n/langpiergz/www/wp-content/plugins/wpdiscuz/utils/class.WpdiscuzHelperUpload.php |
<?php if (!defined("ABSPATH")) { exit(); } class WpdiscuzHelperUpload implements WpDiscuzConstants { /** * @var $options WpdiscuzOptions */ private $options; /** * @var $dbManager WpdiscuzDBManager */ private $dbManager; /** * @var $wpdiscuzForm wpDiscuzForm */ private $wpdiscuzForm; /** * @var $helper WpdiscuzHelper */ private $helper; private $wpUploadsPath; private $wpUploadsUrl; private $wpUploadsSubdir; private $currentUser; private $requestUri; private $mimeTypes = []; public function __construct($options, $dbManager, $wpdiscuzForm, $helper) { $this->options = $options; $this->dbManager = $dbManager; $this->wpdiscuzForm = $wpdiscuzForm; $this->helper = $helper; $this->requestUri = isset($_SERVER["REQUEST_URI"]) ? $_SERVER["REQUEST_URI"] : ""; if ($this->options->content["wmuIsEnabled"]) { add_action("init", [$this, "initUploadsFolderVars"]); add_filter("wpdiscuz_editor_buttons_html", [&$this, "uploadButtons"], 1, 2); add_action("wpdiscuz_button_actions", [&$this, "uploadPreview"], 1, 2); add_filter("wpdiscuz_comment_list_args", [&$this, "commentListArgs"]); add_filter("comment_text", [&$this, "commentText"], 100, 3); add_filter("wpdiscuz_after_read_more", [&$this, "afterReadMore"], 100, 3); add_action("comment_post", [&$this, "addAttachments"]); add_filter("wpdiscuz_comment_post", [&$this, "postComment"], 10); add_filter("wpdiscuz_ajax_callbacks", [&$this, "wmuImageCallbacks"], 10); add_action("wp_ajax_wmuUploadFiles", [&$this, "uploadFiles"]); add_action("wp_ajax_nopriv_wmuUploadFiles", [&$this, "uploadFiles"]); add_action("wp_ajax_wmuRemoveAttachmentPreview", [&$this, "removeAttachmentPreview"]); add_action("wp_ajax_nopriv_wmuRemoveAttachmentPreview", [&$this, "removeAttachmentPreview"]); add_action("wp_ajax_wmuDeleteAttachment", [&$this, "deleteAttachment"]); add_action("wp_ajax_nopriv_wmuDeleteAttachment", [&$this, "deleteAttachment"]); add_action("delete_comment", [&$this, "deleteLinkedAttachments"], 20); add_action("delete_attachment", [&$this, "deleteAttachmentIdFromMeta"], 20); add_filter("wpdiscuz_privacy_personal_data_export", [&$this, "exportPersonalData"], 10, 2); add_filter("wpdiscuz_do_export_personal_data", "__return_true"); /* CRON JOBS */ add_action("init", [&$this, "registerJobThumbnailsViaCron"]); add_action("init", [&$this, "deregisterJobThumbnailsViaCron"]); add_action(self::DELETE_UNATTACHED_FILES_ACTION, [&$this, "deleteUnattachedFiles"]); add_action(self::GENERATE_THUMBNAILS_ACTION, [&$this, "generateThumbnails"]); add_filter("cron_schedules", [&$this, "setIntervalThumbnailsViaCron"]); /* /CRON JOBS */ add_action("restrict_manage_posts", [$this, "wpdiscuzMediaFiler"]); add_filter("parse_query", [$this, "getWpdiscuzMedia"]); // add_filter("manage_media_columns", [$this, "wpdiscuzMediaCommentColumn"], 10, 2); } } public function initUploadsFolderVars() { $wpUploadsDir = wp_upload_dir(); $this->wpUploadsSubdir = $wpUploadsDir["subdir"]; $wpdiscuzUploadsFolder = apply_filters("wpdiscuz_uploads_folder", ""); $this->wpUploadsPath = $wpUploadsDir["basedir"] . "/" . trim($wpdiscuzUploadsFolder, "/\\") . $this->wpUploadsSubdir; $this->wpUploadsUrl = $this->helper->fixURLScheme($wpUploadsDir["baseurl"] . "/" . trim($wpdiscuzUploadsFolder, "/\\") . $this->wpUploadsSubdir); if (!is_dir($this->wpUploadsPath)) { wp_mkdir_p($this->wpUploadsPath); } } public function uploadButtons($html, $uniqueId) { if ($this->isUploadingAllowed()) { $type = apply_filters("wpdiscuz_mu_upload_type", ""); $faIcon = apply_filters("wpdiscuz_mu_upload_icon", "far fa-image"); $allowedExts = apply_filters("wpdiscuz_mu_allowed_extensions", "accept='image/*'"); $html .= "<span class='wmu-upload-wrap' wpd-tooltip='" . esc_attr($this->options->getPhrase("wmuAttachImage", ["unique_id" => $uniqueId])) . "' wpd-tooltip-position='" . (!is_rtl() ? 'left' : 'right') . "'>"; $html .= "<label class='wmu-add'>"; $html .= "<i class='$faIcon'></i>"; $html .= "<input style='display:none;' class='wmu-add-files' type='file' name='" . self::INPUT_NAME . "[]' $type $allowedExts/>"; $html .= "</label>"; $html .= "</span>"; } return $html; } public function uploadPreview($uniqueId, $currentUser) { if ($this->isUploadingAllowed()) { $html = "<div class='wmu-action-wrap'>"; $html .= "<div class='wmu-tabs wmu-" . self::KEY_IMAGES . "-tab wmu-hide'></div>"; $html .= apply_filters("wpdiscuz_mu_tabs", ""); $html .= "</div>"; echo $html; } } public function commentText($content, $comment) { if ($comment && strpos($this->requestUri, self::PAGE_COMMENTS) !== false && $this->options->content["wmuIsShowFilesDashboard"]) { $content = $this->getAttachments($content, $comment); } return $content; } public function afterReadMore($content, $comment) { return $this->getAttachments($content, $comment); } private function getAttachments($content, $comment) { $attachments = get_comment_meta($comment->comment_ID, self::METAKEY_ATTACHMENTS, true); if ($attachments && is_array($attachments)) { // get files from jetpack CDN on ajax calls add_filter("jetpack_photon_admin_allow_image_downsize", "__return_true"); $content .= "<div class='wmu-comment-attachments'>"; foreach ($attachments as $key => $ids) { if (!empty($ids)) { $attachIds = array_map("intval", $ids); $type = (count($attachIds) > 1) ? "multi" : "single"; if ($key == self::KEY_IMAGES) { $imgHtml = $this->getAttachedImages($attachIds, $this->currentUser); $content .= "<div class='wmu-attached-images wmu-count-" . $type . "'>" . $imgHtml . "</div>"; } $content .= apply_filters("wpdiscuz_mu_get_attachments", "", $attachIds, $this->currentUser, $key); } } $content .= "</div>"; } return $content; } public function getAttachedImages($attachIds, $currentUser = null, $size = "full", $lazyLoad = true) { global $pagenow; $images = ""; if ($attachIds) { $attachments = get_posts(["include" => $attachIds, "post_type" => "attachment", "orderby" => "ID", "order" => "asc"]); if ($attachments && is_array($attachments)) { $style = ""; if ($pagenow == self::PAGE_COMMENTS) { $style .= "max-height:100px;"; $style .= "width:auto;"; $height = ""; $width = ""; $secondarySizeKey = ""; $secondarySize = ""; } else { if (count($attachments) > 1) { $whData = apply_filters("wpdiscuz_mu_image_sizes", ["width" => 90, "height" => 90]); $width = $whData["width"]; $height = $whData["height"]; } else { $width = $this->options->content["wmuSingleImageWidth"]; $height = $this->options->content["wmuSingleImageHeight"]; } if (intval($width)) { $primarySizeKey = "width"; $primarySize = $width; $secondarySizeKey = "height"; $secondarySize = $height; } else { $primarySizeKey = "height"; $primarySize = $height; $secondarySizeKey = "width"; $secondarySize = $width; } $style .= "max-$primarySizeKey:{$primarySize}px;"; $style .= "$primarySizeKey:{$primarySize}px;"; $style .= "$secondarySizeKey:auto;"; } if ($pagenow == self::PAGE_COMMENTS) { $size = "thumbnail"; } else { foreach ($this->getImageSizes() as $sizeKey => $sizeValue) { if (!intval($sizeValue["height"]) && !intval($sizeValue["width"])) { continue; } if ($sizeValue[$primarySizeKey] > 0 && $primarySize <= $sizeValue[$primarySizeKey]) { $size = $sizeKey; break; } else { $size = "full"; } } } $lightboxCls = $this->options->content["wmuIsLightbox"] ? "wmu-lightbox" : ""; $wmuLazyLoadImages = apply_filters("wpdiscuz_mu_lazyload_images", ""); foreach ($attachments as $attachment) { $deleteHtml = $this->getDeleteHtml($currentUser, $attachment, "image"); $url = $this->helper->fixURLScheme(wp_get_attachment_image_url($attachment->ID, "full")); $srcData = wp_get_attachment_image_src($attachment->ID, $size); $srcData = wp_get_attachment_image_src($attachment->ID, $size); $src = $this->helper->fixURLScheme($srcData[0]); if ($wmuLazyLoadImages && $lazyLoad) { $srcValue = ""; $dataSrcValue = $src; } else { $srcValue = $src; $dataSrcValue = ""; } $attachmentId = self::encrypt($attachment->ID); $alt = get_post_meta($attachment->ID, "_wp_attachment_image_alt", true); $images .= "<div class='wmu-attachment wmu-attachment-$attachmentId'>"; if ($lightboxCls) { $images .= "<a href='$url' class='wmu-attached-image-link $lightboxCls'>"; $images .= "<img style='$style' alt='" . esc_attr($alt) . "' title='" . esc_attr($attachment->post_excerpt) . "' id='wmu-attachemnt-$attachmentId' class='attachment-$size size-$size wmu-attached-image' src='$srcValue' wmu-data-src='$dataSrcValue' $secondarySizeKey='$secondarySize' />"; $images .= "</a>"; } else { $images .= apply_filters("wpdiscuz_mu_attached_image_before", "<a href='$url' class='wmu-attached-image-link' target='_blank' rel='noreferrer ugc'>", $attachment->ID); $images .= "<img style='$style' alt='" . esc_attr($alt) . "' title='" . esc_attr($attachment->post_excerpt) . "' id='wmu-attachemnt-$attachmentId' class='attachment-$size size-$size wmu-attached-image' src='$srcValue' wmu-data-src='$dataSrcValue' $secondarySizeKey='$secondarySize' />"; $images .= apply_filters("wpdiscuz_mu_attached_image_after", "</a>", $attachment->ID); } $images .= $deleteHtml; $images .= "</div>"; } } } return $images; } public function addAttachments($cId) { if ($cId && !empty($_POST["wmu_attachments"])) { $wmuAttachments = json_decode(stripslashes($_POST["wmu_attachments"]), JSON_OBJECT_AS_ARRAY); if ($wmuAttachments && is_array($wmuAttachments)) { $attachments = []; foreach ($wmuAttachments as $key => $data) { if ($data && is_array($data)) { foreach ($data as $attachmentId) { if (!empty($attachmentId) && ($attachmentId = self::decrypt($attachmentId))) { $attachments[$key][] = $attachmentId; update_post_meta($attachmentId, self::METAKEY_ATTCHMENT_COMMENT_ID, $cId); } } } } if ($attachments) { update_comment_meta($cId, self::METAKEY_ATTACHMENTS, $attachments); } } } } public function postComment($response) { $response["callbackFunctions"][] = "wmuHideAll"; $response["callbackFunctions"][] = "wmuAddLightBox"; return $response; } public function wmuImageCallbacks($response) { $response["callbackFunctions"][] = "wmuAddLightBox"; return $response; } public function uploadFiles() { $this->helper->validateNonce(); $response = ["errorCode" => "", "error" => "", "errors" => [], "attachmentsHtml" => "", "previewsData" => ""]; $postId = WpdiscuzHelper::sanitize(INPUT_POST, "postId", FILTER_SANITIZE_NUMBER_INT, 0); $uniqueId = WpdiscuzHelper::sanitize(INPUT_POST, "uniqueId", "FILTER_SANITIZE_STRING"); if (!$postId) { $response["errorCode"] = "msgPostIdNotExists"; wp_send_json_error($response); } if (empty($_FILES[self::INPUT_NAME])) { $response["errorCode"] = "msgEmptyFile"; wp_send_json_error($response); } $files = $this->combineArray($_FILES[self::INPUT_NAME]); $filesCount = count($files); $allowedCount = apply_filters("wpdiscuz_mu_file_count", 1); if ($filesCount > $allowedCount) { $response["errorCode"] = "wmuPhraseMaxFileCount"; wp_send_json_error($response); } $post = get_post($postId); if (!$this->isUploadingAllowed($post)) { $response["errorCode"] = "msgUploadingNotAllowed"; wp_send_json_error($response); } // all expected data are correct, continue uploading $attachmentIds = apply_filters("wpdiscuz_mu_attachment_ids", [self::KEY_IMAGES => []]); $attachmentsData = apply_filters("wpdiscuz_mu_attachments_data", [self::KEY_IMAGES => []]); $wmuAttachmentsData = empty($_POST["wmuAttachmentsData"]) ? "" : json_decode(stripslashes(sanitize_text_field($_POST["wmuAttachmentsData"])), JSON_OBJECT_AS_ARRAY); if ($wmuAttachmentsData && is_array($wmuAttachmentsData)) { if ($allowedCount == 1) { foreach ($wmuAttachmentsData as $key => $value) { if ($value && is_array($value)) { foreach ($value as $v) { wp_delete_attachment($v["id"], true); } } } } else { foreach ($wmuAttachmentsData as $key => $value) { if ($value && is_array($value)) { $filesCount += count($value); foreach ($value as $v) { $attachmentIds[$key][] = $v["id"]; $attachmentsData[$key][] = $v; } } } } } if ($filesCount > $allowedCount) { $response["errorCode"] = "wmuPhraseMaxFileCount"; wp_send_json_error($response); } $postSize = empty($_SERVER["CONTENT_LENGTH"]) ? 0 : intval($_SERVER["CONTENT_LENGTH"]); if ($postSize && $postSize > $this->options->wmuPostMaxSize) { $response["errorCode"] = "wmuPhrasePostMaxSize"; wp_send_json_error($response); } $size = 0; foreach ($files as $file) { $size += empty($file["size"]) ? 0 : intval($file["size"]); } if ($size > ($this->options->content["wmuMaxFileSize"] * 1024 * 1024)) { $response["errorCode"] = "wmuPhraseMaxFileSize"; wp_send_json_error($response); } $this->includeImageFunctions(); foreach ($files as $file) { $error = false; $extension = strtolower(pathinfo($file["name"], PATHINFO_EXTENSION)); if ($mimeType = $this->isImage($file)) { if ((strpos($mimeType, "image/") !== false) && empty($extension)) { $file["name"] .= ".jpg"; $extension = "jpg"; } } else { $mimeType = $this->getMimeType($file, $extension); } if ($this->isAllowedFileType($mimeType, $extension)) { if (empty($extension)) { if (strpos($mimeType, "image/") === false) { foreach ($this->mimeTypes as $ext => $mimes) { if (in_array($mimeType, explode("|", $mimes))) { $file["name"] .= "." . $ext; } } } } $file["type"] = $mimeType; } else { $error = true; $response["errors"][] = $file["name"] . " " . (current_user_can("manage_options") ? "(mimetype - " . $mimeType . ") " : "") . "- " . esc_html($this->options->getPhrase("wmuPhraseNotAllowedFile")); } do_action("wpdiscuz_mu_preupload", $file); if (!$error) { $attachmentData = $this->uploadSingleFile($file); if ($attachmentData) { if (strpos($file["type"], "image/") !== false) { $attachmentIds[self::KEY_IMAGES][] = $attachmentData["id"]; $attachmentsData[self::KEY_IMAGES][] = $attachmentData; } else { $attachmentIds = apply_filters("wpdiscuz_mu_add_attachment_ids", $attachmentIds, $attachmentData, $file); $attachmentsData = apply_filters("wpdiscuz_mu_add_attachments_data", $attachmentsData, $attachmentData, $file); } } } } if ($attachmentIds) { $response["attachmentsHtml"] = "<div class='wmu-attached-data-info wmu-hide'>"; // $response["attachmentsHtml"] .= "<input class='wmu-attachments-ids' type='hidden' name='wmu_attachments' value='" . esc_attr(json_encode($attachmentIds)) . "'/>"; $response["attachmentsHtml"] .= "<textarea class='wmu-attachments-ids' name='wmu_attachments'>" . esc_attr(json_encode($attachmentIds)) . "</textarea>"; $response["attachmentsHtml"] .= "<textarea class='wmu-attachments-data'>" . esc_attr(json_encode($attachmentsData)) . "</textarea>"; // $response["attachmentsHtml"] .= "<input class='wmu-attachments-data' type='hidden' value='" . esc_attr(json_encode($attachmentsData)) . "'/>"; $response["attachmentsHtml"] .= "</div>"; $response["previewsData"] = $attachmentsData; if ($allowedCount == 1) { $response["tooltip"] = esc_html($this->options->getPhrase("wmuChangeImage", ["unique_id" => $uniqueId])); } } wp_send_json_success($response); } public static function encrypt($data) { $key = __FILE__; $plaintext = $data; $ivlen = openssl_cipher_iv_length($cipher = 'AES-128-CBC'); $iv = openssl_random_pseudo_bytes($ivlen); $ciphertext_raw = openssl_encrypt($plaintext, $cipher, $key, $options = OPENSSL_RAW_DATA, $iv); $hmac = hash_hmac('sha256', $ciphertext_raw, $key, $as_binary = true); $ciphertext = base64_encode($iv . $hmac . $ciphertext_raw); return $ciphertext; } public static function decrypt($data) { $key = __FILE__; $c = base64_decode($data); $ivlen = openssl_cipher_iv_length($cipher = 'AES-128-CBC'); $iv = substr($c, 0, $ivlen); $hmac = substr($c, $ivlen, $sha2len = 32); $ciphertext_raw = substr($c, $ivlen + $sha2len); $original_plaintext = openssl_decrypt($ciphertext_raw, $cipher, $key, $options = OPENSSL_RAW_DATA, $iv); $calcmac = hash_hmac('sha256', $ciphertext_raw, $key, $as_binary = true); if ($original_plaintext && hash_equals($hmac, $calcmac)) { return $original_plaintext; } return false; } private function isAllowedFileType($mimeType, $extension) { $isAllowed = false; if (!empty($this->mimeTypes) && is_array($this->mimeTypes)) { foreach ($this->mimeTypes as $ext => $mimes) { if ($ext === $extension) { if ($isAllowed = in_array($mimeType, explode("|", $mimes))) { break; } } } } return $isAllowed; } private function getMimeType($file, $extension) { $mimeType = ""; if (function_exists("finfo_open") && function_exists("finfo_file")) { $finfo = finfo_open(FILEINFO_MIME_TYPE); $mimeType = finfo_file($finfo, $file["tmp_name"]); } elseif (function_exists("mime_content_type")) { $mimeType = mime_content_type($file["tmp_name"]); } elseif ($extension) { foreach ($this->mimeTypes as $ext => $mimeTypes) { $exp = explode("|", $mimeTypes); if ($extension === $ext) { $mimeType = $exp[0]; break; } } } return $mimeType; } public function removeAttachmentPreview() { $this->helper->validateNonce(); $response = ["errorCode" => "", "error" => "", "attachmentsHtml" => ""]; $attachmentId = WpdiscuzHelper::sanitize(INPUT_POST, "attachmentId", "FILTER_SANITIZE_STRING", 0); $attachmentId = self::decrypt($attachmentId); $uniqueId = WpdiscuzHelper::sanitize(INPUT_POST, "uniqueId", "FILTER_SANITIZE_STRING"); $attachment = get_post($attachmentId); // add attachment not exists message in wpdoptions > jsargs if (!$attachment) { $response["errorCode"] = "wmuMsgAttachmentNotExists"; wp_send_json_error($response); } if (empty($this->currentUser->ID)) { $this->setCurrentUser(WpdiscuzHelper::getCurrentUser()); } $ip = WpdiscuzHelper::getRealIPAddr(); $ownerIp = get_post_meta($attachmentId, self::METAKEY_ATTCHMENT_OWNER_IP, true); if (!current_user_can("manage_options") && (($attachment->post_author != 0 && $attachment->post_author != $this->currentUser->ID) || ($attachment->post_author == 0 && $ownerIp !== $ip))) { $response["errorCode"] = "msgPermissionDenied"; wp_send_json_error($response); } $filesCount = 0; $attachmentIds = apply_filters("wpdiscuz_mu_attachment_ids", [self::KEY_IMAGES => []]); $attachmentsData = apply_filters("wpdiscuz_mu_attachments_data", [self::KEY_IMAGES => []]); wp_delete_attachment($attachmentId, true); $wmuAttachmentsData = empty($_POST["wmuAttachmentsData"]) ? "" : json_decode(stripslashes(sanitize_text_field($_POST["wmuAttachmentsData"])), JSON_OBJECT_AS_ARRAY); if ($wmuAttachmentsData && is_array($wmuAttachmentsData)) { foreach ($wmuAttachmentsData as $key => $value) { if ($value && is_array($value)) { foreach ($value as $v) { $attachmentDataId = self::decrypt($v["id"]); if ($attachmentDataId != $attachmentId) { $attachmentIds[$key][] = $v["id"]; $attachmentsData[$key][] = $v; $filesCount++; } } } } } if ($filesCount) { $response["attachmentsHtml"] = "<div class='wmu-attached-data-info wmu-hide'>"; $response["attachmentsHtml"] .= "<input class='wmu-attachments-ids' type='hidden' name='wmu_attachments' value='" . esc_attr(json_encode($attachmentIds)) . "'/>"; $response["attachmentsHtml"] .= "<input class='wmu-attachments-data' type='hidden' value='" . esc_attr(json_encode($attachmentsData)) . "'/>"; $response["attachmentsHtml"] .= "</div>"; } else { $response["tooltip"] = esc_html($this->options->getPhrase("wmuAttachImage", ["unique_id" => $uniqueId])); } wp_send_json_success($response); } public function deleteAttachment() { $this->helper->validateNonce(); $response = ["errorCode" => "", "error" => ""]; $attachmentId = isset($_POST["attachmentId"]) ? trim($_POST["attachmentId"]) : 0; $attachmentId = self::decrypt($attachmentId); $attachment = get_post($attachmentId); $commentId = get_post_meta($attachmentId, self::METAKEY_ATTCHMENT_COMMENT_ID, true); $comment = get_comment($commentId); if ($attachment && $comment) { if (empty($this->currentUser->ID)) { $this->setCurrentUser(WpdiscuzHelper::getCurrentUser()); } $args = []; if (isset($this->currentUser->user_email)) { $args["comment_author_email"] = $this->currentUser->user_email; } if (current_user_can("moderate_comments") || ($this->helper->isCommentEditable($comment) && $this->helper->canUserEditComment($comment, $this->currentUser, $args))) { wp_delete_attachment($attachmentId, true); do_action("wpdiscuz_reset_comments_extra_cache", $comment->comment_post_ID); wp_send_json_success($response); } } else { $response["error"] = esc_html__("The attachment does not exist", "wpdiscuz"); wp_send_json_error($response); } } public function isUploadingAllowed($postObj = null) { global $post; $gPost = $postObj ? $postObj : $post; $isAllowed = false; $this->mimeTypes = apply_filters("wpdiscuz_mu_mime_types", $this->options->content["wmuMimeTypes"]); if ($this->isAllowedPostType($gPost) && !empty($this->mimeTypes)) { $currentUser = WpdiscuzHelper::getCurrentUser(); $isUserLoggedIn = !empty($currentUser->ID); $isGuestAllowed = !$isUserLoggedIn && $this->options->content["wmuIsGuestAllowed"]; $isUserAllowed = $isUserLoggedIn && $this->canUserUpload($currentUser); if ($isGuestAllowed || $isUserAllowed) { $isAllowed = true; } } return $isAllowed; } public function isAllowedPostType($post) { $allowedPosttypes = apply_filters("wpdiscuz_mu_allowed_posttypes", $this->getDefaultPostTypes()); return ($post && is_object($post) && isset($post->post_type) && in_array($post->post_type, $allowedPosttypes)); } public function canUserUpload($currentUser) { $bool = false; if ($currentUser && $currentUser->ID) { $userRoles = $currentUser->roles; $allowedRoles = apply_filters("wpdiscuz_mu_allowed_roles", $this->getDefaultRoles()); foreach ($userRoles as $role) { if (in_array($role, $allowedRoles)) { $bool = true; break; } } } return $bool; } private function uploadSingleFile($file) { $currentTime = WpdiscuzHelper::getMicrotime(); $attachmentData = []; $path = $this->wpUploadsPath . "/"; $fName = $file["name"]; $pathInfo = pathinfo($fName); $realFileName = $pathInfo["filename"]; $ext = empty($pathInfo["extension"]) ? "" : strtolower($pathInfo["extension"]); $sanitizedName = sanitize_file_name($realFileName); $cleanFileName = $sanitizedName . "-" . $currentTime . "." . $ext; $cleanRealFileName = $sanitizedName . "." . $ext; $fileName = $path . $cleanFileName; if (in_array($ext, ["jpeg", "jpg"])) { $this->imageFixOrientation($file["tmp_name"]); } $success = apply_filters("wpdiscuz_mu_compress_image", false, $file["tmp_name"], $fileName, $q = 60); if ($success || @move_uploaded_file($file["tmp_name"], $fileName)) { $postParent = apply_filters("wpdiscuz_mu_attachment_parent", 0); $attachment = [ "guid" => $this->wpUploadsUrl . "/" . $cleanFileName, "post_mime_type" => $file["type"], "post_title" => preg_replace("#\.[^.]+$#", "", wp_slash($sanitizedName)), "post_excerpt" => wp_slash($sanitizedName), "post_content" => "", "post_status" => "inherit", "post_parent" => $postParent ]; if ($attachId = wp_insert_attachment($attachment, $fileName)) { if (!$this->options->content["wmuIsThumbnailsViaCron"]) { $attachData = $this->generateAttachmentMetadata($attachId, $fileName); } update_post_meta($attachId, "_wp_attachment_image_alt", $sanitizedName); $ip = WpdiscuzHelper::getRealIPAddr(); update_post_meta($attachId, self::METAKEY_ATTCHMENT_OWNER_IP, $ip); update_post_meta($attachId, self::METAKEY_ATTCHMENT_COMMENT_ID, 0); $attachmentData["id"] = self::encrypt($attachId); $attachmentData["url"] = empty($attachData["sizes"]["thumbnail"]["file"]) ? $this->wpUploadsUrl . "/" . $cleanFileName : $this->wpUploadsUrl . "/" . $attachData["sizes"]["thumbnail"]["file"]; $attachmentData["fullname"] = $cleanRealFileName; $attachmentData["shortname"] = $this->getFileName($cleanRealFileName); } } return $attachmentData; } private function getImageSizes() { $sizes = []; $this->options->content["wmuThumbnailSizes"] = array_filter($this->options->content["wmuThumbnailSizes"], function ($v) { return in_array($v, get_intermediate_image_sizes()); }); foreach ($this->options->content["wmuThumbnailSizes"] as $_size) { if (in_array($_size, $this->options->getDefaultThumbnailSizes())) { $sizes[$_size]["width"] = intval(get_option("{$_size}_size_w")); $sizes[$_size]["height"] = intval(get_option("{$_size}_size_h")); } else if (isset($additionalSizes[$_size])) { $sizes[$_size]["width"] = $additionalSizes[$_size]["width"]; $sizes[$_size]["height"] = $additionalSizes[$_size]["height"]; } } return $sizes; } public function getThumbnailSizes() { $sizes = $this->options->content["wmuThumbnailSizes"]; if ($sizes && is_array($sizes) && !in_array("full", $sizes)) { $sizes[] = "full"; } if (!$sizes) { $sizes = ["full"]; } return $sizes; } private function combineArray($array) { $combinedArray = []; foreach ($array as $k => $v) { foreach ($v as $k1 => $v1) { $combinedArray[$k1][$k] = $v1; } } return $combinedArray; } private function imageFixOrientation($filename) { $isFunctionsExists = function_exists("exif_read_data") && function_exists("imagecreatefromjpeg") && function_exists("imagerotate") && function_exists("imagejpeg"); if ($isFunctionsExists) { $exif = @exif_read_data($filename); if (!empty($exif["Orientation"])) { $image = imagecreatefromjpeg($filename); switch ($exif["Orientation"]) { case 3: $image = imagerotate($image, 180, 0); break; case 6: $image = imagerotate($image, -90, 0); break; case 8: $image = imagerotate($image, 90, 0); break; } imagejpeg($image, $filename, 90); } } } public function getFileName($attachment) { $name = false; if ($attachment) { if (is_object($attachment) && (isset($attachment->post_excerpt) || isset($attachment->post_title))) { $name = $attachment->post_excerpt ? $attachment->post_excerpt : $attachment->post_title; } else { $name = $attachment; } if (strlen($name) > 40) { $name = function_exists("mb_substr") ? mb_substr($name, -40, 40, "UTF-8") : substr($name, -40, 40); $name = "..." . $name; } $name = ucfirst(str_replace(["-", "_"], " ", $name)); } return $name; } public function deleteLinkedAttachments($commentId) { if ($commentId) { $metaData = get_comment_meta($commentId, self::METAKEY_ATTACHMENTS, true); if ($metaData && is_array($metaData)) { foreach ($metaData as $key => $attachments) { if ($attachments && is_array($attachments)) { foreach ($attachments as $attachment) { wp_delete_attachment($attachment); } } } } } } public function deleteAttachmentIdFromMeta($postId) { $commentId = get_post_meta($postId, self::METAKEY_ATTCHMENT_COMMENT_ID, true); if ($commentId) { $attachments = get_comment_meta($commentId, self::METAKEY_ATTACHMENTS, true); if ($attachments && is_array($attachments)) { $tmpData = []; foreach ($attachments as $key => $value) { $index = array_search($postId, $value); if ($index !== false) { unset($value[$index]); $tmpData[$key] = array_values($value); } else { $tmpData[$key] = $value; } } if (self::hasAttachments($tmpData)) { update_comment_meta($commentId, self::METAKEY_ATTACHMENTS, $tmpData); } else { delete_comment_meta($commentId, self::METAKEY_ATTACHMENTS); } } } } public static function hasAttachments($attachments) { $hasItems = false; if ($attachments && is_array($attachments)) { foreach ($attachments as $attachment) { if (is_array($attachment) && count($attachment)) { $hasItems = true; break; } } } return $hasItems; } public function canEditAttachments($currentUser, $attachment) { $args = []; if (isset($this->currentUser->user_email)) { $args["comment_author_email"] = $this->currentUser->user_email; } $commentId = get_post_meta($attachment->ID, self::METAKEY_ATTCHMENT_COMMENT_ID, true); $comment = get_comment($commentId); return current_user_can("moderate_comments") || ($this->helper->isCommentEditable($comment) && $this->helper->canUserEditComment($comment, $currentUser, $args)); } public function getDeleteHtml($currentUser, $attachment, $type) { $attachmentId = self::encrypt($attachment->ID); $deleteHtml = "<div class='wmu-attachment-delete wmu-delete-$type' title='" . esc_html__("Delete", "wpdiscuz") . "' data-wmu-attachment='$attachmentId'> </div>"; return $this->canEditAttachments($currentUser, $attachment) ? $deleteHtml : "<div class='wmu-separator'></div>"; } public function commentListArgs($args) { if (empty($args["current_user"])) { $this->currentUser = WpdiscuzHelper::getCurrentUser(); } else { $this->currentUser = $args["current_user"]; } return $args; } public function setCurrentUser($currentUser) { $this->currentUser = $currentUser; } private function getDefaultPostTypes() { return ["post", "page", "attachment"]; } private function getDefaultRoles() { return ["administrator", "editor", "author", "contributor", "subscriber"]; } public function isImage($file) { return wp_get_image_mime($file["tmp_name"]); } /** * DEPRECATED due to some secuirty issues */ public function getMimeTypeFromContent($path) { $fileContent = $path && function_exists("file_get_contents") && ($v = file_get_contents($path)) ? $v : ""; if ($fileContent && preg_match('/\A(?:(\xff\xd8\xff)|(GIF8[79]a)|(\x89PNG\x0d\x0a)|(BM)|(\x49\x49(?:\x2a\x00|\x00\x4a))|(FORM.{4}ILBM))/', $fileContent, $hits)) { $type = [ 1 => "jpeg", 2 => "gif", 3 => "png", 4 => "bmp", 5 => "tiff", 6 => "ilbm", ]; return $type[count($hits) - 1]; } return false; } public function exportPersonalData($data, $commentId) { $attachments = get_comment_meta($commentId, self::METAKEY_ATTACHMENTS, true); if ($attachments && is_array($attachments)) { $isWmuExists = apply_filters("wpdiscuz_mu_exists", false); foreach ($attachments as $key => $attachIds) { if (empty($attachIds)) { continue; } foreach ($attachIds as $attachId) { if (intval($attachId)) { if ($key === self::KEY_IMAGES) { $data[] = ["name" => esc_html__("Attached Images", "wpdiscuz"), "value" => wp_get_attachment_url($attachId)]; } else if ($isWmuExists) { $data = apply_filters("wpdiscuz_mu_export_data", $data, $key, $attachId); } } } } } return $data; } public function deleteUnattachedFiles() { if (!apply_filters("wpdiscuz_delete_unattached_files", true)) { wp_clear_scheduled_hook(self::DELETE_UNATTACHED_FILES_ACTION); return; } $attachments = get_posts([ "post_type" => "attachment", "posts_per_page" => apply_filters("wpdiscuz_delete_unattached_files_limit", 20), /* "date_query" => [ [ "column" => "post_date_gmt", "before" => "30 minutes ago", ], ], */ "meta_query" => [ [ "key" => self::METAKEY_ATTCHMENT_COMMENT_ID, "value" => "0", "compare" => "=", ], ], "fields" => "ids", ]); foreach ($attachments as $key => $attachment) { wp_delete_attachment($attachment, true); } } public function registerJobThumbnailsViaCron() { if (!wp_next_scheduled(self::GENERATE_THUMBNAILS_ACTION)) { wp_schedule_event(current_time("timestamp"), self::GENERATE_THUMBNAILS_KEY_RECURRENCE, self::GENERATE_THUMBNAILS_ACTION); } } public function deregisterJobThumbnailsViaCron() { if (!$this->options->content["wmuIsThumbnailsViaCron"] && wp_next_scheduled(self::GENERATE_THUMBNAILS_ACTION)) { wp_clear_scheduled_hook(self::GENERATE_THUMBNAILS_ACTION); } } public function setIntervalThumbnailsViaCron($schedules) { $schedules[self::GENERATE_THUMBNAILS_KEY_RECURRENCE] = [ "interval" => self::GENERATE_THUMBNAILS_RECURRENCE * HOUR_IN_SECONDS, "display" => esc_html__("Every 3 hours", "wpdiscuz") ]; return $schedules; } public function generateThumbnails() { if (!apply_filters("wpdiscuz_generate_thumbnails_check", true)) { wp_clear_scheduled_hook(self::GENERATE_THUMBNAILS_ACTION); return; } set_time_limit(-1); $attachments = get_posts([ "post_type" => "attachment", "posts_per_page" => apply_filters("wpdiscuz_generate_thumbnails_limit", -1), "fields" => "ids", "meta_query" => [ "relation" => "AND", [ "relation" => "OR", [ "key" => "_wp_attachment_metadata", "compare" => "NOT EXISTS", ], [ "key" => '_wp_attachment_metadata', "value" => "", "compare" => "=", ], ], [ "key" => "_wmu_comment_id", "value" => "", "compare" => "!=" ] ], ]); foreach ($attachments as $attachId) { $fileName = get_post_meta($attachId, "_wp_attached_file", true); $is_wpdiscuz_attachment = (int)get_post_meta($attachId, '_wmu_comment_id', true); if (!$fileName || !$is_wpdiscuz_attachment) { continue; } $fileName = $this->wpUploadsPath . "/" . basename($fileName); $attachData = $this->generateAttachmentMetadata($attachId, $fileName); } } private function generateAttachmentMetadata($attachId, $fileName) { $this->includeImageFunctions(); add_filter("intermediate_image_sizes", [&$this, "getThumbnailSizes"]); $attachData = wp_generate_attachment_metadata($attachId, $fileName); wp_update_attachment_metadata($attachId, $attachData); return $attachData; } public function includeImageFunctions() { if (!function_exists("get_file_description")) { require_once ABSPATH . "wp-admin/includes/file.php"; } if (!function_exists("wp_generate_attachment_metadata")) { require_once ABSPATH . "wp-admin/includes/image.php"; } if (!function_exists("wp_get_additional_image_sizes")) { require_once ABSPATH . "wp-admin/includes/media.php"; } } public function wpdiscuzMediaFiler() { $scr = get_current_screen(); if ($scr->base !== "upload") { return; } $source = WpdiscuzHelper::sanitize(INPUT_GET, "media_source", "FILTER_SANITIZE_STRING"); $selected = $source === "wpdiscuz" ? " selected='selected'" : ""; $dropdown = "<select name='media_source' id='wpdiscuz_media' class='postform'>"; $dropdown .= "<option value=''>" . esc_html__("All Media Items", "wpdiscuz") . "</option>"; $dropdown .= "<option value='wpdiscuz' {$selected}>" . esc_html__("wpDiscuz Media Items", "wpdiscuz") . "</option>"; $dropdown .= "</select>"; echo $dropdown; } function getWpdiscuzMedia($query) { global $pagenow; $mode = WpdiscuzHelper::sanitize(INPUT_GET, "mode", "FILTER_SANITIZE_STRING"); $source = WpdiscuzHelper::sanitize(INPUT_GET, "media_source", "FILTER_SANITIZE_STRING"); if (is_admin() && "upload.php" === $pagenow && $mode === "list" && $source === "wpdiscuz") { $query->query_vars["meta_key"] = "_wmu_comment_id"; $query->query_vars["meta_value"] = ""; $query->query_vars["meta_compare"] = "!="; } } public function wpdiscuzMediaCommentColumn($columns, $detached) { if ($columns && is_array($columns)) { $columns['wpdcomment'] = esc_html__('Attached To Comment', 'wpdiscuz'); } return $columns; } }