Вы здесьКак нам обустроить заливку KIT-4063
Опубликовано чт, 28/08/2008 - 16:51 пользователем pkn
Как нам обустроить заливку KIT-4063 При имеющемся коде заливочного скрипта (file author.inc, function AddFileToLibrusec) всем этим 4063 книгам при заливке будут обнаружены дубли, конфликт которых придется разрешать вручную. Это очень много кликов. За один день вручную столько не сделать, и получится, что эта заливка забьет ленту новостей на несколько дней в лучшем случае. Да и лень делать вручную то, что можно отдать машине, она железная. Поэтому я хочу попросить Ларина внести изменения в заливочный скрипт. Точный текст изменения я сформирую попозже, а пока смысл этого изменения. Как работает заливочный скрипт сейчас: Как я предлагаю: 1. Автоматический апгрейд той же книги Если 2. Автоматическая замена книги, сделанной LibRusEc kit Если Если ни одна из этих проверок не выполняется - то, как и раньше, предложение разрешить конфликт дублей вручную. Вопрос: не создаст ли такое изменение каких-либо подводных камней? ----------- -----------
|
Вход на сайтПоиск по блогам и форумамUser menuПоследние комментарии
Саша из Киева RE:Приключения белочки Рыжки 1 день
alex-from RE:Оплатил два раза, но абонемента нет 3 дня sem14 RE:Книжная серия "Жизнь в искусстве" издательство "Искусство"... 4 дня Kiesza RE:На 78-м году жизни скончался советский и российский... 4 дня Aliki RE:Подайте бедному копеечку на книжку с литреса... 5 дней Paul von Sokolovski RE:Бушков умер. 2 недели lemma7 RE:Серия «Интеллектуальный детектив» изд-ва АСТ 2 недели mig2009 RE:Багрепорт - 2 2 недели Isais RE:Издательство "Медуза" 2 недели babajga RE:Народные сказки - Сказки народов Сибири = Fairy-Tales of... 1 месяц Саша из Киева RE:Кто сможет раздобыть и оцифровать нужные мне книги? 1 месяц sibkron RE:Серия "Библиотека французской литературы" (Макбел) 1 месяц Isais RE:Игорь Северянин - Том 2. Поэзоантракт 1 месяц sem14 RE:Современная корейская литература. Книжная серия... 1 месяц sem14 RE:Семейственность в литературе 1 месяц Isais RE:Детство, опаленное войной (Вторая мировая 1939-1945 и ВОВ) 1 месяц Саша из Киева RE:Подводное течение 2 месяца konst1 RE:Переименовать ник (имя учетки) 2 месяца Впечатления о книгах
Shelest 2000 про Черепнев: Цена империи. Выбор пути [litres] (Альтернативная история, Боевая фантастика)
07 11 Продолжение после 4й книги будет?
ne_fanat про Александр Александрович Бушков
06 11 Земля пухом, Сан Саныч. Спасибо за написанное, жаль, что больше ничего не напишете. Мне будет вас не хватать.
ne_fanat про Дронт: Первый в фамилии [СИ] (Социальная фантастика, Фэнтези, Попаданцы, Самиздат, сетевая литература)
06 11 Не соглашусь с предыдущим оратором:) Серенько и простенько только если рассматривать это как самостоятельное произведение. А вот если как вбоквел "Придворного", да с возможностью продолжения, да с раскрытием туманных моментов ……… Оценка: хорошо
Perca про Киров: Рыцарь Огненной кавалерии [СИ] (Фэнтези, Самиздат, сетевая литература)
06 11 Очень неплохо. Такое впечатление, что "Никит Кировых" двое, один регулярно пишет откровенный треш, а другой выдает неплохие вещи, хоть и достаточно редко. Оценка: отлично!
Perca про Киров: Молот империи 1 [СИ] (Боевая фантастика, Городское фэнтези, Самиздат, сетевая литература)
06 11 Серия неплохая, на удивление. Беда в том, что чтобы быть в теме, надо сначала прочитать откровенный шлак, приквел "Я - палач" аж в трех томах.
Олег Макаров. про Лагин: Старик Хоттабыч [litres] (Советская классическая проза, Сказка)
06 11 2 RedRoses3: не распространяйте фейки. Крон был только соавтором Лагина в работе над сценарием фильма «Старик Хоттабыч» (в 50-е годы). В процессе работы они разругались. После этого Крон чего только не говорил
RedRoses3 про Лагин: Старик Хоттабыч [litres] (Советская классическая проза, Сказка)
06 11 В 1938 году Лазарь Лагин написал детскую повесть-сказку «Старик Хоттабыч»! - хм... а со временем хороший писатель Александо Крон признался, что в молодости подрабатывал литрабом и Хоттабыча написал он... А Лагин так больше ничего выдающегося и не натворил....
Олег Макаров. про Карелин: Архитектор душ (Городское фэнтези, Попаданцы, Самиздат, сетевая литература)
05 11 Идея неплохая, но написано предельно нудно. Сюжет стоит на месте, буксует, шины визжат, но ничего не едет. Почти до конца первую книгу дочитал и бросил Оценка: плохо
Олег Макаров. про Анатолий Н. Патман
05 11 «боец СВО, оказавшийся, на удивление, наследником древней космической, и могущественной цивилизации» обожемой! какой полёт мысли у автора! какая акутальность шыдевра! какая смелая интерпретация событий! ну и так далее. Вот ………
Sanyok89 про Пелевин: A Sinistra | А Синистра | Левый Путь (Триллер, Современная проза)
05 11 Ну хоть одна более-менее читаемая книга из этого цикла. Завершать уже пора этот трансгуманизм, а то Санта Барбара какая то Оценка: неплохо
Олег Макаров. про Андрей Владимирович Курпатов
04 11 Доктор Курпатов, Доктор Курпатов, Доктор Курпатов - многократное повторение этого словосочетания создало у многих превратное представление о том, что А.Курпатов является доктором наук. На самом деле человек имеет только ………
Lena Stol про Искаженный мир
04 11 Прочитала обе книги, пропускала много, особенно во второй части, хороший сюжет, но уж очень автор растянул. Если из двух книг сделать одну, будет интереснее. |
Комментарии
Текст изменения в 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 всё должно работать :((