Вы здесьКак нам обустроить заливку KIT-4063
Опубликовано чт, 28/08/2008 - 16:51 пользователем pkn
Как нам обустроить заливку KIT-4063 При имеющемся коде заливочного скрипта (file author.inc, function AddFileToLibrusec) всем этим 4063 книгам при заливке будут обнаружены дубли, конфликт которых придется разрешать вручную. Это очень много кликов. За один день вручную столько не сделать, и получится, что эта заливка забьет ленту новостей на несколько дней в лучшем случае. Да и лень делать вручную то, что можно отдать машине, она железная. Поэтому я хочу попросить Ларина внести изменения в заливочный скрипт. Точный текст изменения я сформирую попозже, а пока смысл этого изменения. Как работает заливочный скрипт сейчас: Как я предлагаю: 1. Автоматический апгрейд той же книги Если 2. Автоматическая замена книги, сделанной LibRusEc kit Если Если ни одна из этих проверок не выполняется - то, как и раньше, предложение разрешить конфликт дублей вручную. Вопрос: не создаст ли такое изменение каких-либо подводных камней? ----------- -----------
|
Вход на сайтПоиск по блогам и форумамUser menuПоследние комментарии
aldan RE:Подайте бедному копеечку на книжку с литреса... 1 час
Larisa_F RE:Серия "Новые сказочные повести" издательство "Самовар" ... 1 неделя sem14 RE:Серия "Символы времени" издательства "Аграф" 1 неделя Larisa_F RE:Серия книг «Судьбы книг» издательства «Книга» 2 недели tvv RE:faq brainstorm =) 2 недели Larisa_F RE:Серия "Что есть что" издательства "Слово"(чего не хватает) 2 недели Larisa_F RE:Серия "Очень прикольная книга", издательство Азбука-классика 3 недели larin RE:абонемент не обновлен 3 недели sem14 RE:За иллюминатором (серия) - чего не хватает? 3 недели sem14 RE:Собираем серию: "Мастер серия", издательство "Лимбус". 3 недели Larisa_F RE:Книжная серия «Сlio» издательства "Евразия" 4 недели larin RE:Пропал абонемент 1 месяц tvv RE:DNS 1 месяц MrMansur RE:<НРЗБ> 1 месяц Stager RE:Беженцы с Флибусты 1 месяц Tramell RE:Серия "Библиотека французской литературы" (Макбел) 1 месяц sem14 RE:Книжная серия "Жизнь в искусстве" издательство "Искусство"... 1 месяц sem14 RE:Современная корейская литература. Книжная серия... 1 месяц Впечатления о книгах
DGOBLEK про Найт: Мастера эволюции (Фантастика: прочее)
08 02 ЭТО МОЖТ ОБУЧИТЬСЯ С ТОПОЙ! - название рассказа....Mefisto - ну как так можно делать спустя рукава электронку? Взялись делать FB2 - делайте хорошо. Название рассказа - Это можт свучиться с топой! Если в оглавлении допускать ………
MrMansur про Дубнов: Книга жизни [воспоминания и размышления] (Биографии и Мемуары)
07 02 Так есть же в формате fb2 http://209.42.197.18/b/786038
MrMansur про Прилепин: Тума (Современная проза)
07 02 Первая мысль - как же много крови проливали. Но потом осознание: почему проливали? Так было, ьак есть и так будет пока существует эта раковая опухоль - человек... Владея русским и татарским, было интересно читать многоязычные ……… Оценка: отлично!
polyn про Корсакова: Лисье золото [СИ litres] (Ужасы, Триллер, Самиздат, сетевая литература)
07 02 Очень интересное начало серии Оценка: отлично!
udrees про Каменистый: Запрещённый юг (Боевая фантастика, Фэнтези, Попаданцы, ЛитРПГ)
07 02 Смешно написано, продолжение хорошее. Понравится любителям серии. Герой снова попадает в переделки, снова сражается с сильными противниками, и снова получает кучу прогресса. Описания статов и достижений иногда могут раздражать, ……… Оценка: отлично!
udrees про Атаманов: Новые Боги (Боевая фантастика, ЛитРПГ, Самиздат, сетевая литература)
07 02 Смешное окончание приключений. Все было бы хорошо, если бы не вмешательство богов в дела земные. Хотя конечно изначально все предупреждены, что они игроки в большой Игре. Но в 4-й книге приключения в своем стиле, интересные ……… Оценка: хорошо
udrees про Атаманов: Верховья Стикса [СИ] (ЛитРПГ, Самиздат, сетевая литература)
07 02 Я полагаю не вторая, а третья книга может быть окончанием всей серии. Концовку чуть поменять и все, логический венец приключений гоблина. Собственно, в таком же стиле грамотное описание приключений гоблина, победы над сильными ……… Оценка: хорошо
udrees про Атаманов: Сохранить крылья [СИ] (ЛитРПГ, Самиздат, сетевая литература)
07 02 Совершенно сумасшедшее продолжение истории про приключения гоблина-травника в игровом мире, заодно перемежающееся с событиями в реальном мире. Автор часто использует такой прием в своих книгах. Не знаю, в «Забаненном» меня ……… Оценка: хорошо
alexk про Цзи Юнь: Заметки из хижины «Великое в малом» [сборник litres] (Древневосточная литература)
07 02 Издание повторяет старый советский вариант, только предисловие выкинули. И издание, и сам файл хуже предшественника.
decim про Смурыгина: Дефицит. Как в СССР доставали то, что невозможно было достать (История, Публицистика)
05 02 Даже забег по мос. лавкам в понедельник приносил урожай, а уж в посёлках чего только не было. Среди тамошнего населения считалось предосудительным носить не то, что принято - т.е. спецовку на каждый день и старый шерстяной ………
Barbud про Трофимов: Толмач [litres] (Боевая фантастика, Попаданцы)
05 02 Автор успел накропать уже целую охапку писева про данный исторический период, но так и не озаботился получше узнать о реалиях того времени, хотя бы учебник истории почитать - ну да, чукча не читатель, чукча писатель. Тут у ……… Оценка: плохо
irukan про Ланцов: Шанс (Альтернативная история, Социальная фантастика, Самиздат, сетевая литература)
04 02 Хорошо зашла книга! На одном дыхании прочёл. Давно у Ланцова такого не было. Наш совеременник попадает в Константинополь за несколько лет до его падения. То есть, понимаешь, что всё у него получится, но всё равно до конца держит в напряжении Оценка: отлично! |
Комментарии
Текст изменения в author.inc, прошу знающих php глянуть
Текст предлагаемого изменения в author.inc, прошу знающих php глянуть на предмет косяков.
Old (file author.inc, function AddFileToLibrusec lines 609-610):
if ($dublid = Sel ("BookId FROM libbook JOIN libavtor USING (BookId) WHERE Title="$title" AND AvtorId = $a AND BookID != $b AND NOT Deleted"))$r .= "<p>Кажется, нашли дубля. Ткните в него для разрешения конфликта. <a href=/b/$b/join/$dublid target=_blank>Дубль: $title</a>";
New (вариант при котором автоматическая замена работает для всех):
if ($dublid = Sel ("BookId FROM libbook JOIN libavtor USING (BookId) WHERE Title="$title" AND AvtorId = $a AND BookID != $b AND NOT Deleted")){
$r .= "<p>Кажется, нашли дубля.";
//
// $b - new book Librusec-book-number, not the FICTIONBOOK/DESCRIPTION/DOCUMENT-INFO/ID
// $dublid - dubl Librusec-book-number
// $id - new book document-info-ID (was set earlier)
// $ver - new book document-info-version (was set earlier)
//
// Get document-info-ID and version for dubl
$dubldocid = Sel ("Id FROM libbook WHERE BookId = $dublid"); // ya ne uveren v sintaksise
$dublver = Sel ("Ver FROM libbook WHERE BookId = $dublid");
// Automatic upgrade of the same book
if( ($dubldocid==$id) && (1.0*$ver > 1.0*$dublver) ){
$r .= joinbooks($b,$dublid,$title);
return $r . "<hr>\n";
};
// Automatic upgrade of the old "LibRusEc kit" book
// 012345678901234567890123
// U libruseka dva tipa id - "Tue Jun 12 03:34:15 2007" i "Mon Jun 10 19:57:46 2013"
// Kljuchevoe - probely s godom.
// 012345678901234567890123
// ("ID"="... ... .. ..:..:.. 2013" OR "ID"="... ... .. ..:..:.. 2007")
$i = strrpos($dubldocid," 20");
if( ($i==19) && (1.0*$ver > 1.0*$dublver) ){
$r .= joinbooks($b,$dublid,$title);
return $r . "<hr>\n";
};
// No automatic resolution, resolve conflict manually
$r .= " Ткните в него для разрешения конфликта. <a href=/b/$b/join/$dublid target=_blank>Дубль: $title</a>";
};
New (вариант при котором автоматическая замена работает только для библиотекарей):
if ($dublid = Sel ("BookId FROM libbook JOIN libavtor USING (BookId) WHERE Title="$title" AND AvtorId = $a AND BookID != $b AND NOT Deleted")){
$r .= "<p>Кажется, нашли дубля.";
if (user_access('библиотекарь'))
{
//
// $b - new book Librusec-book-number, not the FICTIONBOOK/DESCRIPTION/DOCUMENT-INFO/ID
// $dublid - dubl Librusec-book-number
// $id - new book document-info-ID (was set earlier)
// $ver - new book document-info-version (was set earlier)
//
// Get document-info-ID and version for dubl
$dubldocid = Sel ("Id FROM libbook WHERE BookId = $dublid"); // ya ne uveren v sintaksise
$dublver = Sel ("Ver FROM libbook WHERE BookId = $dublid");
// Automatic upgrade of the same book
if( ($dubldocid==$id) && (1.0*$ver > 1.0*$dublver) ){
$r .= joinbooks($b,$dublid,$title);
return $r . "<hr>\n";
};
// Automatic upgrade of the old "LibRusEc kit" book
// 012345678901234567890123
// U libruseka dva tipa id - "Tue Jun 12 03:34:15 2007" i "Mon Jun 10 19:57:46 2013"
// Kljuchevoe - probely s godom.
// 012345678901234567890123
// ("ID"="... ... .. ..:..:.. 2013" OR "ID"="... ... .. ..:..:.. 2007")
$i = strrpos($dubldocid," 20");
if( ($i==19) && (1.0*$ver > 1.0*$dublver) ){
$r .= joinbooks($b,$dublid,$title);
return $r . "<hr>\n";
};
}; // if библиотекарь
// No automatic resolution, resolve conflict manually
$r .= " Ткните в него для разрешения конфликта. <a href=/b/$b/join/$dublid target=_blank>Дубль: $title</a>";
};
Отв: Как нам обустроить заливку KIT-4063
Да, до завтра жду замечаний-предложений, потом прошу Ларина внести изменение, и если он согласится - то кто не спрятался, я не виноват ;-)
Отв: Как нам обустроить заливку KIT-4063
Честно признаю, что я чайник. Поэтому и вопрос у меня скорее всего дурацкий. Но если можно я его задам. Не открывает ли это возможность для вредительства. Предположим кто-то берёт имеющийся у нас файл, текст в нём заменяет на некую абракадабру и затем заливает на ЛибРусЭк как апргрейженый. Автоматически старый файл с полным текстом заменяется на абракадабру. А если такое произойдёт в массовом порядке?
Отв: Как нам обустроить заливку KIT-4063
Вопрос точный и правильный. Я себе это так представляю: для того, чтобы проделать такую диверсию, нужно сделать много-много-кликов-на-одну-книгу. А откатывается это дело - одним кликом. Обнаружение и вовсе не представляет проблемы - новинки пасут почитай что все. Поэтому не думаю, что тут откроется много возможностей для вредительства.
Отв: Как нам обустроить заливку KIT-4063
Я тоже чайник в том смысле, что не разбираюсь в скриптах. Поэтому только замечу, что если скрипт будет изменен, надо сначала залить несколько книг и тщательно проверить, что получилось, а только потом заливать все. Насчет злоупотреблений и вредительства - это тоже возможно, при автоматическом апдейте можно представить себе бота, который будет скачивать книги, менять текст в них любым способом, и заливать обратно "исправленные". От этого есть очень простое средство: массвоые заливки / апдейты с использованием автоматики сделать доступными только библиотекарям, а для простых смертных оставить все, как есть. Можно также просто поставить капча-фильтр, чтобы авторизация и скачка книг проходила как обычно, а вот заливка, переименование, изменение жанра и прочие креативные операции - только после набора кода с картинки. Это не сильно усложнит операции по заливке, но зато увеличит уровень защищенности. Для библиотекарей, естественно, такой защиты не надо.
Отв: Как нам обустроить заливку KIT-4063
Я, честно говоря, не думаю что там так все просто с ботами. Но на всякий случай добавил ещё вариант, при котором автоматическая замена работает только для библиотекарей.
Отв: Как нам обустроить заливку KIT-4063
Заметка для отметки. Просьба Ларину внести изменение отправлена.
Отв: Как нам обустроить заливку KIT-4063
Внёс.
Отв: Как нам обустроить заливку KIT-4063
Спасибо.
И сразу проблемка :((
Заливка первых 20-ти книг на пробу показала, что первый "if"
// Automatic upgrade of the same bookif( ($dubldocid==$id) && (1.0*$ver > 1.0*$dublver) ){
$r .= joinbooks($b,$dublid,$title);
return $r . "<hr>\n";
};
срабатывает штатно.
А второй "if"
// Automatic upgrade of the old "LibRusEc kit" book// 012345678901234567890123
// U libruseka dva tipa id - "Tue Jun 12 03:34:15 2007" i "Mon Jun 10 19:57:46 2013"
// Kljuchevoe - probely s godom.
$i = strrpos($dubldocid," 20");
if( ($i==19) && (1.0*$ver > 1.0*$dublver) ){
$r .= joinbooks($b,$dublid,$title);
return $r . "<hr>\n";
};
- не срабатывает. joinbooks который у него внутре, никогда не происходит. То бишь условие if( ($i==19) && (1.0*$ver > 1.0*$dublver) ) не выполняется на тех книжках, где железно должно было бы выполняться... Например, пары книг (я пока держу их в незакрытых окнах браузера):
http://lib.rus.ec/b/120358/join/288
http://lib.rus.ec/b/120363/join/538
Я не знаю в чем причина... вроде по TFM strrpos всё должно работать :((