<?php
App::view($config['themes'].'/index');
$act = (isset($_GET['act'])) ? check($_GET['act']) : 'index';
$cid = (isset($_GET['cid'])) ? abs(intval($_GET['cid'])) : 0;
$id = (isset($_GET['id'])) ? abs(intval($_GET['id'])) : 0;
if (is_user()) {
if (is_admin() || $config['downupload'] == 1) {
switch ($act):
/**
* Главная страница
*/
case 'index':
show_title('Публикация нового файла');
echo '<i class="fa fa-book"></i> <b>Публикация</b> / ';
echo '<a href="/load/add?act=waiting">Ожидающие</a> / ';
echo '<a href="/load/active">Проверенные</a><hr />';
if ($config['home'] == 'http://visavi.net') {
echo '<div class="info">';
echo '<i class="fa fa-question-circle"></i> Перед публикацией скрипта настоятельно рекомендуем ознакомиться с <a href="/load/add?act=rules&cid='.$cid.'">правилами оформления скриптов</a><br />';
echo 'Чем лучше вы оформите свой скрипт, тем быстрее он будет опубликован и добавлен в общий каталог</div><br />';
}
$querydown = DB::run() -> query("SELECT * FROM `cats` ORDER BY `sort` ASC;");
$downs = $querydown -> fetchAll();
if (count($downs) > 0) {
echo '<div class="form">';
echo '<form action="/load/add?act=add&uid='.$_SESSION['token'].'" method="post">';
echo 'Категория*:<br />';
$output = [];
foreach ($downs as $row) {
$i = $row['id'];
$p = $row['parent'];
$output[$p][$i] = $row;
}
echo '<select name="cid">';
echo '<option value="0">Выберите категорию</option>';
foreach ($output[0] as $key => $data) {
$selected = $cid == $data['id'] ? ' selected="selected"' : '';
$disabled = ! empty($data['closed']) ? ' disabled="disabled"' : '';
echo '<option value="'.$data['id'].'"'.$selected.$disabled.'>'.$data['name'].'</option>';
if (isset($output[$key])) {
foreach($output[$key] as $datasub) {
$selected = ($cid == $datasub['id']) ? ' selected="selected"' : '';
$disabled = ! empty($datasub['closed']) ? ' disabled="disabled"' : '';
echo '<option value="'.$datasub['id'].'"'.$selected.$disabled.'>– '.$datasub['name'].'</option>';
}
}
}
echo '</select><br />';
echo 'Название*:<br />';
echo '<input type="text" name="title" size="50" maxlength="50" /><br />';
echo 'Описание*:<br />';
echo '<textarea cols="25" rows="10" name="text"></textarea><br />';
echo 'Автор файла:<br />';
echo '<input type="text" name="author" maxlength="50" /><br />';
echo 'Сайт автора:<br />';
echo '<input type="text" name="site" maxlength="50" value="http://" /><br />';
echo '<input value="Продолжить" type="submit" /></form></div><br />';
echo 'Все поля отмеченные знаком *, обязательны для заполнения<br />';
echo 'Файл и скриншот вы сможете загрузить после добавления описания<br />';
echo 'Если вы ошиблись в названии или описании файла, вы всегда можете его отредактировать<br /><br />';
} else {
show_error('Категории файлов еще не созданы!');
}
break;
/**
* Просмотр ожидающих модерации
*/
case 'waiting':
show_title('Список ожидающих модерации файлов');
echo '<i class="fa fa-book"></i> <a href="/load/add">Публикация</a> / ';
echo '<b>Ожидающие</b> / ';
echo '<a href="/load/active">Проверенные</a><hr />';
$total = DB::run() -> querySingle("SELECT count(*) FROM `downs` WHERE `active`=? AND `user`=?;", [0, $log]);
if ($total > 0) {
$querynew = DB::run() -> query("SELECT `downs`.*, `name` FROM `downs` LEFT JOIN `cats` ON `downs`.`category_id`=`cats`.`id` WHERE `active`=? AND `user`=? ORDER BY `time` DESC;", [0, $log]);
while ($data = $querynew -> fetch()) {
echo '<div class="b">';
echo '<i class="fa fa-download"></i> ';
echo '<b><a href="/load/add?act=view&id='.$data['id'].'">'.$data['title'].'</a></b> ('.date_fixed($data['time']).')</div>';
echo '<div>';
echo 'Категория: '.$data['name'].'<br />';
if (!empty($data['link'])) {
echo 'Файл: '.$data['link'].' ('.read_file(HOME.'/uploads/files/'.$data['link']).')<br />';
} else {
echo 'Файл: <span style="color:#ff0000">Не загружен</span><br />';
}
if (!empty($data['screen'])) {
echo 'Скрин: '.$data['screen'].' ('.read_file(HOME.'/uploads/files/'.$data['screen']).')<br />';
} else {
echo 'Скрин: <span style="color:#ff0000">Не загружен</span><br />';
}
echo '</div>';
}
echo '<br />';
} else {
show_error('Ожидающих модерации файлов еще нет!');
}
echo '<i class="fa fa-arrow-circle-left"></i> <a href="/load/add">Вернуться</a><br />';
break;
/**
* Публикация файла
*/
case 'add':
show_title('Публикация нового файла');
$uid = check($_GET['uid']);
$cid = abs(intval($_POST['cid']));
$title = check($_POST['title']);
$text = check($_POST['text']);
$author = (!empty($_POST['author'])) ? check($_POST['author']) : '';
$site = ($_POST['site'] != 'http://') ? check($_POST['site']) : '';
if ($uid == $_SESSION['token']) {
if (!empty($cid)) {
if (utf_strlen($title) >= 5 && utf_strlen($title) <= 50) {
if (utf_strlen($text) >= 50 && utf_strlen($text) <= 5000) {
if (utf_strlen($author) <= 50) {
if (utf_strlen($site) <= 50) {
if (empty($site) || preg_match('#^https?://([а-яa-z0-9_\-\.])+(\.([а-яa-z0-9\/])+)+$#u', $site)) {
$downs = DBM::run()->selectFirst('cats', ['id' => $cid]);
if (!empty($downs)) {
if (empty($downs['closed'])) {
$downtitle = DB::run() -> querySingle("SELECT `title` FROM `downs` WHERE `title`=? LIMIT 1;", [$title]);
if (empty($downtitle)) {
//DB::run() -> query("UPDATE `cats` SET `count`=`count`+1 WHERE `category_id`=?", array($cid));
DB::run() -> query("INSERT INTO `downs` (`category_id`, `title`, `text`, `link`, `user`, `author`, `site`, `screen`, `time`) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?);", [$cid, $title, $text, '', $log, $author, $site, '', SITETIME]);
$lastid = DB::run() -> lastInsertId();
notice('Данные успешно добавлены!');
redirect("/load/add?act=view&id=$lastid");
} else {
show_error('Ошибка! Название файла '.$title.' уже имеется в загрузках!');
}
} else {
show_error('Ошибка! В данный раздел запрещена загрузка файлов!');
}
} else {
show_error('Ошибка! Выбранный вами раздел не существует!');
}
} else {
show_error('Ошибка! Недопустимый адрес сайта, необходим формат http://site.domen!');
}
} else {
show_error('Ошибка! Слишком длинный адрес сайта (не более 50 символов)!');
}
} else {
show_error('Ошибка! Слишком длинный ник (логин) автора (до 50 символов)!');
}
} else {
show_error('Ошибка! Слишком длинный или короткий текст описания (от 50 до 5000 символов)!');
}
} else {
show_error('Ошибка! Слишком длинное или короткое название (от 5 до 50 символов)!');
}
} else {
show_error('Ошибка! Вы не выбрали категорию для добавления файла!');
}
} else {
show_error('Ошибка! Неверный идентификатор сессии, повторите действие!');
}
echo '<i class="fa fa-arrow-circle-left"></i> <a href="/load/add?act=newfile&cid='.$cid.'">Вернуться</a><br />';
break;
/**
* Подготовка к редактированию файла
*/
case 'view':
show_title('Редактирование ожидающего файла');
echo '<i class="fa fa-book"></i> <a href="/load/add">Публикация</a> / ';
echo '<b><a href="/load/add?act=waiting">Ожидающие</a></b> / ';
echo '<a href="/load/active?act=files">Проверенные</a><hr />';
$new = DB::run() -> queryFetch("SELECT * FROM `downs` d LEFT JOIN `cats` c ON `d`.`category_id`=`c`.`id` WHERE d.`id`=? LIMIT 1;", [$id]);
if (!empty($new)) {
$downs = DB::run() -> query("SELECT `id`, `parent`, `name` FROM `cats` WHERE `closed`=0 ORDER BY `sort` ASC;") -> fetchAll();
if (count($downs) > 0) {
if ($new['user'] == $log) {
if (empty($new['active'])) {
$folder = $new['folder'] ? $new['folder'].'/' : '';
echo '<a href="/load">Категории</a> / ';
if (!empty($new['parent'])) {
$podcats = DB::run() -> queryFetch("SELECT `id`, `name` FROM `cats` WHERE `id`=? LIMIT 1;", [$new['parent']]);
echo '<a href="/load/down?cid='.$podcats['id'].'">'.$podcats['name'].'</a> / ';
}
echo '<a href="/load/down?act=view&id='.$id.'">Обзор файла</a><br /><br />';
echo '<div class="info"><b>Внимание!</b> Данная загрузка опубликована, но еще требует модераторской проверки<br />После проверки вы не сможете отредактировать описание и загрузить файл или скриншот</div><br />';
if (empty($new['link'])) {
echo '<b><big>Загрузка файла</big></b><br /><br />';
echo '<div class="info">';
echo '<form action="/load/add?act=loadfile&id='.$id.'&uid='.$_SESSION['token'].'" method="post" enctype="multipart/form-data">';
echo 'Прикрепить файл* ('.$config['allowextload'].'):<br /><input type="file" name="loadfile" /><br />';
echo '<input value="Загрузить" type="submit" /></form><br />';
echo 'Максимальный вес файла: '.formatsize($config['fileupload']).'</div><br />';
} else {
echo '<i class="fa fa-download"></i> <b><a href="/uploads/files/'.$folder.$new['link'].'">'.$new['link'].'</a></b> ('.read_file(HOME.'/uploads/files/'.$folder.$new['link']).') (<a href="/load/add?act=delfile&id='.$id.'" onclick="return confirm(\'Вы действительно хотите удалить данный файл?\')">Удалить</a>)<br />';
$ext = getExtension($new['link']);
if ($ext != 'jpg' && $ext != 'jpeg' && $ext != 'gif' && $ext != 'png') {
if (empty($new['screen'])) {
echo '<br /><b><big>Загрузка скриншота</big></b><br /><br />';
echo '<div class="info">';
echo '<form action="/load/add?act=loadscreen&id='.$id.'&uid='.$_SESSION['token'].'" method="post" enctype="multipart/form-data">';
echo 'Прикрепить скрин (jpg,jpeg,gif,png):<br /><input type="file" name="screen" /><br />';
echo '<input value="Загрузить" type="submit" /></form><br />';
echo 'Максимальный вес скриншота: '.formatsize($config['screenupload']).'<br />';
echo 'Требуемый размер скриншота: от 100 до '.$config['screenupsize'].' px</div><br /><br />';
} else {
echo '<i class="fa fa-picture-o"></i> <b><a href="/uploads/screen/'.$folder.$new['screen'].'">'.$new['screen'].'</a></b> ('.read_file(HOME.'/uploads/screen/'.$folder.$new['screen']).') (<a href="/load/add?act=delscreen&id='.$id.'" onclick="return confirm(\'Вы действительно хотите удалить данный скриншот?\')">Удалить</a>)<br /><br />';
echo resize_image('uploads/screen/'.$folder, $new['screen'], $config['previewsize']).'<br />';
}
}
}
echo '<br />';
echo '<b><big>Редактирование</big></b><br /><br />';
echo '<div class="form">';
echo '<form action="/load/add?act=edit&id='.$id.'&uid='.$_SESSION['token'].'" method="post">';
echo 'Категория*:<br />';
$output = [];
foreach ($downs as $row) {
$i = $row['id'];
$p = $row['parent'];
$output[$p][$i] = $row;
}
echo '<select name="cid">';
foreach ($output[0] as $key => $data) {
$selected = ($new['id'] == $data['id']) ? ' selected="selected"' : '';
echo '<option value="'.$data['id'].'"'.$selected.'>'.$data['name'].'</option>';
if (isset($output[$key])) {
foreach($output[$key] as $datasub) {
$selected = ($new['id'] == $datasub['id']) ? ' selected="selected"' : '';
echo '<option value="'.$datasub['id'].'"'.$selected.'>– '.$datasub['name'].'</option>';
}
}
}
echo '</select><br />';
echo 'Название*:<br />';
echo '<input type="text" name="title" size="50" maxlength="50" value="'.$new['title'].'" /><br />';
echo 'Описание*:<br />';
echo '<textarea cols="25" rows="5" name="text">'.$new['text'].'</textarea><br />';
echo 'Автор файла:<br />';
echo '<input type="text" name="author" maxlength="50" value="'.$new['author'].'" /><br />';
echo 'Сайт автора:<br />';
echo '<input type="text" name="site" maxlength="50" value="'.$new['site'].'" /><br />';
echo '<input value="Изменить" type="submit" /></form></div><br />';
echo 'Все поля отмеченные знаком *, обязательны для заполнения<br /><br />';
} else {
show_error('Ошибка! Данный файл уже проверен модератором!');
}
} else {
show_error('Ошибка! Изменение невозможно, вы не автор данного файла!');
}
} else {
show_error('Категории файлов еще не созданы!');
}
} else {
show_error('Данного файла не существует!');
}
break;
/**
* Редактирование файла
*/
case 'edit':
show_title('Редактирование ожидающего файла');
$uid = check($_GET['uid']);
$cid = abs(intval($_POST['cid']));
$title = check($_POST['title']);
$text = check($_POST['text']);
$author = (!empty($_POST['author'])) ? check($_POST['author']) : '';
$site = ($_POST['site'] != 'http://') ? check($_POST['site']) : '';
if ($uid == $_SESSION['token']) {
if (utf_strlen($title) >= 5 && utf_strlen($title) <= 50) {
if (utf_strlen($text) >= 50 && utf_strlen($text) <= 5000) {
if (utf_strlen($author) <= 50) {
if (utf_strlen($site) <= 50) {
if (empty($site) || preg_match('#^https?://([а-яa-z0-9_\-\.])+(\.([а-яa-z0-9\/])+)+$#u', $site)) {
$new = DB::run() -> queryFetch("SELECT * FROM `downs` WHERE `id`=? LIMIT 1;", [$id]);
if (!empty($new)) {
if (empty($downs['closed'])) {
if ($new['user'] == $log) {
if (empty($new['active'])) {
$categories = DB::run() -> querySingle("SELECT `id` FROM `cats` WHERE `id`=? LIMIT 1;", [$cid]);
if (!empty($categories)) {
$newtitle = DB::run() -> querySingle("SELECT `title` FROM `downs` WHERE `title`=? AND `id`<>? LIMIT 1;", [$title, $id]);
if (empty($newtitle)) {
DB::run() -> query("UPDATE `downs` SET `category_id`=?, `title`=?, `text`=?, `author`=?, `site`=?, `time`=? WHERE `id`=?;", [$cid, $title, $text, $author, $site, $new['time'], $id]);
notice('Данные успешно изменены!');
redirect("/load/add?act=view&id=$id");
} else {
show_error('Ошибка! Название файла '.$title.' уже имеется в загрузках!');
}
} else {
show_error('Ошибка! Выбранный вами раздел не существует!');
}
} else {
show_error('Ошибка! Данный файл уже проверен модератором!');
}
} else {
show_error('Ошибка! Изменение невозможно, вы не автор данного файла!');
}
} else {
show_error('Ошибка! В данный раздел запрещена загрузка файлов!');
}
} else {
show_error('Данного файла не существует!');
}
} else {
show_error('Ошибка! Недопустимый адрес сайта, необходим формат http://site.domen!');
}
} else {
show_error('Ошибка! Слишком длинный адрес сайта (не более 50 символов)!');
}
} else {
show_error('Ошибка! Слишком длинный ник (логин) автора (до 50 символов)!');
}
} else {
show_error('Ошибка! Слишком длинный или короткий текст описания (от 50 до 5000 символов)!');
}
} else {
show_error('Ошибка! Слишком длинное или короткое название (от 5 до 50 символов)!');
}
} else {
show_error('Ошибка! Неверный идентификатор сессии, повторите действие!');
}
echo '<i class="fa fa-arrow-circle-left"></i> <a href="/load/add?act=view&id='.$id.'">Вернуться</a><br />';
break;
/**
* Загрузка файла
*/
case 'loadfile':
show_title('Загрузка файла');
$down = DB::run() -> queryFetch("SELECT `d`.*, `c`.`folder` FROM `downs` d LEFT JOIN `cats` c ON `d`.`category_id`=`c`.`id` WHERE d.`id`=? LIMIT 1;", [$id]);
$folder = $down['folder'] ? $down['folder'].'/' : '';
if (!empty($down)) {
if ($down['user'] == $log) {
if (empty($down['active'])) {
if (empty($down['link'])) {
if (is_writeable(HOME.'/uploads/files/'.$folder)) {
if (isset($_FILES['loadfile']) && is_uploaded_file($_FILES['loadfile']['tmp_name'])) {
$filename = check(strtolower($_FILES['loadfile']['name']));
if (strlen($filename) <= 50) {
if (preg_match('|^[a-z0-9_\.\-]+$|i', $filename)) {
$ext = getExtension($filename);
if (in_array($ext, explode(',', $config['allowextload']), true)) {
if ($_FILES['loadfile']['size'] > 0 && $_FILES['loadfile']['size'] <= $config['fileupload']) {
$downlink = DB::run() -> querySingle("SELECT `link` FROM `downs` WHERE `link`=? LIMIT 1;", [$filename]);
if (empty($downlink)) {
move_uploaded_file($_FILES['loadfile']['tmp_name'], HOME.'/uploads/files/'.$folder.$filename);
@chmod(HOME.'/uploads/files/'.$folder.$filename, 0666);
copyright_archive(HOME.'/uploads/files/'.$folder.$filename);
DB::run() -> query("UPDATE `downs` SET `link`=? WHERE `id`=?;", [$filename, $id]);
// Обработка видео
if ($ext == 'mp4') { // TODO проверять по mime-type и поддержку обработки
$ffconfig = [
'ffmpeg.binaries' => '/usr/bin/ffmpeg',
'ffprobe.binaries' => '/usr/bin/ffprobe',
'timeout' => 3600,
'ffmpeg.threads' => 4,
];
$ffmpeg = FFMpeg\FFMpeg::create($ffconfig);
$video = $ffmpeg->open(HOME.'/uploads/files/'.$folder.$filename);
// Сохраняем скрин с 10 секунды
$video
->frame(FFMpeg\Coordinate\TimeCode::fromSeconds(10))
->save(HOME.'/uploads/screen/'.$folder.'/'.$filename.'.jpg');
DB::run() -> query("UPDATE `downs` SET `screen`=? WHERE `id`=?;", [$filename.'.jpg', $id]);
// Перекодируем видео в h264
$ffprobe = FFMpeg\FFProbe::create($ffconfig);
$codec = $ffprobe
->streams(HOME.'/uploads/files/'.$folder.$filename)
->videos()
->first()
->get('codec_name');
if ($codec != 'h264') {
$format = new FFMpeg\Format\Video\X264('libmp3lame', 'libx264');
$video->save($format, HOME.'/uploads/files/'.$folder.'/convert-'.$filename);
rename(
HOME.'/uploads/files/'.$folder.'/convert-'.$filename,
HOME.'/uploads/files/'.$folder.'/'.$filename
);
}
}
notice('Файл успешно загружен!');
redirect("/load/add?act=view&id=$id");
} else {
show_error('Ошибка! Файл '.$filename.' уже имеется в общих файлах!');
}
} else {
show_error('Ошибка! Максимальный размер загружаемого файла '.formatsize($config['fileupload']).'!');
}
} else {
show_error('Ошибка! Недопустимое расширение файла!');
}
} else {
show_error('Ошибка! В названии файла присутствуют недопустимые символы!');
}
} else {
show_error('Ошибка! Слишком длинное имя файла (не более 50 символов)!');
}
} else {
show_error('Ошибка! Не удалось загрузить файл!');
}
} else {
show_error('Ошибка! Директория для файлов недоступна для записи!');
}
} else {
show_error('Ошибка! Файл уже загружен!');
}
} else {
show_error('Ошибка! Данный файл уже проверен модератором!');
}
} else {
show_error('Ошибка! Изменение невозможно, вы не автор данного файла!');
}
} else {
show_error('Данного файла не существует!');
}
echo '<i class="fa fa-arrow-circle-left"></i> <a href="/load/add?act=view&id='.$id.'">Вернуться</a><br />';
break;
/**
* Загрузка скриншота
*/
case 'loadscreen':
show_title('Загрузка скриншота');
$down = DB::run() -> queryFetch("SELECT `d`.*, `c`.`folder` FROM `downs` d LEFT JOIN `cats` c ON `d`.`category_id`=`c`.`id` WHERE d.`id`=? LIMIT 1;", [$id]);
if (!empty($down)) {
if ($down['user'] == $log) {
if (empty($down['active'])) {
if (empty($down['screen'])) {
if (is_uploaded_file($_FILES['screen']['tmp_name'])) {
// ------------------------------------------------------//
$handle = upload_image($_FILES['screen'], $config['screenupload'], $config['screenupsize'], $down['link']);
if ($handle) {
$folder = $down['folder'] ? $down['folder'].'/' : '';
$handle -> process(HOME.'/uploads/screen/'.$folder);
if ($handle -> processed) {
DB::run() -> query("UPDATE `downs` SET `screen`=? WHERE `id`=?;", [$handle -> file_dst_name, $id]);
$handle -> clean();
notice('Скриншот успешно загружен!');
redirect("/load/add?act=view&id=$id");
} else {
show_error($handle -> error);
}
} else {
show_error('Ошибка! Не удалось загрузить изображение!');
}
} else {
show_error('Ошибка! Вы не загрузили скриншот!');
}
} else {
show_error('Ошибка! Скриншот уже загружен!');
}
} else {
show_error('Ошибка! Данный файл уже проверен модератором!');
}
} else {
show_error('Ошибка! Изменение невозможно, вы не автор данного файла!');
}
} else {
show_error('Данного файла не существует!');
}
echo '<i class="fa fa-arrow-circle-left"></i> <a href="/load/add?act=view&id='.$id.'">Вернуться</a><br />';
break;
/**
* Удаление файла
*/
case 'delfile':
$link = DB::run() -> queryFetch("SELECT `d`.*, `c`.`folder` FROM `downs` d LEFT JOIN `cats` c ON `d`.`category_id`=`c`.`id` WHERE d.`id`=? LIMIT 1;", [$id]);
if (!empty($link)) {
if ($link['user'] == $log) {
if (empty($link['active'])) {
$folder = $link['folder'] ? $link['folder'].'/' : '';
if (!empty($link['link']) && file_exists(HOME.'/uploads/files/'.$folder.$link['link'])) {
unlink(HOME.'/uploads/files/'.$folder.$link['link']);
}
unlink_image('uploads/files/'.$folder, $link['link']);
unlink_image('uploads/screen/'.$folder, $link['screen']);
DB::run() -> query("UPDATE `downs` SET `link`=?, `screen`=? WHERE `id`=?;", ['', '', $id]);
notice('Файл успешно удален!');
redirect("/load/add?act=view&id=$id");
} else {
show_error('Ошибка! Данный файл уже проверен модератором!');
}
} else {
show_error('Ошибка! Удаление невозможно, вы не автор данного файла!');
}
} else {
show_error('Ошибка! Данного файла не существует!');
}
echo '<i class="fa fa-arrow-circle-left"></i> <a href="/load/add?act=view&id='.$id.'">Вернуться</a><br />';
break;
/**
* Удаление скриншота
*/
case 'delscreen':
$screen = DB::run() -> queryFetch("SELECT `d`.*, `c`.`folder` FROM `downs` d LEFT JOIN `cats` c ON `d`.`category_id`=`c`.`id` WHERE d.`id`=? LIMIT 1;", [$id]);
if (!empty($screen)) {
if ($screen['user'] == $log) {
if (empty($screen['active'])) {
$folder = $screen['folder'] ? $screen['folder'].'/' : '';
unlink_image('uploads/screen/'.$folder, $screen['screen']);
DB::run() -> query("UPDATE `downs` SET `screen`=? WHERE `id`=?;", ['', $id]);
notice('Скриншот успешно удален!');
redirect("/load/add?act=view&id=$id");
} else {
show_error('Ошибка! Данный файл уже проверен модератором!');
}
} else {
show_error('Ошибка! Удаление невозможно, вы не автор данного файла!');
}
} else {
show_error('Ошибка! Данного файла не существует!');
}
echo '<i class="fa fa-arrow-circle-left"></i> <a href="/load/add?act=view&id='.$id.'">Вернуться</a><br />';
break;
/**
* Правила
*/
case 'rules':
if ($config['home'] == 'http://visavi.net') {
show_title('Правила оформления скриптов');
echo '<b><span style="color:#ff0000">Внимание! Запрещено выкладывать платные скрипты или скрипты не предназначенные для свободного распространения.<br />
Запрещено размещать скрипты накрутчиков, скрипты для спама, взлома или любые вредоносные скрипты</span></b><br /><br />';
echo 'Чтобы не превращать архив скриптов в свалку мусора, все скрипты на нашем сайте проходят ручную обработку<br />';
echo 'Если вы хотите добавить скрипт, НЕ обязательно быть его автором, но вы обязательно должны указать данные и контакты автора скрипта<br />';
echo 'Также если вы автор модификации или небольшой переделки, то можете указать и свои данные в описании к скрипту<br /><br />';
echo '<b>Авторские права</b><br />';
echo 'Для размещения скрипта в нашем архиве вы должны быть автором этого скрипта, у вас должны быть эсклюзивные права для размещения этого скрипта или лицензия на распространения скрипта<br />';
echo 'Не рекомендуется публиковать скрипт если вы не уверены, что он распространяется свободно или автор не против этого<br />';
echo 'Все скрипты размещенные у нас не могут быть удалены с нашего сайта, исключением является публикация скрипта без согласия автора или выложенных с нарушением текущих правил и только по требованию автора<br />';
echo 'Размещая скрипт у нас вы автоматически соглашаетесь со всеми правилами<br /><br />';
echo '<b>В архиве со скриптом должны быть следующие, обязательные файлы:</b><br />';
echo '<b>1.</b> Сам скрипт. Все файлы необходимые для нормальной работы<br />';
echo '<b>2.</b> Инструкция по установке. Как правильно установить скрипт<br />';
echo '<b>3.</b> Полное описание скрипта. Какие функции имеются в этом скрипте, возможности и т.д.<br />';
echo '<b>4.</b> Требования для работы. (К примеру PHP4, HTML, библиотека ICONV)<br />';
echo '<b>5.</b> Автор скрипта и(или) автор модификации<br />';
echo '<b>6.</b> Контакты авторов (адрес сайта)<br />';
echo '<b>7.</b> Красивое и уникальное название архива и скрипта<br /><br />';
echo '<b>Примеры описания скриптов</b><br />';
echo 'Название: <b>cat_skor</b><br />';
echo 'Каталог мобильных сайтов в трех версиях: wml xhtml и html.<br />
Возможности<br />
- Полная статистика каталога: переходы по дням, по месяцам и за все время.<br />
- Полная статистика по каждому сайту: переходы по дням, месяцам, переходы за все время, описание.<br />
- Автоудаление неактивных сайтов.<br />
- Отчет на email за каждый день ....... (и т.д.)
<br />
Требования: PHP4, MySQL, WML, (X)HTML, CRON<br />
Автор cкрипта: skor<br />
Сайт автора http://xwap.org<br /><br />';
echo '<b>Ограничения:</b><br />';
echo 'К загрузке допускаются архивы в формате zip, скриншоты можно загружать в форматах jpg, jpeg, gif и png<br />';
echo 'Максимальный вес архива: '.formatsize($config['fileupload']).'<br />';
echo 'Максимальный вес скриншота: '.formatsize($config['screenupload']).'<br />';
echo 'Требуемый размер скриншота: от 100 до '.$config['screenupsize'].' px<br /><br />';
echo '<b>Рекомендации:</b><br />';
echo 'Чем лучше вы оформите скрипт при публикации, тем быстрее он будет проверен и размещен в архиве<br />';
echo 'Рекомендуем самостоятельно подготовить хорошее и граммотное описание скрипта, а не просто скопировать и вставить текст<br />';
echo 'Важным моментом является выбор названия и имени архива со скриптом, они должны быть уникальными, нельзя добавлять к примеру gb.zip, forum.zip и т.д. так как эти названия не уникальные и подходят под большинство скриптов выбранной категории<br />';
echo 'Название и имя архива не должны быть слишком короткими или длинными, не должны быть чересчур информативными<br /><br />';
echo 'После проверки ваш скрипт будет размещен в нашем архиве и станет доступным для скачивания, добавления оценок и комментариев<br /><br />';
echo '<i class="fa fa-arrow-circle-left"></i> <a href="/load/add?cid='.$cid.'">Вернуться</a><br />';
}
break;
endswitch;
} else {
show_error('Возможность добавление файлов запрещена администрацией сайта');
}
} else {
show_login('Вы не авторизованы, для добавления файла, необходимо');
}
render('includes/back', ['link' => '/load/', 'title' => 'Категории']);
App::view($config['themes'].'/foot');