function update_activity_after_thumb_set($id) { $model = new RTMediaModel(); $mediaObj = new RTMediaMedia(); $media = $model->get(array('id' => $id)); $privacy = $media[0]->privacy; $activity_id = rtmedia_activity_id($id); if (!empty($activity_id)) { $same_medias = $mediaObj->model->get(array('activity_id' => $activity_id)); $update_activity_media = array(); foreach ($same_medias as $a_media) { $update_activity_media[] = $a_media->id; } $objActivity = new RTMediaActivity($update_activity_media, $privacy, false); global $wpdb, $bp; $activity_old_content = bp_activity_get_meta($activity_id, "bp_old_activity_content"); $activity_text = bp_activity_get_meta($activity_id, "bp_activity_text"); if ($activity_old_content == "") { // get old activity content and save in activity meta $activity_get = bp_activity_get_specific(array('activity_ids' => $activity_id)); $activity = $activity_get['activities'][0]; $activity_body = $activity->content; bp_activity_update_meta($activity_id, "bp_old_activity_content", $activity_body); //extract activity text from old content $activity_text = strip_tags($activity_body, '<span>'); $activity_text = explode("</span>", $activity_text); $activity_text = strip_tags($activity_text[0]); bp_activity_update_meta($activity_id, "bp_activity_text", $activity_text); } $activity_text = bp_activity_get_meta($activity_id, "bp_activity_text"); $objActivity->activity_text = $activity_text; $wpdb->update($bp->activity->table_name, array("type" => "rtmedia_update", "content" => $objActivity->create_activity_html()), array("id" => $activity_id)); } }
function save_single_edit() { add_filter('intermediate_image_sizes_advanced', array($this, 'filter_image_sizes_details')); global $rtmedia_query; $nonce = $_POST['rtmedia_media_nonce']; if (wp_verify_nonce($nonce, 'rtmedia_' . $rtmedia_query->action_query->id)) { /* * Need this file in order to use `wp_generate_attachment_metadata` function */ require_once ABSPATH . 'wp-admin/includes/image.php'; do_action('rtmedia_before_update_media', $rtmedia_query->action_query->id); $data_array = array('media_title', 'description', 'privacy'); //for medias except album and playlist, if album_is is found, then update album_id for the media also if (isset($_POST['album_id']) && $_POST['album_id'] != '') { $data_array[] = 'album_id'; } $data = rtmedia_sanitize_object($_POST, $data_array); $media = new RTMediaMedia(); $image_path = get_attached_file($rtmedia_query->media[0]->media_id); if ($image_path && $rtmedia_query->media[0]->media_type == "photo") { $image_meta_data = wp_generate_attachment_metadata($rtmedia_query->media[0]->media_id, $image_path); wp_update_attachment_metadata($rtmedia_query->media[0]->media_id, $image_meta_data); } $state = $media->update($rtmedia_query->action_query->id, $data, $rtmedia_query->media[0]->media_id); if (isset($_POST['rtmedia-filepath-old'])) { $is_valid_url = preg_match("/\\b(?:(?:https?|ftp):\\/\\/|www\\.)[-a-z0-9+&@#\\/%?=~_|!:,.;]*[-a-z0-9+&@#\\/%=~_|]/i", $_POST['rtmedia-filepath-old']); if ($is_valid_url && function_exists('bp_is_active') && bp_is_active('activity')) { $thumbnailinfo = wp_get_attachment_image_src($rtmedia_query->media[0]->media_id, 'rt_media_activity_image'); $activity_id = rtmedia_activity_id($rtmedia_query->media[0]->id); if ($rtmedia_query->media[0]->media_id && !empty($activity_id)) { global $wpdb, $bp; if (!empty($bp->activity)) { $related_media_data = $media->model->get(array('activity_id' => $activity_id)); $related_media = array(); foreach ($related_media_data as $activity_media) { $related_media[] = $activity_media->id; } $activity_text = bp_activity_get_meta($activity_id, 'bp_activity_text'); $activity = new RTMediaActivity($related_media, 0, $activity_text); $activity_content_new = $activity->create_activity_html(); // Replacing the filename with new effected filename $activity_content = str_replace($_POST['rtmedia-filepath-old'], $thumbnailinfo[0], $activity_content_new); $wpdb->update($bp->activity->table_name, array('content' => $activity_content), array('id' => $activity_id)); } } } } $rtmedia_query->query(false); global $rtmedia_points_media_id; $rtmedia_points_media_id = $rtmedia_query->action_query->id; do_action('rtmedia_after_edit_media', $rtmedia_query->action_query->id, $state); //refresh $rtMediaNav = new RTMediaNav(); if ($rtmedia_query->media[0]->context == "group") { $rtMediaNav->refresh_counts($rtmedia_query->media[0]->context_id, array("context" => $rtmedia_query->media[0]->context, 'context_id' => $rtmedia_query->media[0]->context_id)); } else { $rtMediaNav->refresh_counts($rtmedia_query->media[0]->media_author, array("context" => "profile", 'media_author' => $rtmedia_query->media[0]->media_author)); } $state = apply_filters('rtmedia_single_edit_state', $state); if ($state !== false) { add_action("rtmedia_before_template_load", array(&$this, "media_update_success_messege")); } else { add_action("rtmedia_before_template_load", array(&$this, "media_update_success_error")); } } else { _e('Ooops !!! Invalid access. No nonce was found !!', 'buddypress-media'); } remove_filter('intermediate_image_sizes_advanced', array($this, 'filter_image_sizes_details')); }
function rtmedia_api_process_rtmedia_upload_media_request() { $this->rtmediajsonapifunction->rtmedia_api_verfiy_token(); //Error Codes for new look $ec_no_file = 140001; $msg_no_file = __('no file', 'rtmedia'); $ec_invalid_file_string = 140005; $msg_invalid_file_string = __('invalid file string', 'rtmedia'); $ec_image_type_missing = 140006; $msg_image_type_missing = __('image type missing', 'rtmedia'); $ec_no_file_title = 140002; $msg_no_file_title = __('no title', 'rtmedia'); $ec_invalid_image = 140003; $msg_invalid_image = __('upload failed, check size and file type', 'rtmedia'); $ec_look_updated = 140004; $msg_look_updated = __('media updated', 'rtmedia'); $description = ''; extract($_POST); $updated = FALSE; $uploaded_look = FALSE; if (empty($_POST['rtmedia_file']) && empty($_FILES['rtmedia_file'])) { echo $this->rtmedia_api_response_object('FALSE', $ec_no_file, $msg_no_file); exit; } if (!empty($_POST['rtmedia_file'])) { if (empty($_POST['image_type'])) { echo $this->rtmedia_api_response_object('FALSE', $ec_image_type_missing, $msg_image_type_missing); exit; } if (empty($title)) { echo $this->rtmedia_api_response_object('FALSE', $ec_no_file_title, $msg_no_file_title); exit; } } if (!empty($_FILES['rtmedia_file'])) { $_POST['rtmedia_upload_nonce'] = $_REQUEST['rtmedia_upload_nonce'] = wp_create_nonce('rtmedia_upload_nonce'); $_POST['rtmedia_simple_file_upload'] = $_REQUEST['rtmedia_simple_file_upload'] = 1; $_POST['context'] = $_REQUEST['context'] = !empty($_REQUEST['context']) ? $_REQUEST['context'] : 'profile'; $_POST['context_id'] = $_REQUEST['context_id'] = !empty($_REQUEST['context_id']) ? $_REQUEST['context_id'] : $this->user_id; $_POST['mode'] = $_REQUEST['mode'] = 'file_upload'; $_POST['media_author'] = $_REQUEST['media_author'] = $this->user_id; $upload = new RTMediaUploadEndpoint(); $uploaded_look = $upload->template_redirect(); } else { //Process rtmedia_file $img = $rtmedia_file; $img = str_replace('data:image/png;base64,', '', $img); // $img = str_replace(' ', '+', $img); $rtmedia_file = base64_decode($img); if (!$rtmedia_file) { echo $this->rtmedia_api_response_object('FALSE', $ec_invalid_file_string, $msg_invalid_file_string); exit; } define('UPLOAD_DIR_LOOK', sys_get_temp_dir() . '/'); $tmp_name = UPLOAD_DIR_LOOK . $title; $file = $tmp_name . '.' . $image_type; $success = file_put_contents($file, $rtmedia_file); add_filter('upload_dir', array($this, 'api_new_media_upload_dir')); // echo $file; $new_look = wp_upload_bits($title . '.' . $image_type, '', $rtmedia_file); $new_look['type'] = 'image/' . $image_type; remove_filter('upload_dir', array($this, 'api_new_media_upload_dir')); foreach ($new_look as $key => $value) { $new_look[0][$key] = $value; unset($new_look[$key]); } //Jugaad if (!empty($tags)) { $tags = explode(',', $tags); } $uploaded['rtmedia_upload_nonce'] = wp_create_nonce('rtmedia_upload_nonce'); $uploaded['rtmedia_simple_file_upload'] = 1; $uploaded['context'] = 'profile'; $uploaded['context_id'] = $this->user_id; $uploaded['mode'] = 'file_upload'; $uploaded['media_author'] = $this->user_id; $uploaded['album_id'] = $this->user_id; $uploaded['privacy'] = 0; $uploaded['title'] = $title; $uploaded['description'] = $description; $uploaded['taxonomy'] = array(); $uploaded['custom_fields'] = array(); $rtmedia = new RTMediaMedia(); $rtupload = $rtmedia->add($uploaded, $new_look); $id = rtmedia_media_id($rtupload[0]); if (!empty($_POST['tags'])) { wp_set_post_terms($id, $_POST["tags"], 'media-category', true); } $media = $rtmedia->model->get(array('id' => $rtupload[0])); $rtMediaNav = new RTMediaNav(); $perma_link = ""; if (isset($media) && sizeof($media) > 0) { $perma_link = get_rtmedia_permalink($media[0]->id); if ($media[0]->media_type == "photo") { $thumb_image = rtmedia_image("rt_media_thumbnail", $rtupload[0], false); } elseif ($media[0]->media_type == "music") { $thumb_image = $media[0]->cover_art; } else { $thumb_image = ""; } if ($media[0]->context == "group") { $rtMediaNav->refresh_counts($media[0]->context_id, array("context" => $media[0]->context, 'context_id' => $media[0]->context_id)); } else { $rtMediaNav->refresh_counts($media[0]->media_author, array("context" => "profile", 'media_author' => $media[0]->media_author)); } $activity_id = $rtmedia->insert_activity($media[0]->media_id, $media[0]); $rtmedia->model->update(array('activity_id' => $activity_id), array('id' => $rtupload[0])); // $same_medias = $rtmedia->model->get(array('activity_id' => $activity_id)); $update_activity_media = array(); foreach ($same_medias as $a_media) { $update_activity_media[] = $a_media->id; } $privacy = 0; $objActivity = new RTMediaActivity($update_activity_media, $privacy, false); global $wpdb, $bp; $updated = $wpdb->update($bp->activity->table_name, array("type" => "rtmedia_update", "content" => $objActivity->create_activity_html()), array("id" => $activity_id)); } } if ($updated || $uploaded_look) { echo $this->rtmedia_api_response_object('TRUE', $ec_look_updated, $msg_look_updated); exit; } else { echo $this->rtmedia_api_response_object('TRUE', $ec_invalid_image, $msg_invalid_image); exit; } }
function bp_activity_posted_update($content, $user_id, $activity_id) { global $wpdb, $bp; $updated_content = ''; // hook for rtmedia buddypress before activity posted do_action('rtmedia_bp_before_activity_posted', $content, $user_id, $activity_id); if (isset($_POST['rtMedia_attached_files']) && is_array($_POST['rtMedia_attached_files'])) { $updated_content = $wpdb->get_var("select content from {$bp->activity->table_name} where id= {$activity_id}"); $objActivity = new RTMediaActivity($_POST['rtMedia_attached_files'], 0, $updated_content); $html_content = $objActivity->create_activity_html(); bp_activity_update_meta($activity_id, 'bp_old_activity_content', $html_content); bp_activity_update_meta($activity_id, 'bp_activity_text', $updated_content); $wpdb->update($bp->activity->table_name, array('type' => 'rtmedia_update', 'content' => $html_content), array('id' => $activity_id)); $mediaObj = new RTMediaModel(); $sql = "update {$mediaObj->table_name} set activity_id = '" . $activity_id . "' where blog_id = '" . get_current_blog_id() . "' and id in (" . implode(',', $_POST['rtMedia_attached_files']) . ')'; $wpdb->query($sql); } // hook for rtmedia buddypress after activity posted do_action('rtmedia_bp_activity_posted', $updated_content, $user_id, $activity_id); if (isset($_POST['rtmedia-privacy'])) { $privacy = -1; if (is_rtmedia_privacy_enable()) { if (is_rtmedia_privacy_user_overide()) { $privacy = $_POST['rtmedia-privacy']; } else { $privacy = get_rtmedia_default_privacy(); } } bp_activity_update_meta($activity_id, 'rtmedia_privacy', $privacy); // insert/update activity details in rtmedia activity table $rtmedia_activity_model = new RTMediaActivityModel(); if (!$rtmedia_activity_model->check($activity_id)) { $rtmedia_activity_model->insert(array('activity_id' => $activity_id, 'user_id' => $user_id, 'privacy' => $privacy)); } else { $rtmedia_activity_model->update(array('activity_id' => $activity_id, 'user_id' => $user_id, 'privacy' => $privacy), array('activity_id' => $activity_id)); } } }
/** * */ function template_redirect($create_activity = true) { ob_start(); if (!count($_POST)) { include get_404_template(); } else { $nonce = $_REQUEST['rtmedia_upload_nonce']; if (isset($_REQUEST['mode'])) { $mode = $_REQUEST['mode']; } $rtupload = false; $activity_id = -1; $redirect_url = ""; if (wp_verify_nonce($nonce, 'rtmedia_upload_nonce')) { $model = new RTMediaUploadModel(); do_action('rtmedia_upload_set_post_object'); $this->upload = $model->set_post_object(); if (isset($_POST['activity_id']) && $_POST['activity_id'] != -1) { $this->upload['activity_id'] = $_POST['activity_id']; $activity_id = $_POST['activity_id']; } // ////if media upload is being made for a group, identify the group privacy and set media privacy accordingly if (isset($this->upload['context']) && isset($this->upload['context_id']) && $this->upload['context'] == 'group' && function_exists('groups_get_group')) { $group = groups_get_group(array('group_id' => $this->upload['context_id'])); if (isset($group->status) && $group->status != 'public') { // if group is not public, then set media privacy as 20, so only the group members can see the images $this->upload['privacy'] = '20'; } else { // if group is public, then set media privacy as 0 $this->upload['privacy'] = '0'; } } $this->upload = apply_filters('rtmedia_media_param_before_upload', $this->upload); $rtupload = new RTMediaUpload($this->upload); $mediaObj = new RTMediaMedia(); $media = $mediaObj->model->get(array('id' => $rtupload->media_ids[0])); $rtMediaNav = new RTMediaNav(); $perma_link = ""; if (isset($media) && sizeof($media) > 0) { $perma_link = get_rtmedia_permalink($media[0]->id); if ($media[0]->media_type == "photo") { $thumb_image = rtmedia_image("rt_media_thumbnail", $rtupload->media_ids[0], false); } elseif ($media[0]->media_type == "music") { $thumb_image = $media[0]->cover_art; } else { $thumb_image = ""; } if ($media[0]->context == "group") { $rtMediaNav->refresh_counts($media[0]->context_id, array("context" => $media[0]->context, 'context_id' => $media[0]->context_id)); } else { $rtMediaNav->refresh_counts($media[0]->media_author, array("context" => "profile", 'media_author' => $media[0]->media_author)); } if ($create_activity !== false && class_exists('BuddyPress')) { $allow_single_activity = apply_filters('rtmedia_media_single_activity', false); // Following will not apply to activity uploads. For first time activity won't be generated. // Create activity first and pass activity id in response. // todo fixme rtmedia_media_single_activity filter. It will create 2 activity with same media if uploaded from activity page. if ($activity_id == -1 && !(isset($_POST["rtmedia_update"]) && $_POST["rtmedia_update"] == "true") || $allow_single_activity) { $activity_id = $mediaObj->insert_activity($media[0]->media_id, $media[0]); } else { $mediaObj->model->update(array('activity_id' => $activity_id), array('id' => $rtupload->media_ids[0])); // $same_medias = $mediaObj->model->get(array('activity_id' => $activity_id)); $update_activity_media = array(); foreach ($same_medias as $a_media) { $update_activity_media[] = $a_media->id; } $privacy = 0; if (isset($_POST["privacy"])) { $privacy = $_POST["privacy"]; } $objActivity = new RTMediaActivity($update_activity_media, $privacy, false); global $wpdb, $bp; $user = get_userdata($same_medias[0]->media_author); $username = '******' . get_rtmedia_user_link($same_medias[0]->media_author) . '">' . $user->user_nicename . '</a>'; $action = sprintf(__('%s added %d %s', 'buddypress-media'), $username, sizeof($same_medias), RTMEDIA_MEDIA_SLUG); $action = apply_filters('rtmedia_buddypress_action_text_fitler_multiple_media', $action, $username, sizeof($same_medias), $user->user_nicename); $wpdb->update($bp->activity->table_name, array("type" => "rtmedia_update", "content" => $objActivity->create_activity_html(), 'action' => $action), array("id" => $activity_id)); } // update group last active if ($media[0]->context == "group") { RTMediaGroup::update_last_active($media[0]->context_id); } } } if (isset($this->upload['rtmedia_simple_file_upload']) && $this->upload['rtmedia_simple_file_upload'] == true) { if (isset($media) && sizeof($media) > 0) { if (isset($_POST["redirect"])) { if (intval($_POST["redirect"]) > 1) { //bulkurl if ($media[0]->context == "group") { $redirect_url = trailingslashit(get_rtmedia_group_link($media[0]->context_id)) . RTMEDIA_MEDIA_SLUG; } else { $redirect_url = trailingslashit(get_rtmedia_user_link($media[0]->media_author)) . RTMEDIA_MEDIA_SLUG; } } else { $redirect_url = get_rtmedia_permalink($media[0]->id); } $redirect_url = apply_filters("rtmedia_simple_file_upload_redirect_url_filter", $redirect_url); wp_safe_redirect(esc_url_raw($redirect_url)); die; } return $media; } return false; } } $redirect_url = ""; if (isset($_POST["redirect"]) && is_numeric($_POST["redirect"])) { if (intval($_POST["redirect"]) > 1) { //bulkurl if ($media[0]->context == "group") { $redirect_url = trailingslashit(get_rtmedia_group_link($media[0]->context_id)) . RTMEDIA_MEDIA_SLUG; } else { $redirect_url = trailingslashit(get_rtmedia_user_link($media[0]->media_author)) . RTMEDIA_MEDIA_SLUG; } } else { $redirect_url = get_rtmedia_permalink($media[0]->id); } } // Ha ha ha ob_end_clean(); //check for simpe /** * if(redirect) * */ if (isset($_POST["rtmedia_update"]) && $_POST["rtmedia_update"] == "true") { if (preg_match('/(?i)msie [1-9]/', $_SERVER['HTTP_USER_AGENT'])) { // if IE(<=9) set content type = text/plain header('Content-type: text/plain'); } else { header('Content-type: application/json'); } echo json_encode($rtupload->media_ids); } else { // Media Upload Case - on album/post/profile/group if (isset($media[0])) { $data = array('media_id' => $media[0]->id, 'activity_id' => $activity_id, 'redirect_url' => $redirect_url, 'permalink' => $perma_link, 'cover_art' => $thumb_image); } else { $data = array(); } if (preg_match('/(?i)msie [1-9]/', $_SERVER['HTTP_USER_AGENT'])) { // if IE(<=9) set content type = text/plain header('Content-type: text/plain'); } else { header('Content-type: application/json'); } echo json_encode(apply_filters('rtmedia_upload_endpoint_response', $data)); } die; } }
function template_redirect($create_activity = true) { ob_start(); if (!count($_POST)) { // @codingStandardsIgnoreLine include get_404_template(); } else { $nonce = $mode = ''; $_activity_id = -1; if (isset($_REQUEST['rtmedia_upload_nonce'])) { $nonce = sanitize_text_field(wp_unslash($_REQUEST['rtmedia_upload_nonce'])); } if (isset($_REQUEST['mode'])) { $mode = sanitize_text_field(wp_unslash($_REQUEST['mode'])); } if (isset($_REQUEST['activity_id'])) { $_activity_id = sanitize_text_field($_REQUEST['activity_id']); } $_redirect_url = filter_input(INPUT_POST, 'redirect', FILTER_SANITIZE_NUMBER_INT); $rtupload = false; $activity_id = -1; $redirect_url = ''; if (wp_verify_nonce($nonce, 'rtmedia_upload_nonce')) { $model = new RTMediaUploadModel(); do_action('rtmedia_upload_set_post_object'); $this->upload = $model->set_post_object(); if (-1 !== $_activity_id) { $this->upload['activity_id'] = $_activity_id; $activity_id = $_activity_id; } //if media upload is being made for a group, identify the group privacy and set media privacy accordingly if (isset($this->upload['context']) && isset($this->upload['context_id']) && 'group' === $this->upload['context'] && function_exists('groups_get_group')) { $group = groups_get_group(array('group_id' => $this->upload['context_id'])); if (isset($group->status) && 'public' !== $group->status) { // if group is not public, then set media privacy as 20, so only the group members can see the images $this->upload['privacy'] = '20'; } else { // if group is public, then set media privacy as 0 $this->upload['privacy'] = '0'; } } $this->upload = apply_filters('rtmedia_media_param_before_upload', $this->upload); $rtupload = new RTMediaUpload($this->upload); $media_obj = new RTMediaMedia(); $media = $media_obj->model->get(array('id' => $rtupload->media_ids[0])); $rtmedia_nav = new RTMediaNav(); $perma_link = ''; if (isset($media) && count($media) > 0) { $perma_link = get_rtmedia_permalink($media[0]->id); if ('photo' === $media[0]->media_type) { $thumb_image = rtmedia_image('rt_media_thumbnail', $rtupload->media_ids[0], false); } elseif ('music' === $media[0]->media_type) { $thumb_image = $media[0]->cover_art; } else { $thumb_image = ''; } if ('group' === $media[0]->context) { $rtmedia_nav->refresh_counts($media[0]->context_id, array('context' => $media[0]->context, 'context_id' => $media[0]->context_id)); } else { $rtmedia_nav->refresh_counts($media[0]->media_author, array('context' => 'profile', 'media_author' => $media[0]->media_author)); } if (false !== $create_activity && class_exists('BuddyPress') && bp_is_active('activity')) { $allow_single_activity = apply_filters('rtmedia_media_single_activity', false); // Following will not apply to activity uploads. For first time activity won't be generated. // Create activity first and pass activity id in response. // todo fixme rtmedia_media_single_activity filter. It will create 2 activity with same media if uploaded from activity page. $_rtmedia_update = filter_input(INPUT_POST, 'rtmedia_update', FILTER_SANITIZE_STRING); if (-1 === intval($activity_id) && !(isset($_rtmedia_update) && 'true' === $_rtmedia_update) || $allow_single_activity) { $activity_id = $media_obj->insert_activity($media[0]->media_id, $media[0]); } else { $media_obj->model->update(array('activity_id' => $activity_id), array('id' => $rtupload->media_ids[0])); // $same_medias = $media_obj->model->get(array('activity_id' => $activity_id)); $update_activity_media = array(); foreach ($same_medias as $a_media) { $update_activity_media[] = $a_media->id; } $privacy = filter_input(INPUT_POST, 'privacy', FILTER_SANITIZE_NUMBER_INT); if (empty($privacy)) { $privacy = 0; } $obj_activity = new RTMediaActivity($update_activity_media, $privacy, false); global $wpdb, $bp; $user = get_userdata($same_medias[0]->media_author); $username = '******' . esc_url(get_rtmedia_user_link($same_medias[0]->media_author)) . '">' . esc_html($user->user_nicename) . '</a>'; $action = sprintf(esc_html__('%s added %d %s', 'buddypress-media'), $username, count($same_medias), RTMEDIA_MEDIA_SLUG); $action = apply_filters('rtmedia_buddypress_action_text_fitler_multiple_media', $action, $username, count($same_medias), $user->user_nicename); $wpdb->update($bp->activity->table_name, array('type' => 'rtmedia_update', 'content' => $obj_activity->create_activity_html(), 'action' => $action), array('id' => $activity_id)); } // update group last active if ('group' === $media[0]->context) { RTMediaGroup::update_last_active($media[0]->context_id); } } } if (isset($this->upload['rtmedia_simple_file_upload']) && true == $this->upload['rtmedia_simple_file_upload']) { if (isset($media) && count($media) > 0) { if (isset($_redirect_url)) { if (intval($_redirect_url) > 1) { //bulkurl if ('group' === $media[0]->context) { $redirect_url = trailingslashit(get_rtmedia_group_link($media[0]->context_id)) . RTMEDIA_MEDIA_SLUG; } else { $redirect_url = trailingslashit(get_rtmedia_user_link($media[0]->media_author)) . RTMEDIA_MEDIA_SLUG; } } else { $redirect_url = get_rtmedia_permalink($media[0]->id); } $redirect_url = apply_filters('rtmedia_simple_file_upload_redirect_url_filter', $redirect_url); wp_safe_redirect(esc_url_raw($redirect_url)); die; } return $media; } return false; } } $redirect_url = ''; if (isset($_redirect_url) && is_numeric($_redirect_url)) { if (intval($_redirect_url) > 1) { //bulkurl if ('group' === $media[0]->context) { $redirect_url = trailingslashit(get_rtmedia_group_link($media[0]->context_id)) . RTMEDIA_MEDIA_SLUG; } else { $redirect_url = trailingslashit(get_rtmedia_user_link($media[0]->media_author)) . RTMEDIA_MEDIA_SLUG; } } else { $redirect_url = get_rtmedia_permalink($media[0]->id); } } // Ha ha ha ob_end_clean(); //check for simpe $rtmedia_update = filter_input(INPUT_POST, 'rtmedia_update', FILTER_SANITIZE_STRING); $_user_agent = rtm_get_server_var('HTTP_USER_AGENT', 'FILTER_SANITIZE_STRING'); /** * if(redirect) * */ if (!empty($rtmedia_update) && 'true' === $rtmedia_update) { if (preg_match('/(?i)msie [1-9]/', $_user_agent)) { // if IE(<=9) set content type = text/plain header('Content-type: text/plain'); } else { header('Content-type: application/json'); } echo wp_json_encode($rtupload->media_ids); } else { // Media Upload Case - on album/post/profile/group if (isset($media[0])) { $data = array('media_id' => $media[0]->id, 'activity_id' => $activity_id, 'redirect_url' => $redirect_url, 'permalink' => $perma_link, 'cover_art' => $thumb_image); } else { $data = array(); } if (preg_match('/(?i)msie [1-9]/', $_user_agent)) { // if IE(<=9) set content type = text/plain header('Content-type: text/plain'); } else { header('Content-type: application/json'); } echo wp_json_encode(apply_filters('rtmedia_upload_endpoint_response', $data)); } die; } }
function insert_activity($id, $media) { if (!$this->activity_enabled()) { return false; } $activity = new RTMediaActivity($media->id, $media->privacy); $activity_content = $activity->create_activity_html(); $user = get_userdata($media->media_author); $username = '******' . get_rtmedia_user_link($media->media_author) . '">' . $user->user_nicename . '</a>'; $count = count($id); $media_const = 'RTMEDIA_' . strtoupper($media->media_type); if ($count > 1) { $media_const .= '_PLURAL'; } $media_const .= '_LABEL'; $media_str = constant($media_const); $action = sprintf($count == 1 ? __('%1$s added a %2$s', 'rtmedia') : __('%1$s added %4$d %3$s', 'rtmedia'), $username, $media->media_type, $media_str, $count); $action = apply_filters('rtmedia_buddypress_action_text_fitler', $action, $username, $count, $user->user_nicename, $media->media_type); $activity_args = array('user_id' => $user->ID, 'action' => $action, 'content' => $activity_content, 'type' => 'rtmedia_update', 'primary_link' => '', 'item_id' => $id); if ($media->context == "group" && function_exists("bp_get_group_status") && bp_get_group_status(groups_get_group(array("group_id" => $media->context_id))) != "public") { $activity_args["hide_sitewide"] = true; } if ($media->context == 'group' || 'profile') { $activity_args['component'] = $media->context; if ($media->context == 'group') { $activity_args['component'] = "groups"; $activity_args['item_id'] = $media->context_id; } } $activity_id = bp_activity_add($activity_args); bp_activity_update_meta($activity_id, 'rtmedia_privacy', $media->privacy == 0 ? -1 : $media->privacy); $this->model->update(array('activity_id' => $activity_id), array('id' => $media->id)); // insert/update activity details in rtmedia activity table $rtmedia_activity_model = new RTMediaActivityModel(); if (!$rtmedia_activity_model->check($activity_id)) { $rtmedia_activity_model->insert(array('activity_id' => $activity_id, 'user_id' => $media->media_author, 'privacy' => $media->privacy)); } else { $rtmedia_activity_model->update(array('activity_id' => $activity_id, 'user_id' => $media->media_author, 'privacy' => $media->privacy), array('activity_id' => $activity_id)); } return $activity_id; }
function rtmedia_api_process_rtmedia_upload_media_request() { $this->rtmediajsonapifunction->rtmedia_api_verfiy_token(); //Error Codes for new look $ec_no_file = 140001; $msg_no_file = esc_html__('no file', 'buddypress-media'); $ec_invalid_file_string = 140005; $msg_invalid_file_string = esc_html__('invalid file string', 'buddypress-media'); $ec_image_type_missing = 140006; $msg_image_type_missing = esc_html__('image type missing', 'buddypress-media'); $ec_no_file_title = 140002; $msg_no_file_title = esc_html__('no title', 'buddypress-media'); $ec_invalid_image = 140003; $msg_invalid_image = esc_html__('upload failed, check size and file type', 'buddypress-media'); $ec_look_updated = 140004; $msg_look_updated = esc_html__('media updated', 'buddypress-media'); $description = ''; $rtmedia_file = filter_input(INPUT_POST, 'rtmedia_file', FILTER_SANITIZE_STRING); $image_type = filter_input(INPUT_POST, 'image_type', FILTER_SANITIZE_STRING); $title = filter_input(INPUT_POST, 'title', FILTER_SANITIZE_STRING); $updated = false; $uploaded_look = false; if (empty($rtmedia_file) && empty($_FILES['rtmedia_file'])) { wp_send_json($this->rtmedia_api_response_object('FALSE', $ec_no_file, $msg_no_file)); } if (!empty($rtmedia_file)) { if (empty($image_type)) { wp_send_json($this->rtmedia_api_response_object('FALSE', $ec_image_type_missing, $msg_image_type_missing)); } if (empty($title)) { wp_send_json($this->rtmedia_api_response_object('FALSE', $ec_no_file_title, $msg_no_file_title)); } } if (!empty($_FILES['rtmedia_file'])) { $_POST['rtmedia_upload_nonce'] = $_REQUEST['rtmedia_upload_nonce'] = wp_create_nonce('rtmedia_upload_nonce'); $_POST['rtmedia_simple_file_upload'] = $_REQUEST['rtmedia_simple_file_upload'] = 1; $_POST['context'] = $_REQUEST['context'] = !empty($_REQUEST['context']) ? wp_unslash($_REQUEST['context']) : 'profile'; $_POST['context_id'] = $_REQUEST['context_id'] = !empty($_REQUEST['context_id']) ? absint($_REQUEST['context_id']) : $this->user_id; $_POST['mode'] = $_REQUEST['mode'] = 'file_upload'; $_POST['media_author'] = $_REQUEST['media_author'] = $this->user_id; $upload = new RTMediaUploadEndpoint(); //todo refactor below function so it takes param also and use if passed else use POST request $uploaded_look = $upload->template_redirect(); } else { //Process rtmedia_file $img = $rtmedia_file; $str_replace = 'data:image/' . $image_type . ';base64,'; $img = str_replace($str_replace, '', $img); $rtmedia_file = base64_decode($img); if (!$rtmedia_file) { wp_send_json($this->rtmedia_api_response_object('FALSE', $ec_invalid_file_string, $msg_invalid_file_string)); } define('UPLOAD_DIR_LOOK', sys_get_temp_dir() . '/'); $tmp_name = UPLOAD_DIR_LOOK . $title; $file = $tmp_name . '.' . $image_type; $success = file_put_contents($file, $rtmedia_file); add_filter('upload_dir', array($this, 'api_new_media_upload_dir')); $new_look = wp_upload_bits($title . '.' . $image_type, '', $rtmedia_file); $new_look['type'] = 'image/' . $image_type; remove_filter('upload_dir', array($this, 'api_new_media_upload_dir')); foreach ($new_look as $key => $value) { $new_look[0][$key] = $value; unset($new_look[$key]); } //Jugaad if (!empty($tags)) { $tags = explode(',', $tags); } $album_id = filter_input(INPUT_POST, 'album_id', FILTER_SANITIZE_NUMBER_INT); $context_id = filter_input(INPUT_POST, 'context_id', FILTER_SANITIZE_NUMBER_INT); $context = filter_input(INPUT_POST, 'context', FILTER_SANITIZE_STRING); $privacy = filter_input(INPUT_POST, 'privacy', FILTER_SANITIZE_STRING); $tags = filter_input(INPUT_POST, 'tags', FILTER_SANITIZE_STRING); $uploaded['rtmedia_upload_nonce'] = wp_create_nonce('rtmedia_upload_nonce'); $uploaded['rtmedia_simple_file_upload'] = 1; $uploaded['context'] = !empty($context) ? $context : 'profile'; $uploaded['context_id'] = !empty($context_id) ? $context_id : $this->user_id; $uploaded['mode'] = 'file_upload'; $uploaded['media_author'] = $this->user_id; $uploaded['album_id'] = !empty($album_id) ? $album_id : RTMediaAlbum::get_default(); $uploaded['privacy'] = !empty($privacy) ? $privacy : get_rtmedia_default_privacy(); $uploaded['title'] = $title; $uploaded['description'] = $description; $uploaded['taxonomy'] = array(); $uploaded['custom_fields'] = array(); $rtmedia = new RTMediaMedia(); $rtupload = $rtmedia->add($uploaded, $new_look); $id = rtmedia_media_id($rtupload[0]); if (!empty($tags)) { wp_set_post_terms($id, $tags, 'media-category', true); } $media = $rtmedia->model->get(array('id' => $rtupload[0])); $rtmedia_nav = new RTMediaNav(); if (isset($media) && count($media) > 0) { $perma_link = get_rtmedia_permalink($media[0]->id); if ('photo' === $media[0]->media_type) { $thumb_image = rtmedia_image('rt_media_thumbnail', $rtupload[0], false); } elseif ('music' === $media[0]->media_type) { $thumb_image = $media[0]->cover_art; } else { $thumb_image = ''; } if ('group' === $media[0]->context) { $rtmedia_nav->refresh_counts($media[0]->context_id, array('context' => sanitize_text_field($media[0]->context), 'context_id' => intval($media[0]->context_id))); } else { $rtmedia_nav->refresh_counts($media[0]->media_author, array('context' => 'profile', 'media_author' => sanitize_text_field($media[0]->media_author))); } $activity_id = $rtmedia->insert_activity($media[0]->media_id, $media[0]); $rtmedia->model->update(array('activity_id' => $activity_id), array('id' => intval($rtupload[0]))); // $same_medias = $rtmedia->model->get(array('activity_id' => $activity_id)); $update_activity_media = array(); foreach ($same_medias as $a_media) { $update_activity_media[] = $a_media->id; } $privacy = 0; $obj_activity = new RTMediaActivity($update_activity_media, $privacy, false); global $wpdb, $bp; $updated = $wpdb->update($bp->activity->table_name, array('type' => 'rtmedia_update', 'content' => $obj_activity->create_activity_html()), array('id' => $activity_id)); // if there is only single media the $updated value will be false even if the value we are passing to check is correct. // So we need to hardcode the $updated to true if there is only single media for same activity if (1 === count($same_medias) && $activity_id) { $updated = true; } } } if ($updated || $uploaded_look) { wp_send_json($this->rtmedia_api_response_object('TRUE', $ec_look_updated, $msg_look_updated)); } else { wp_send_json($this->rtmedia_api_response_object('TRUE', $ec_invalid_image, $msg_invalid_image)); } }
function bp_activity_posted_update($content, $user_id, $activity_id) { global $wpdb, $bp; $updated_content = ""; // hook for rtmedia buddypress before activity posted do_action('rtmedia_bp_before_activity_posted', $content, $user_id, $activity_id); if (isset($_POST["rtMedia_attached_files"]) && is_array($_POST["rtMedia_attached_files"])) { $updated_content = $wpdb->get_var("select content from {$bp->activity->table_name} where id= {$activity_id}"); $objActivity = new RTMediaActivity($_POST["rtMedia_attached_files"], 0, $updated_content); $html_content = $objActivity->create_activity_html(); bp_activity_update_meta($activity_id, "bp_old_activity_content", $html_content); bp_activity_update_meta($activity_id, "bp_activity_text", $updated_content); $wpdb->update($bp->activity->table_name, array("type" => "rtmedia_update", "content" => $html_content), array("id" => $activity_id)); $mediaObj = new RTMediaModel(); $sql = "update {$mediaObj->table_name} set activity_id = '" . $activity_id . "' where blog_id = '" . get_current_blog_id() . "' and id in (" . implode(",", $_POST["rtMedia_attached_files"]) . ")"; $wpdb->query($sql); } // hook for rtmedia buddypress after activity posted do_action('rtmedia_bp_activity_posted', $updated_content, $user_id, $activity_id); if (isset($_POST['rtmedia-privacy'])) { $privacy = -1; if (is_rtmedia_privacy_enable()) { if (is_rtmedia_privacy_user_overide()) { $privacy = $_POST['rtmedia-privacy']; } else { $privacy = get_rtmedia_default_privacy(); } } bp_activity_update_meta($activity_id, 'rtmedia_privacy', $privacy); } }
/** * [rtmedia_edit_media_on_database] * Update Media details on database while admin edit reported media * @param [Array] $data Image Details * @param [Number] $post_ID Media ID * @return [array] $data */ function rtmedia_edit_media_on_database($data, $post_ID) { $post = get_post($post_ID); if ($_REQUEST) { if (isset($_REQUEST['postid']) && 'image-editor' == $_REQUEST['action'] && 'edit-attachment' == $_REQUEST['context']) { $media = new RTMediaModel(); $media_available = $media->get_media(array('media_id' => $_REQUEST['postid']), 0, 1); $media_id = $media_available[0]->id; if (!empty($media_available)) { $rtmedia_filepath_old = rtmedia_image('rt_media_activity_image', $media_id, false); if (isset($rtmedia_filepath_old)) { $is_valid_url = preg_match("/\\b(?:(?:https?|ftp):\\/\\/|www\\.)[-a-z0-9+&@#\\/%?=~_|!:,.;]*[-a-z0-9+&@#\\/%=~_|]/i", $rtmedia_filepath_old); if ($is_valid_url && function_exists('bp_is_active') && bp_is_active('activity')) { $thumbnailinfo = wp_get_attachment_image_src($post_ID, 'rt_media_activity_image'); $activity_id = rtmedia_activity_id($media_id); if ($post_ID && !empty($activity_id)) { global $wpdb, $bp; if (!empty($bp->activity)) { $media->model = new RTMediaModel(); $related_media_data = $media->model->get(array('activity_id' => $activity_id)); $related_media = array(); foreach ($related_media_data as $activity_media) { $related_media[] = $activity_media->id; } $activity_text = bp_activity_get_meta($activity_id, 'bp_activity_text'); $activity = new RTMediaActivity($related_media, 0, $activity_text); $activity_content_new = $activity->create_activity_html(); $activity_content = str_replace($rtmedia_filepath_old, wp_get_attachment_url($post_ID), $activity_content_new); $wpdb->update($bp->activity->table_name, array('content' => $activity_content), array('id' => $activity_id)); } } } } } } } return $data; }
function bp_activity_posted_update($content, $user_id, $activity_id) { global $wpdb, $bp; $updated_content = ''; // hook for rtmedia buddypress before activity posted do_action('rtmedia_bp_before_activity_posted', $content, $user_id, $activity_id); $rtmedia_attached_files = filter_input(INPUT_POST, 'rtMedia_attached_files', FILTER_DEFAULT, FILTER_REQUIRE_ARRAY); if (is_array($rtmedia_attached_files)) { $updated_content = $wpdb->get_var("select content from {$bp->activity->table_name} where id= {$activity_id} limit 1"); // @codingStandardsIgnoreLine $obj_activity = new RTMediaActivity($rtmedia_attached_files, 0, $updated_content); $html_content = $obj_activity->create_activity_html(); bp_activity_update_meta($activity_id, 'bp_old_activity_content', $html_content); bp_activity_update_meta($activity_id, 'bp_activity_text', $updated_content); $wpdb->update($bp->activity->table_name, array('type' => 'rtmedia_update', 'content' => $html_content), array('id' => $activity_id)); $media_obj = new RTMediaModel(); //Credit faisal : https://gist.github.com/faishal/c4306ae7267fff976465 $in_str_arr = array_fill(0, count($rtmedia_attached_files), '%d'); $in_str = join(',', $in_str_arr); $sql = $wpdb->prepare("update {$media_obj->table_name} set activity_id = %d where blog_id = %d and ", $activity_id, get_current_blog_id()); // @codingStandardsIgnoreLine $form_id_where = $wpdb->prepare("id IN ({$in_str})", $rtmedia_attached_files); $sql .= $form_id_where; $wpdb->query($sql); // @codingStandardsIgnoreLine } // hook for rtmedia buddypress after activity posted do_action('rtmedia_bp_activity_posted', $updated_content, $user_id, $activity_id); $rtmedia_privacy = filter_input(INPUT_POST, 'rtmedia-privacy', FILTER_SANITIZE_NUMBER_INT); if (null !== $rtmedia_privacy) { $privacy = -1; if (is_rtmedia_privacy_enable()) { if (is_rtmedia_privacy_user_overide()) { $privacy = $rtmedia_privacy; } else { $privacy = get_rtmedia_default_privacy(); } } bp_activity_update_meta($activity_id, 'rtmedia_privacy', $privacy); // insert/update activity details in rtmedia activity table $rtmedia_activity_model = new RTMediaActivityModel(); if (!$rtmedia_activity_model->check($activity_id)) { $rtmedia_activity_model->insert(array('activity_id' => $activity_id, 'user_id' => $user_id, 'privacy' => $privacy)); } else { $rtmedia_activity_model->update(array('activity_id' => $activity_id, 'user_id' => $user_id, 'privacy' => $privacy), array('activity_id' => $activity_id)); } } }