Файл: system/modules/videos.php
Строк: 694
<?php
/*
Appointment: Видео
File: videos.php
Author: f0rt1
Engine: Vii Engine
Copyright: NiceWeb Group (с) 2011
e-mail: niceweb@i.ua
URL: http://www.niceweb.in.ua/
ICQ: 427-825-959
Данный код защищен авторскими правами
*/
if(!defined('MOZG')){
die('Hacking attempt!');
}
if($ajax == 'yes')
NoAjaxQuery();
if($logged){
$act = $_GET['act'];
$user_id = $user_info['user_id'];
$limit_vieos = 20;
switch($act){
//################### Страница добавления видео ###################//
case "add":
NoAjaxQuery();
$tpl->load_template('videos/add.tpl');
$tpl->compile('content');
AjaxTpl();
die();
break;
//################### Добавление видео в БД ###################//
case "send":
NoAjaxQuery();
if($config['video_mod_add'] == 'yes'){
$good_video_lnk = ajax_utf8(textFilter($_POST['good_video_lnk']));
$title = ajax_utf8(textFilter($_POST['title'], false, true));
$descr = ajax_utf8(textFilter($_POST['descr'], 3000));
$privacy = intval($_POST['privacy']);
if($privacy <= 0 OR $privacy > 3) $privacy = 1;
//Если youtube то добавляем префикс src=" и составляем ответ для скрипта, для вставки в БД
if(preg_match("/src="http://www.youtube.com|src="http://youtube.com/i", 'src="'.$good_video_lnk)){
$good_video_lnk = str_replace(array('#', '!'), '', $good_video_lnk);
$exp_y = explode('v=', $good_video_lnk);
$exp_x = explode('&', $exp_y[1]);
$result_video_lnk = '<iframe width="770" height="420" src="http://www.youtube.com/embed/'.$exp_x[0].'" frameborder="0" allowfullscreen></iframe>';
}
//Если rutube, То добавляем префикс value="
if(preg_match("/value="http://www.rutube.ru|value="http://rutube.ru/i", 'value="'.$good_video_lnk)){
$exp_frutube = explode('?v=', $good_video_lnk);
$result_video_lnk = '<OBJECT width="770" height="420"><PARAM name="movie" value="http://video.rutube.ru/'.$exp_frutube[1].'"></PARAM><PARAM name="wmode" value="window"></PARAM><PARAM name="allowFullScreen" value="true"></PARAM><EMBED src="http://video.rutube.ru/'.$exp_frutube[1].'" type="application/x-shockwave-flash" wmode="window" width="770" height="420" allowFullScreen="true" ></EMBED></OBJECT>';
}
//Если vimeo, То добавляем префикс src="
if(preg_match("/src="http://www.vimeo.com|src="http://vimeo.com/i", 'src="'.$good_video_lnk)){
$exp_frutube = explode('com/', $good_video_lnk);
$result_video_lnk = '<iframe src="http://player.vimeo.com/video/'.$exp_frutube[1].'" width="770" height="420" frameborder="0"></iframe>';
}
//Если smotri, То добавляем префикс src="
if(preg_match("/src="http://www.smotri.com|src="http://smotri.com/i", 'src="'.$good_video_lnk)){
$exp = explode('id=', str_replace('#', '', $good_video_lnk));
$result_video_lnk = '<object id="smotriComVideoPlayer'.$exp[1].'_1314557535.5897_7726" classid="clsid:d27cdb6e-ae6d-11cf-96b8-444553540000" width="770" height="420"><param name="movie" value="http://pics.smotri.com/player.swf?file='.$exp[1].'&bufferTime=3&autoStart=false&str_lang=rus&xmlsource=http%3A%2F%2Fpics.smotri.com%2Fcskins%2Fblue%2Fskin_color.xml&xmldatasource=http%3A%2F%2Fpics.smotri.com%2Fskin_ng.xml" /><param name="allowScriptAccess" value="always" /><param name="allowFullScreen" value="true" /><param name="bgcolor" value="#ffffff" /><embed src="http://pics.smotri.com/player.swf?file='.$exp[1].'&bufferTime=3&autoStart=false&str_lang=rus&xmlsource=http%3A%2F%2Fpics.smotri.com%2Fcskins%2Fblue%2Fskin_color.xml&xmldatasource=http%3A%2F%2Fpics.smotri.com%2Fskin_ng.xml" quality="high" allowscriptaccess="always" allowfullscreen="true" wmode="opaque" width="770" height="420" type="application/x-shockwave-flash"></embed></object>';
}
//Формируем данные о фото
$photo = $db->safesql(ajax_utf8(htmlspecialchars(trim($_POST['photo']))));
$photo = str_replace("\", "/", $photo);
$img_name_arr = explode(".", $photo);
$img_format = totranslit(end($img_name_arr));
$image_name = substr(md5(time().md5($good_video_lnk)), 0, 15);
//Разришенные форматы
$allowed_files = array('jpg', 'jpeg', 'jpe', 'png', 'gif');
//Загружаем картинку на сайт
if(in_array(strtolower($img_format), $allowed_files) && preg_match("/http:///i", $photo) && $result_video_lnk){
//Директория загрузки фото
$upload_dir = ROOT_DIR.'/uploads/videos/'.$user_id;
//Если нет папки юзера, то создаём её
if(!is_dir($upload_dir)){
@mkdir($upload_dir, 0777);
@chmod($upload_dir, 0777);
}
//Подключаем класс для фотографий
include ENGINE_DIR.'/classes/images.php';
@copy($photo, $upload_dir.'/'.$image_name.'.'.$img_format);
$tmb = new thumbnail($upload_dir.'/'.$image_name.'.'.$img_format);
$tmb->size_auto('175x131');
$tmb->jpeg_quality(100);
$tmb->save($upload_dir.'/'.$image_name.'.'.$img_format);
}
if($result_video_lnk AND $title){
$photo = $config['home_url'].'uploads/videos/'.$user_id.'/'.$image_name.'.'.$img_format;
$db->query("INSERT INTO `".PREFIX."_videos` SET owner_user_id = '{$user_id}', video = '{$result_video_lnk}', photo = '{$photo}', title = '{$title}', descr = '{$descr}', add_date = NOW(), privacy = '{$privacy}'");
$dbid = $db->insert_id();
$db->query("UPDATE `".PREFIX."_users` SET user_videos_num = user_videos_num+1 WHERE user_id = '{$user_id}'");
$photo = str_replace($config['home_url'], '/', $photo);
//Добавляем действия в ленту новостей
$generateLastTime = $server_time-10800;
$row = $db->super_query("SELECT ac_id, action_text FROM `".PREFIX."_news` WHERE action_time > '{$generateLastTime}' AND action_type = 2 AND ac_user_id = '{$user_id}'");
if($row)
$db->query("UPDATE `".PREFIX."_news` SET action_text = '{$dbid}|{$photo}||{$row['action_text']}', action_time = '{$server_time}' WHERE ac_id = '{$row['ac_id']}'");
else
$db->query("INSERT INTO `".PREFIX."_news` SET ac_user_id = '{$user_id}', action_type = 2, action_text = '{$dbid}|{$photo}', action_time = '{$server_time}'");
//Чистим кеш
mozg_mass_clear_cache_file("user_{$user_id}/page_videos_user|user_{$user_id}/page_videos_user_friends|user_{$user_id}/page_videos_user_all|user_{$user_id}/profile_{$user_id}|user_{$user_id}/videos_num_all|user_{$user_id}/videos_num_friends");
if($_POST['notes'] == 1)
echo "{$photo}|{$user_id}|{$dbid}";
}
} else
echo 'error';
die();
break;
//################### Страница добавления видео ###################//
case "upload_add":
$tpl->load_template('videos/upload.tpl');
$tpl->compile('content');
AjaxTpl();
die();
break;
//################### Загрузка с компьютера ###################//
case "upload":
// Получаем данные о файле
$file_tmp = $_FILES['uploadfile']['tmp_name'];
// Оригинальное название для оприделения формата
$file_name = totranslit($_FILES['uploadfile']['name']);
// Получаем уникальное имя для файла
$file_rename = substr(md5($server_time+rand(1,100000)), 0, 15);
// Размер файла
$file_size = $_FILES['uploadfile']['size'];
// Формат файла
$type = strtolower(end(explode(".", $file_name)));
// Поддержка форматов, конфигурацыя модуля.
if($type == 'mp4'||'mpeg'||'avi'||'ogg'||'flv' AND $config['video_mod_add'] == 'yes' AND $file_size < 500000000){
// Формирование текста и запись.
$title = ajax_utf8(textFilter($_POST['title'], false, true));
$descr = ajax_utf8(textFilter($_POST['descr'], 3000));
// Если нету названия и описания то автоматически записываем в таблицу об этом.
if(isset($title) AND empty($title)) $title = 'Видео без названия.';
if(isset($descr) AND empty($descr)) $descr = 'Информация о видео отсутствует.';
// Приватность просмотра видеоматериала.
$privacy = intval($_POST['privacy']);
if($privacy <= 0 OR $privacy > 3) $privacy = 1;
// Создаем или ищем созданый рание путь загрузки видеоматериала.
$video_dir = ROOT_DIR.'/uploads/videos/'.$user_id.'/';
if(!is_dir($video_dir)){
@mkdir($video_dir, 0777);
@chmod($video_dir, 0777);
}
//Подключаем библиотеку ffmpeg.
if( stristr($_SERVER['HTTP_USER_AGENT'], 'Windows NT 6.1') ) {
$path_to_mpeg = module_root .'/usr/bin/ffmpeg/ffmpeg.exe';
}else {
$path_to_mpeg = module_root .'/usr/bin/ffmpeg';
}
// Получаем росширение файла.
$res_type = '.'.$type;
// Генерируем путь куда будет загружено видео материалы.
if(move_uploaded_file($file_tmp, $video_dir.$file_rename.$res_type)){
// URL Самого видео обекта.
$result_video = $config['home_url'].'uploads/videos/'.$user_id.'/'.$file_rename.$res_type;
// Конвертируем видео материал в flv. exec
//$convert = $video_dir.$file_rename.'.flv';
//$formating = exec(''.$result_video.' -i '.$file_tmp.' -f flv -b 200000 '.$convert.'');
// Создаем обьект из видео файла
$mov = new ffmpeg_movie($result_video, false);
// Получаем высоту и ширину
$w = $mov->GetFrameWidth();
$h = $mov->GetFrameHeight();
// Берем третий кадр
$frame = $mov->getFrame(400);
// Создаем ресурс кадра
$gd = $frame->toGDImage();
// Создаем картинку с размерами
$image_stat = imageCreateTrueColor(180, 130);
$image_orig = imageCreateTrueColor(640, 480);
// Заносим на нее наш кадр и изменяем его размеры
imageCopyResampled($image_stat, $gd, 0, 0, 0, 0, 180, 130, $w, $h);
imageCopyResampled($image_orig, $gd, 0, 0, 0, 0, 640, 480, $w, $h);
// Выводим JPEG картинку
@imagejpeg($image_stat, 'uploads/videos/'.$user_id.'/'.$file_rename.'.jpg', 100);
@imagejpeg($image_orig, 'uploads/videos/'.$user_id.'/original_'.$file_rename.'.jpg', 100);
// Чистим toGDImage
imagedestroy($image_stat, $image_orig);
// Получаем сылку к нашому обекту.
$result_img = $config['home_url'].'uploads/videos/'.$user_id.'/'.$file_rename.'.jpg';
$result_img_original = $config['home_url'].'uploads/videos/'.$user_id.'/original_'.$file_rename.'.jpg';
// Компилируем сам код для прогрователя.
$frame_video = '<object width="770" height="420" id="sonetticFLVPlayer" classid="clsid:d27cdb6e-ae6d-11cf-96b8-444553540000" codebase="http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=9,0,0,0">
<param name="movie" value="'.$config['home_url'].'swf/cinemaplayer.swf"/>
<param name="allowFullScreen" value="true"/>
<param name="allowScriptAccess" value="sameDomain" />
<param name="bgcolor" value="#161616"/>
<param name="flashvars" value="'.$result_video.'"/>
<embed src="'.$config['home_url'].'swf/cinemaplayer.swf" name="sonetticFLVPlayer" type="application/x-shockwave-flash" width="770" height="420" bgcolor="#161616" allowFullScreen="true" allowScriptAccess="sameDomain" flashvars="poster='.$result_img_original.'&content='.$result_video.'"> </embed>
</object>';
// Вносим запись о видео материале.
$db->query("INSERT INTO `".PREFIX."_videos` SET owner_user_id = '{$user_id}', video = '{$frame_video}', video_unlink = '{$result_video}', photo_original = '{$result_img_original}', photo = '{$result_img}', title = '{$title}', descr = '{$descr}', add_date = NOW(), privacy = '{$privacy}'");
// Получаем ID
$dbid = $db->insert_id();
// Перезаписываем запись о количестве видео Usera.
$db->query("UPDATE `".PREFIX."_users` SET user_videos_num = user_videos_num+1 WHERE user_id = '{$user_id}'");
// Регенирируем сылку обекта (фотографии).
$photo = str_replace($config['home_url'], '/', $result_img);
//Добавляем действия в ленту новостей
$generateLastTime = $server_time-10800;
$row = $db->super_query("SELECT ac_id, action_text FROM `".PREFIX."_news` WHERE action_time > '{$generateLastTime}' AND action_type = 2 AND ac_user_id = '{$user_id}'");
if($row)
$db->query("UPDATE `".PREFIX."_news` SET action_text = '{$dbid}|{$photo}||{$row['action_text']}', action_time = '{$server_time}' WHERE ac_id = '{$row['ac_id']}'");
else
$db->query("INSERT INTO `".PREFIX."_news` SET ac_user_id = '{$user_id}', action_type = 2, action_text = '{$dbid}|{$photo}', action_time = '{$server_time}'");
// Чистим кеш
mozg_mass_clear_cache_file("user_{$user_id}/page_videos_user|user_{$user_id}/page_videos_user_friends|user_{$user_id}/page_videos_user_all|user_{$user_id}/profile_{$user_id}|user_{$user_id}/videos_num_all|user_{$user_id}/videos_num_friends");
} else
echo 1;
} else
echo 1;
die();
break;
//################### Парсер . Загрузка данных о видео ###################//
case "load":
NoAjaxQuery();
$video_lnk = $_POST['video_lnk'];
if(preg_match("/http://www.youtube.com|http://youtube.com|http://rutube.ru|http://www.rutube.ru|http://www.vimeo.com|http://vimeo.com|http://smotri.com|http://www.smotri.com/i", $video_lnk)){
//Открываем ссылку
//Если ссылка youtube, то формируем xml ссылку для получения данных
if(preg_match("/http://www.youtube.com|http://youtube.com/i", $video_lnk)){
$exp_y = explode('v=', $video_lnk);
$exp_x = explode('&', $exp_y[1]);
$sock = fopen('http://www.youtube.com/oembed?url=http://www.youtube.com/watch?v='.$exp_x[0].'&format=xml', 'r');
} elseif(preg_match("/http://www.vimeo.com|http://vimeo.com/i", $video_lnk)){
$sock = fopen('http://vimeo.com/api/oembed.xml?url='.$video_lnk, 'r');
} else {
$sock = fopen($video_lnk, 'r');
}
if(!$sock){
echo 'no_serviece';
} else {
$html = '';
//Если сервис youtube, rutube, smotri то просто выводи
if(preg_match("/http://www.youtube.com|http://youtube.com|http://rutube.ru|http://www.rutube.ru|http://smotri.com|http://www.smotri.com/i", $video_lnk)){
while(!feof($sock)){
$html .= fgets($sock);
}
}
//Если сервис Vimeo, то сразу применяем кодировку utf-8, win-1251
if(preg_match("/http://www.vimeo.com|http://vimeo.com/i", $video_lnk)){
while(!feof($sock)){
$html .= ajax_utf8(fgets($sock));
}
}
fclose($sock);
//Если сервис Vimeo, то выводим без кодировки
$data = str_replace(array('[', ']'), array('&iqu;', '&iqu2;'), $html);
//Если сервис youtube применяем кодировку utf-8, win-1251
$data_all = ajax_utf8(str_replace(array('[', ']'), array('&iqu;', '&iqu2;'), $html));
//Если видеосервис youtube
if(preg_match("/http://www.youtube.com|http://youtube.com/i", $video_lnk)){
preg_match_all('`(<title>[^[]+</title>)`si', $data_all, $parse);
$res_title = rn_replace(str_replace(array('<title>', '</title>'), '', $parse[1][0]));
//Делаем фотку для youtube
$parse_start = explode('v=', $video_lnk);
$parse_end = explode('&', $parse_start[1]);
$res_img = "http://img.youtube.com/vi/{$parse_end[0]}/0.jpg";
}
//Если видеосервис rutube
if(preg_match("/http://rutube.ru|http://www.rutube.ru/i", $video_lnk)){
$data_rutube = iconv('koi8-u', 'windows-1251', str_replace(array('[', ']'), array('&iqu;', '&iqu2;'), $html));
preg_match_all('`(<meta property="og:title" content="[^[]+<meta property="og:description")`si', $data_rutube, $parse_rutube);
$res_title = rn_replace(str_replace(array('<meta property="og:title" content="', '<meta property="og:description"', '" />'), '', $parse_rutube[1][0]));
preg_match_all('`(<meta property="og:description" content="[^[]+<meta property="og:image")`si', $data_rutube, $parse_rutube_descr);
$res_descr = rn_replace(str_replace(array('<meta property="og:description" content="', '<meta property="og:image"', '" />'), '', $parse_rutube_descr[1][0]));
$exp_rutube_img = explode('v=', $video_lnk);
$exp_img_dir = substr($exp_rutube_img[1], 0, 2);
$exp_img_dir_2 = substr($exp_rutube_img[1], 2, 2);
$res_img = "http://tub.rutube.ru/thumbs/{$exp_img_dir}/{$exp_img_dir_2}/{$exp_rutube_img[1]}-1.jpg";
}
//Если видеосервис vimeo
if(preg_match("/http://www.vimeo.com|http://vimeo.com/i", $video_lnk)){
preg_match_all('`(<title>[^[]+</title>)`si', $data, $parse);
$res_title = str_replace(array('<title>', '</title>'), '', $parse[1][0]);
preg_match_all('`(<thumbnail_url>[^[]+</thumbnail_url>)`si', $data, $parse_img);
$res_img = str_replace(array('<thumbnail_url>', '</thumbnail_url>'), '', $parse_img[1][0]);
preg_match_all('`(<description>[^[]+</description>)`si', $data, $parse_descr);
$res_descr = myBrRn(rn_replace($parse_descr[1][0]));
}
//Если видеосервис smotri
if(preg_match("/http://smotri.com|http://www.smotri.com/i", $video_lnk)){
$html = iconv('utf-8', 'windows-1251', $html);
preg_match_all('`(<meta property="og:title" content="[^[]+<meta property="og:image")`si', $html, $parse_title);
$res_title = rn_replace(str_replace(array('<meta property="og:title" content="', '<meta property="og:image"', '" />'), '', $parse_title[1][0]));
preg_match_all('`(<link rel="image_src" href="[^[]+<!-- Open Graf Protocol. Facebook/Yandex -->)`si', $html, $parse_img);
$res_img = rn_replace(str_replace(array('<link rel="image_src" href="', '<!-- Open Graf Protocol. Facebook/Yandex -->', '" />'), '', $parse_img[1][0]));
}
$result_img = $res_img;
$result_title = trim(strip_tags(strtr($res_title, array(''' => "'", '"' => '"', '&iqu;' => '[', '&iqu2;' => ']'))));
$result_descr = trim(strip_tags($res_descr));
if($result_img && $result_title)
echo "{$result_img}:|:{$result_title}:|:{$result_descr}";
else
echo 'no_serviece';
}
} else
echo 'no_serviece';
die();
break;
//################### Удаление видео ###################//
/*
case "delet":
NoAjaxQuery();
$vid = intval($_POST['vid']);
if($vid){
$row = $db->super_query("SELECT owner_user_id, photo, public_id FROM `".PREFIX."_videos` WHERE id = '{$vid}'");
if($row['owner_user_id'] == $user_id AND !$row['public_id']){
$db->query("DELETE FROM `".PREFIX."_videos` WHERE id = '{$vid}'");
$db->query("DELETE FROM `".PREFIX."_videos_comments` WHERE video_id = '{$vid}'");
$db->query("UPDATE `".PREFIX."_users` SET user_videos_num = user_videos_num-1 WHERE user_id = '{$row['owner_user_id']}'");
//Удаляем фотку
$exp_photo = explode('/', $row['photo']);
$photo_name = end($exp_photo);
@unlink(ROOT_DIR.'/uploads/videos/'.$row['owner_user_id'].'/'.$photo_name);
//Чистим кеш
mozg_mass_clear_cache_file("user_{$row['owner_user_id']}/page_videos_user|user_{$row['owner_user_id']}/page_videos_user_friends|user_{$row['owner_user_id']}/page_videos_user_all|user_{$row['owner_user_id']}/profile_{$row['owner_user_id']}|user_{$row['owner_user_id']}/videos_num_all|user_{$row['owner_user_id']}/videos_num_friends|wall/video{$vid}");
}
}
die();
break;
*/
//################### Удаление видео ###################//
case "delet":
NoAjaxQuery();
$vid = intval($_POST['vid']);
if($vid){
$row = $db->super_query("SELECT owner_user_id, photo, video_unlink FROM `".PREFIX."_videos` WHERE id = '{$vid}'");
if($row['owner_user_id'] == $user_id){
$db->query("DELETE FROM `".PREFIX."_videos` WHERE id = '{$vid}'");
$db->query("DELETE FROM `".PREFIX."_videos_comments` WHERE video_id = '{$vid}'");
$db->query("UPDATE `".PREFIX."_users` SET user_videos_num = user_videos_num-1 WHERE user_id = '{$row['owner_user_id']}'");
// Удаляем фотку
$exp_photo = explode('/', $row['photo']);
$photo_name = end($exp_photo);
@unlink(ROOT_DIR.'/uploads/videos/'.$row['owner_user_id'].'/'.$photo_name);
// Удаляем видео, если было оно загруженое с компютера..
$exp_unlink = explode('/', $row['video_unlink']);
$video_name = end($exp_unlink);
@unlink(ROOT_DIR.'/uploads/videos/'.$row['owner_user_id'].'/'.$video_name);
// Удаляем видео, если было оно загруженое с компютера..
$exp_photo_original = explode('/', $row['photo']);
$photo_original_name = end($exp_photo_original);
@unlink(ROOT_DIR.'/uploads/videos/'.$row['owner_user_id'].'/original_'.$photo_original_name);
// Чистим кеш
mozg_mass_clear_cache_file("user_{$row['owner_user_id']}/page_videos_user|user_{$row['owner_user_id']}/page_videos_user_friends|user_{$row['owner_user_id']}/page_videos_user_all|user_{$row['owner_user_id']}/profile_{$row['owner_user_id']}|user_{$row['owner_user_id']}/videos_num_all|user_{$row['owner_user_id']}/videos_num_friends");
}
}
die();
break;
//################### Страница редактирования видео ###################//
case "edit":
NoAjaxQuery();
$vid = intval($_POST['vid']);
if($vid){
$row = $db->super_query("SELECT title, descr, privacy FROM `".PREFIX."_videos` WHERE id = '{$vid}' AND owner_user_id = '{$user_id}'");
if($row){
$tpl->load_template('videos/editpage.tpl');
$tpl->set('{title}', stripslashes($row['title']));
$tpl->set('{descr}', stripslashes(myBrRn($row['descr'])));
$tpl->set('{privacy}', $row['privacy']);
$tpl->set('{privacy-text}', strtr($row['privacy'], array('1' => 'Все пользователи', '2' => 'Только друзья', '3' => 'Только я')));
$tpl->compile('content');
AjaxTpl();
}
}
die();
break;
//################### Сохранение отредактированых данных ###################//
case "editsave":
NoAjaxQuery();
$vid = intval($_POST['vid']);
if($vid){
$title = ajax_utf8(textFilter($_POST['title'], false, true));
$descr = ajax_utf8(textFilter($_POST['descr'], 3000));
$privacy = intval($_POST['privacy']);
if($privacy <= 0 OR $privacy > 3) $privacy = 1;
//Проверка на существования записи
$row = $db->super_query("SELECT owner_user_id, public_id FROM `".PREFIX."_videos` WHERE id = '{$vid}'");
if($row['owner_user_id'] == $user_id AND !$row['public_id']){
$db->query("UPDATE `".PREFIX."_videos` SET title = '{$title}', descr = '{$descr}', privacy = '{$privacy}' WHERe id = '{$vid}'");
echo stripslashes($descr);
//Чистим кеш
mozg_mass_clear_cache_file("user_{$row['owner_user_id']}/page_videos_user|user_{$row['owner_user_id']}/page_videos_user_friends|user_{$row['owner_user_id']}/page_videos_user_all|user_{$row['owner_user_id']}/videos_num_all|user_{$row['owner_user_id']}/videos_num_friends|wall/video{$vid}");
}
}
die();
break;
//################### Просмотр видео ###################//
case "view":
NoAjaxQuery();
include ENGINE_DIR.'/modules/video.php';
die();
break;
//################### Добавления комментария в базу ###################//
case "addcomment":
NoAjaxQuery();
if($config['video_mod_comm'] == 'yes'){
$vid = intval($_POST['vid']);
$comment = ajax_utf8(textFilter($_POST['comment']));
//Провекра на существования видео
$check_video = $db->super_query("SELECT owner_user_id, photo, public_id FROM `".PREFIX."_videos` WHERE id = '{$vid}'");
//ЧС
$CheckBlackList = CheckBlackList($check_video['owner_user_id']);
if(!$CheckBlackList){
if($check_video AND isset($comment) AND !empty($comment)){
$db->query("INSERT INTO `".PREFIX."_videos_comments` SET author_user_id = '{$user_id}', video_id = '{$vid}', text = '{$comment}', add_date = NOW()");
$id = $db->insert_id();
$db->query("UPDATE `".PREFIX."_videos` SET comm_num = comm_num+1 WHERE id = '{$vid}'");
$tpl->load_template('videos/comment.tpl');
$tpl->set('{online}', $lang['online']);
$tpl->set('{uid}', $user_id);
$tpl->set('{author}', $user_info['user_search_pref']);
$tpl->set('{comment}', stripslashes($comment));
$tpl->set('[owner]', '');
$tpl->set('[/owner]', '');
$tpl->set('{id}', $id);
$tpl->set('{date}', langdate('сегодня в H:i', time()));
if($user_info['user_photo'])
$tpl->set('{ava}', $config['home_url'].'uploads/users/'.$user_id.'/50_'.$user_info['user_photo']);
else
$tpl->set('{ava}', '{theme}/images/no_ava_50.png');
$tpl->compile('content');
if(!$check_video['public_id']){
//Добавляем действие в ленту новостей "ответы" владельцу фотографии
if($user_id != $check_video['owner_user_id']){
$check_video['photo'] = str_replace($config['home_url'], '/', $check_video['photo']);
$comment = str_replace("|", "|", $comment);
$db->query("INSERT INTO `".PREFIX."_news` SET ac_user_id = '{$user_id}', action_type = 9, action_text = '{$comment}|{$check_video['photo']}|{$vid}', obj_id = '{$id}', for_user_id = '{$check_video['owner_user_id']}', action_time = '{$server_time}'");
//Вставляем событие в моментальные оповещания
$row_userOW = $db->super_query("SELECT user_last_visit FROM `".PREFIX."_users` WHERE user_id = '{$check_video['owner_user_id']}'");
$update_time = $server_time - 70;
if($row_userOW['user_last_visit'] >= $update_time){
$db->query("INSERT INTO `".PREFIX."_updates` SET for_user_id = '{$check_video['owner_user_id']}', from_user_id = '{$user_id}', type = '3', date = '{$server_time}', text = '{$comment}', user_photo = '{$user_info['user_photo']}', user_search_pref = '{$user_info['user_search_pref']}', lnk = '/video{$check_video['owner_user_id']}_{$vid}'");
mozg_create_cache("user_{$check_video['owner_user_id']}/updates", 1);
//ИНАЧЕ Добавляем +1 юзеру для оповещания
} else {
$cntCacheNews = mozg_cache('user_'.$check_video['owner_user_id'].'/new_news');
mozg_create_cache('user_'.$check_video['owner_user_id'].'/new_news', ($cntCacheNews+1));
}
//Отправка уведомления на E-mail
if($config['news_mail_3'] == 'yes'){
$rowUserEmail = $db->super_query("SELECT user_name, user_email FROM `".PREFIX."_users` WHERE user_id = '".$check_video['owner_user_id']."'");
if($rowUserEmail['user_email']){
include_once ENGINE_DIR.'/classes/mail.php';
$mail = new dle_mail($config);
$rowMyInfo = $db->super_query("SELECT user_search_pref FROM `".PREFIX."_users` WHERE user_id = '".$user_id."'");
$rowEmailTpl = $db->super_query("SELECT text FROM `".PREFIX."_mail_tpl` WHERE id = '3'");
$rowEmailTpl['text'] = str_replace('{%user%}', $rowUserEmail['user_name'], $rowEmailTpl['text']);
$rowEmailTpl['text'] = str_replace('{%user-friend%}', $rowMyInfo['user_search_pref'], $rowEmailTpl['text']);
$rowEmailTpl['text'] = str_replace('{%rec-link%}', $config['home_url'].'video'.$check_video['owner_user_id'].'_'.$vid, $rowEmailTpl['text']);
$mail->send($rowUserEmail['user_email'], 'Новый комментарий к Вашей видеозаписи', $rowEmailTpl['text']);
}
}
}
//Чистим кеш
mozg_mass_clear_cache_file("user_{$check_video['owner_user_id']}/page_videos_user|user_{$check_video['owner_user_id']}/page_videos_user_friends|user_{$check_video['owner_user_id']}/page_videos_user_all");
} else
mozg_clear_cache_file("groups/video{$check_video['public_id']}");
AjaxTpl();
}
}
} else
echo 'error';
die();
break;
//################### Удаления комментария ###################//
case "delcomment":
NoAjaxQuery();
$comm_id = intval($_POST['comm_id']);
//Проверка на существования комментария, и выводим ИД владельца видео
$row = $db->super_query("SELECT tb1.video_id, author_user_id, tb2.owner_user_id, public_id FROM `".PREFIX."_videos_comments` tb1, `".PREFIX."_videos` tb2 WHERE tb1.id = '{$comm_id}' AND tb1.video_id = tb2.id");
if($row['public_id']){
$infoGroup = $db->super_query("SELECT admin FROM `".PREFIX."_communities` WHERE id = '{$row['public_id']}'");
if(strpos($infoGroup['admin'], "u{$user_id}|") !== false) $public_admin = true;
else $public_admin = false;
if($public_admin AND $row){
$db->query("DELETE FROM `".PREFIX."_videos_comments` WHERE id = '{$comm_id}'");
$db->query("DELETE FROM `".PREFIX."_news` WHERE obj_id = '{$comm_id}' AND action_type = 9");
$db->query("UPDATE `".PREFIX."_videos` SET comm_num = comm_num-1 WHERE id = '{$row['video_id']}'");
mozg_clear_cache_file("groups/video{$row['public_id']}");
}
} else {
if($row['author_user_id'] == $user_id OR $row['owner_user_id'] == $user_id){
$db->query("DELETE FROM `".PREFIX."_videos_comments` WHERE id = '{$comm_id}'");
$db->query("DELETE FROM `".PREFIX."_news` WHERE obj_id = '{$comm_id}' AND action_type = 9");
$db->query("UPDATE `".PREFIX."_videos` SET comm_num = comm_num-1 WHERE id = '{$row['video_id']}'");
//Чистим кеш
mozg_mass_clear_cache_file("user_{$row['owner_user_id']}/page_videos_user|user_{$row['owner_user_id']}/page_videos_user_friends|user_{$row['owner_user_id']}/page_videos_user_all");
}
}
die();
break;
//################### Показ всех комментариев ###################//
case "all_comm":
NoAjaxQuery();
$vid = intval($_POST['vid']);
$comm_num = intval($_POST['num']);
$owner_id = intval($_POST['owner_id']);
$row = $db->super_query("SELECT public_id FROM `".PREFIX."_videos` WHERE id = '{$vid}'");
if($row['public_id']){
$infoGroup = $db->super_query("SELECT admin FROM `".PREFIX."_communities` WHERE id = '{$row['public_id']}'");
if(strpos($infoGroup['admin'], "u{$user_id}|") !== false) $public_admin = true;
else $public_admin = false;
}
if($comm_num > 3 AND $vid AND $owner_id){
$limit_comm = $comm_num-3;
$sql_comm = $db->super_query("SELECT tb1.id, author_user_id, text, add_date, tb2.user_search_pref, user_photo, user_last_visit, user_logged_mobile FROM `".PREFIX."_videos_comments` tb1, `".PREFIX."_users` tb2 WHERE tb1.video_id = '{$vid}' AND tb1.author_user_id = tb2.user_id ORDER by `add_date` ASC LIMIT 0, {$limit_comm}", 1);
$tpl->load_template('videos/comment.tpl');
foreach($sql_comm as $row_comm){
$tpl->set('{uid}', $row_comm['author_user_id']);
$tpl->set('{author}', $row_comm['user_search_pref']);
$tpl->set('{comment}', stripslashes($row_comm['text']));
$tpl->set('{id}', $row_comm['id']);
OnlineTpl($row_comm['user_last_visit'], $row_comm['user_logged_mobile']);
megaDate(strtotime($row_comm['add_date']));
if($row_comm['author_user_id'] == $user_id OR $owner_id == $user_id OR $public_admin){
$tpl->set('[owner]', '');
$tpl->set('[/owner]', '');
} else
$tpl->set_block("'\[owner\](.*?)\[/owner\]'si","");
if($row_comm['user_photo'])
$tpl->set('{ava}', $config['home_url'].'uploads/users/'.$row_comm['author_user_id'].'/50_'.$row_comm['user_photo']);
else
$tpl->set('{ava}', '{theme}/images/no_ava_50.png');
$tpl->compile('content');
}
}
AjaxTpl();
die();
break;
//################### Страница всех видео юзера, для прикрепления видео кому-то на стену ###################//
case "all_videos":
NoAjaxQuery();
$notes = intval($_POST['notes']);
//Для навигатор
if($_POST['page'] > 0) $page = intval($_POST['page']); else $page = 1;
$gcount = 24;
$limit_page = ($page-1)*$gcount;
//Делаем SQL запрос на вывод
$sql_ = $db->super_query("SELECT id, photo, title FROM `".PREFIX."_videos` WHERE owner_user_id = '{$user_id}' AND public_id = '0' ORDER by `add_date` DESC LIMIT {$limit_page}, {$gcount}", 1);
//Выводим кол-во видео
$count = $db->super_query("SELECT user_videos_num FROM `".PREFIX."_users` WHERE user_id = '{$user_id}'");
if($count['user_videos_num']){
if($notes)
$tpl->load_template('videos/box_all_video_notes_top.tpl');
else
$tpl->load_template('videos/box_all_video_top.tpl');
$tpl->set('[top]', '');
$tpl->set('[/top]', '');
$tpl->set('{photo-num}', $count['user_videos_num'].' '.gram_record($count['user_videos_num'], 'videos'));
$tpl->set_block("'\[bottom\](.*?)\[/bottom\]'si","");
$tpl->compile('content');
//Выводим циклом видео
if(!$notes)
$tpl->load_template('videos/box_all_video.tpl');
else
$tpl->load_template('videos/box_all_video_notes.tpl');
foreach($sql_ as $row){
$tpl->set('{photo}', $row['photo']);
$tpl->set('{title}', stripslashes($row['title']));
$tpl->set('{video-id}', $row['id']);
$tpl->set('{user-id}', $user_id);
$tpl->compile('content');
}
box_navigation($gcount, $count['user_videos_num'], $page, 'wall.attach_addvideo', $notes);
$tpl->load_template('albums_editcover.tpl');
$tpl->set('[bottom]', '');
$tpl->set('[/bottom]', '');
$tpl->set_block("'\[top\](.*?)\[/top\]'si","");
$tpl->compile('content');
} else
if($notes)
echo $lang['videos_box_none'].'<div class="button_div_gray fl_l" style="margin-left:210px;margin-top:20px"><button onClick="videos.add(1)">Добавить новый видеоролик</button></div>';
else
echo $lang['videos_box_none'];
AjaxTpl();
die();
break;
//################### Страница всех видео юзера, для прикрепления видео в сообщество ###################//
case "all_videos_public":
NoAjaxQuery();
$pid = intval($_POST['pid']);
//Для навигатор
if($_POST['page'] > 0) $page = intval($_POST['page']); else $page = 1;
$gcount = 24;
$limit_page = ($page-1)*$gcount;
//Делаем SQL запрос на вывод
$sql_ = $db->super_query("SELECT id, photo, title FROM `".PREFIX."_videos` WHERE public_id = '{$pid}' ORDER by `add_date` DESC LIMIT {$limit_page}, {$gcount}", 1);
//Выводим кол-во видео
$count = $db->super_query("SELECT videos_num FROM `".PREFIX."_communities` WHERE id = '{$pid}'");
if($count['videos_num']){
$tpl->load_template('videos/box_all_video_top.tpl');
$tpl->set('[top]', '');
$tpl->set('[/top]', '');
$tpl->set('{photo-num}', $count['videos_num'].' '.gram_record($count['videos_num'], 'videos'));
$tpl->set_block("'\[bottom\](.*?)\[/bottom\]'si","");
$tpl->compile('content');
//Выводим циклом видео
$tpl->load_template('videos/box_all_video.tpl');
foreach($sql_ as $row){
$tpl->set('{photo}', $row['photo']);
$tpl->set('{title}', stripslashes($row['title']));
$tpl->set('{video-id}', $row['id']);
$tpl->set('{user-id}', $user_id);
$tpl->compile('content');
}
box_navigation($gcount, $count['videos_num'], $page, 'wall.attach_addvideo_public', $pid);
$tpl->load_template('albums_editcover.tpl');
$tpl->set('[bottom]', '');
$tpl->set('[/bottom]', '');
$tpl->set_block("'\[top\](.*?)\[/top\]'si","");
$tpl->compile('content');
} else
echo '<div class="info_center" style="padding-top:170px">Нет ни одной видеозаписи.</div>';
AjaxTpl();
die();
break;
//################### Бесконечная подгрузка видео из БД ###################//
case "page":
NoAjaxQuery();
$get_user_id = intval($_POST['get_user_id']);
$last_id = intval($_POST['last_id']);
if(!$get_user_id)
$get_user_id = $user_id;
//ЧС
$CheckBlackList = CheckBlackList($get_user_id);
if(!$CheckBlackList){
if($last_id){
if($user_id != $get_user_id)
//Проверка естьли запрашиваемый юзер в друзьях у юзера который смотрит стр
$check_friend = CheckFriends($get_user_id);
//Настройки приватности
if($user_id == $get_user_id)
$sql_privacy = "";
elseif($check_friend)
$sql_privacy = "AND privacy regexp '[[:<:]](1|2)[[:>:]]'";
else
$sql_privacy = "AND privacy = 1";
//SQL Запрос
$sql_ = $db->super_query("SELECT id, title, photo, comm_num, add_date, SUBSTRING(descr, 1, 180) AS descr FROM `".PREFIX."_videos` WHERE owner_user_id = '{$get_user_id}' AND id < '{$last_id}' {$sql_privacy} AND public_id = '0' ORDER by `add_date` DESC LIMIT 0, {$limit_vieos}", 1);
//Если есть ответ из БД
if($sql_){
$tpl->load_template('videos/short.tpl');
foreach($sql_ as $row){
$tpl->set('{photo}', stripslashes($row['photo']));
$tpl->set('{title}', stripslashes($row['title']));
$tpl->set('{id}', $row['id']);
$tpl->set('{user-id}', $get_user_id);
if($row['descr'])
$tpl->set('{descr}', stripslashes($row['descr']).'...');
else
$tpl->set('{descr}', '');
$tpl->set('{comm}', $row['comm_num'].' '.gram_record($row['comm_num'], 'comments'));
megaDate(strtotime($row['add_date']));
if($get_user_id == $user_id){
$tpl->set('[owner]', '');
$tpl->set('[/owner]', '');
} else
$tpl->set_block("'\[owner\](.*?)\[/owner\]'si","");
$tpl->compile('content');
}
}
AjaxTpl();
}
}
die();
break;
//################### Добавление видео к себе в список ###################//
case "addmylist":
NoAjaxQuery();
$vid = intval($_POST['vid']);
$row = $db->super_query("SELECT video, photo, title, descr FROM `".PREFIX."_videos` WHERE id = '{$vid}'");
if($row AND $config['video_mod_add_my'] == 'yes'){
//Директория загрузки фото
$upload_dir = ROOT_DIR.'/uploads/videos/'.$user_id;
//Если нет папки юзера, то создаём её
if(!is_dir($upload_dir)){
@mkdir($upload_dir, 0777);
@chmod($upload_dir, 0777);
}
$expPhoto = end(explode('/', $row['photo']));
@copy($row['photo'], ROOT_DIR."/uploads/videos/{$user_id}/{$expPhoto}");
$newPhoto = "{$config['home_url']}uploads/videos/{$user_id}/{$expPhoto}";
$row['video'] = $db->safesql($row['video']);
$row['descr'] = $db->safesql($row['descr']);
$row['title'] = $db->safesql($row['title']);
$db->query("INSERT INTO `".PREFIX."_videos` SET owner_user_id = '{$user_id}', video = '{$row['video']}', photo = '{$newPhoto}', title = '{$row['title']}', descr = '{$row['descr']}', add_date = NOW(), privacy = 1");
$dbid = $db->insert_id();
$db->query("UPDATE `".PREFIX."_users` SET user_videos_num = user_videos_num+1 WHERE user_id = '{$user_id}'");
//Чистим кеш
mozg_mass_clear_cache_file("user_{$user_id}/page_videos_user|user_{$user_id}/page_videos_user_friends|user_{$user_id}/page_videos_user_all|user_{$user_id}/profile_{$user_id}|user_{$user_id}/videos_num_all|user_{$user_id}/videos_num_friends");
}
die();
break;
default:
//################### Вывод всех видео ###################//
$get_user_id = intval($_GET['get_user_id']);
if(!$get_user_id)
$get_user_id = $user_id;
//ЧС
$CheckBlackList = CheckBlackList($get_user_id);
if(!$CheckBlackList){
//Выводи кол-во видео записей
$owner = $db->super_query("SELECT user_videos_num, user_search_pref FROM `".PREFIX."_users` WHERE user_id = '{$get_user_id}'");
if($owner){
$name_info = explode(' ', $owner['user_search_pref']);
$metatags['title'] = $lang['videos'].' '.gramatikName($name_info[0]).' '.gramatikName($name_info[1]);
if($user_id != $get_user_id)
//Проверка естьли запрашиваемый юзер в друзьях у юзера который смотрит стр
$check_friend = CheckFriends($get_user_id);
//Настройки приватности
if($user_id == $get_user_id)
$sql_privacy = "";
elseif($check_friend){
$sql_privacy = "AND privacy regexp '[[:<:]](1|2)[[:>:]]'";
$cache_pref = '_friends';
} else {
$sql_privacy = "AND privacy = 1";
$cache_pref = '_all';
}
//Если страницу смотрит другой юзер, то считаем кол-во видео
if($user_id != $get_user_id){
$video_cnt = $db->super_query("SELECT COUNT(*) AS cnt FROM `".PREFIX."_videos` WHERE owner_user_id = '{$get_user_id}' {$sql_privacy} AND public_id = '0'", false, "user_{$get_user_id}/videos_num{$cache_pref}");
$owner['user_videos_num'] = $video_cnt['cnt'];
}
if($get_user_id == $user_id)
$user_speedbar = 'У Вас <span id="nums">'.($owner['user_videos_num'] ? $owner['user_videos_num'] : false).'</span> '.gram_record($owner['user_videos_num'], 'videos');
else
$user_speedbar = 'У '.gramatikName($name_info[0]).' '.($owner['user_videos_num'] ? $owner['user_videos_num'] : false).' '.gram_record($owner['user_videos_num'], 'videos');
if($owner['user_videos_num']){
//SQL Запрос
$sql_ = $db->super_query("SELECT id, title, photo, comm_num, add_date, SUBSTRING(descr, 1, 180) AS descr FROM `".PREFIX."_videos` WHERE owner_user_id = '{$get_user_id}' {$sql_privacy} AND public_id = '0' ORDER by `add_date` DESC LIMIT 0, {$limit_vieos}", 1);
//Загружаем меню по видео
$tpl->load_template('videos/head.tpl');
$tpl->set('{user-id}', $get_user_id);
$tpl->set('{videos_num}', $owner['user_videos_num']);
$tpl->set('{name}', gramatikName($name_info[0]));
if($get_user_id == $user_id){
$tpl->set('[owner]', '');
$tpl->set('[/owner]', '');
$tpl->set_block("'\[not-owner\](.*?)\[/not-owner\]'si","");
} else {
$tpl->set('[not-owner]', '');
$tpl->set('[/not-owner]', '');
$tpl->set_block("'\[owner\](.*?)\[/owner\]'si","");
}
if($config['video_mod_add'] == 'yes'){
$tpl->set('[admin-video-add]', '');
$tpl->set('[/admin-video-add]', '');
} else
$tpl->set_block("'\[admin-video-add\](.*?)\[/admin-video-add\]'si","");
$tpl->compile('info');
if($sql_){
$tpl->load_template('videos/short.tpl');
$tpl->result['content'] .= '<span id="video_page" class="scroll_page">';
foreach($sql_ as $row){
$tpl->set('{photo}', stripslashes($row['photo']));
$tpl->set('{title}', stripslashes($row['title']));
$tpl->set('{user-id}', $get_user_id);
$tpl->set('{id}', $row['id']);
if($row['descr'])
$tpl->set('{descr}', stripslashes($row['descr']).'...');
else
$tpl->set('{descr}', '');
$tpl->set('{comm}', $row['comm_num'].' '.gram_record($row['comm_num'], 'comments'));
megaDate(strtotime($row['add_date']));
if($get_user_id == $user_id){
$tpl->set('[owner]', '');
$tpl->set('[/owner]', '');
} else
$tpl->set_block("'\[owner\](.*?)\[/owner\]'si","");
$tpl->compile('content');
}
$tpl->result['content'] .= '</span>';
} else
msgbox('', $lang['videos_nones_videos_user'], 'info_2');
} else {
if($get_user_id == $user_id)
msgbox('', $lang['videos_nones_videos_user'], 'info_2');
else
msgbox('', $owner['user_search_pref'].' '.$lang['videos_none'], 'info_2');
}
} else
Hacking();
} else {
$user_speedbar = $lang['error'];
msgbox('', $lang['no_notes'], 'info');
}
}
$tpl->clear();
$db->free();
} else {
$user_speedbar = $lang['no_infooo'];
msgbox('', $lang['not_logged'], 'info');
}
?>