Вы здесьКак нам обустроить заливку KIT-4063
Опубликовано чт, 28/08/2008 - 16:51 пользователем pkn
Как нам обустроить заливку KIT-4063 При имеющемся коде заливочного скрипта (file author.inc, function AddFileToLibrusec) всем этим 4063 книгам при заливке будут обнаружены дубли, конфликт которых придется разрешать вручную. Это очень много кликов. За один день вручную столько не сделать, и получится, что эта заливка забьет ленту новостей на несколько дней в лучшем случае. Да и лень делать вручную то, что можно отдать машине, она железная. Поэтому я хочу попросить Ларина внести изменения в заливочный скрипт. Точный текст изменения я сформирую попозже, а пока смысл этого изменения. Как работает заливочный скрипт сейчас: Как я предлагаю: 1. Автоматический апгрейд той же книги Если 2. Автоматическая замена книги, сделанной LibRusEc kit Если Если ни одна из этих проверок не выполняется - то, как и раньше, предложение разрешить конфликт дублей вручную. Вопрос: не создаст ли такое изменение каких-либо подводных камней? ----------- -----------
|
Вход на сайтПоиск по блогам и форумамUser menuПоследние комментарии
Леди Стервa RE:Подайте бедному копеечку на книжку с литреса... 5 часов
Саша из Киева RE:Подвиг героев - судьба страны. МНР: люди и годы 8 часов commodore RE:Письма 1 неделя Саша из Киева RE:Три минуты истории 1 неделя nehug@cheaphub.net RE:Как бы с этим побороться и побороть? 2 недели Саша из Киева RE:Книги на латышском языке 3 недели stevecepera RE:Список современных французских писателей? 1 месяц etorus2008 RE:Отв: Помогите найти книгу по описанию 1 месяц lemma7 RE:Чёрный нимб и другие истории, исполненные неизъяснимого ужаса 1 месяц Wedmak RE:Помогите найти!.. #2 1 месяц sem14 RE:Координация сканирования и вычитки 1 месяц babajga RE:Кто сможет раздобыть и оцифровать нужные мне книги? 1 месяц Isais RE:Мои открытия 1 месяц kopak RE:О группе Дятлова. О той самой, того самого... 1 месяц A5. RE:Не присылает пароль на почту 1 месяц babajga RE:Плюмаж 2 месяца babajga RE:Блошкинс и Фрю. Опасное путешествие 2 месяца alexk RE:Багрепорт - 2 2 месяца Впечатления о книгах
awas про Ольга Оборзевшая (Тонина)
10 06 Тонина с Афанасьевым всегда были склонны к мрачному юмору, а тут в самом начале книги почти открытым текстом разъяснили, что пишут пародию. Да и администрация ЛибРусЭк совсем уж открытым текстом написала «Юмористическая фантастика, ………
Sello про Фурцева: «Я плачу только в подушку». Откровения «первой леди СССР» [litres] (Биографии и Мемуары)
10 06 Какое-то неоднозначное впечатление оставило чтение этого текста. С одной стороны, понимаешь, что человек пишет с явной целью "отметиться" для последующих поколений (о чем сама Фурцева в конце записей признается), потому - ……… Оценка: неплохо
decim про Фёдор Олегович Ковалов
10 06 Быт и люди психбольницы во имя Св. Николая, она же Пряжка. Рисунки автора. Хорошо. Господа цензоры, замазанные вами слова только подогревают интерес малолетних - взрослые давно узнали и миновали - к известным темам.
udrees про Вальтер: Стадия Уныния (Боевая фантастика, ЛитРПГ, Самиздат, сетевая литература)
10 06 Мрачная писанина про приключения попаданца-маньяка в мир какой-то изуверской игры на выживание. Персонаж у нас антигерой, отрицательный типок, любящий кровь и убийства. Сама книга написана простым языком, без особых описаний. ……… Оценка: неплохо
udrees про Вальтер: Генетический потенциал (Боевая фантастика, Космическая фантастика, Постапокалипсис, Самиздат, сетевая литература)
10 06 2-я книга про жизнь бывшего уголовника на неизвестной планете, где его посвятили в тайну жизни планеты. В общем сюжет круто меняется во второй книге, и то, что кажется понятным в начале книги, в конце полностью меняется на ……… Оценка: неплохо
udrees про Вальтер: Среди нас 1 (Боевая фантастика, Приключения: прочее, Постапокалипсис, Самиздат, сетевая литература)
10 06 В общем то годное произведение, написано даже кажется лучше чем большинство других от Макса Вальтера, а то у автора какая-то тяга к описаниям приключений всякой мрази, маньяков-убийц, антигероев. Здесь же повествование идет ……… Оценка: неплохо
mysevra про Дембский: Властители ночи (Детективная фантастика)
09 06 Вот уж действительно «фантастическая авантюра». Для чтения в поездке – самое оно, на большее не претендует. Оценка: неплохо
mysevra про Симмонс: Горящий Эдем [Литрес] (Ужасы, Триллер)
09 06 Красотища-то какая! Этнофэнтези, да в таких роскошных декорациях. Тут тебе и кровища, и гавайский фольклор, и Марк Твен. Даже философско-социальные проблемы, составляющие канву всей истории, не портят повествование. Оценка: отлично!
mysevra про Корбут: Иван Царевич и серый морг (Ужасы, Триллер)
09 06 Интригующее начало, а дальше, до середины книги - ни о чём. Бросила. Оценка: плохо
Nicout про Акунин: Проснись! у(дис)топия (Социальная фантастика, Современная проза)
09 06 Брат-2 - Одно слово - румын! - Так он болгарин. - Да? Какая разница? (с) Если человек пишет "столько-же", "ту-же", "Ну-да" - с ним все ясно, ему что Мальдивы, что Мальвины...
decim про Эрнест: Города дыма и звёзд [litres] [Cities of Smoke and Starlightde ru] (О любви, Любовная фантастика)
07 06 Часто вы видите, как взрослый мужик - или взрослая баба - закатывает глаза? А ГГ только этим и занят. В подлиннике обычно то же самое: автору на большее не хватает фантазии. Фтопку. Оценка: плохо
nik_ol про Полякова: Одна тайная ставка (Детективы: прочее)
06 06 Ура! Спасибо, что выложили, заждалась новых книг) Оценка: хорошо |
Комментарии
Текст изменения в 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 book
if( ($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 всё должно работать :((