Difference between revisions of "FtpSpider"

From JaWiki (Jabber/XMPP wiki)
Jump to: navigation, search
m
m (GPL -> {{GPL}})
 
(15 intermediate revisions by 4 users not shown)
Line 1: Line 1:
Что-то типа официального сайта: http://mediazona.ru/forum/index.php?automodule=blog&blogid=164&showentry=5022 <br>
+
{{Bot
Исходный код скоро будет доступен.  
+
|            name=FtpSpider
 +
|            url=[http://mediazona.ru/forum/index.php?automodule=blog&blogid=164&showentry=5022 запись в блоге]
 +
|        language={{Lang|b|Python}}
 +
|        library={{Lib|xmpppy}}
 +
|        license={{GPL}}
 +
|            i18n=да
 +
|          disco=нет
 +
|        plugins=да
 +
|          adhoc=нет
 +
}}
 +
Бот является ответвлением (форком) [[Neutron|Нейтрона]]. Основное предназначение&nbsp;&mdash; следить за деревом файлов на определенном [[w:FTP|FTP]]-сервере и сообщать пользователями о тех изменениях, которые их интересуют.
  
Бот является форком [[Neutron|Нейтрона]]. Основное предназначение &mdash; следить за изменениями файлов на FTP и сообщать пользователями то, что их интересует.  
+
Исходный код можно получить из [https://svn.jrudevels.org/ftpspider/ SVN-репозитария] или скачать [http://jrudevels.org/index.php?pg=downloads.php&dir=ftpspider стабильную версию].
  
Работает по следующему алгоритму: периодически производится сканирование FTP дерева и высчитывается разницу по сравнению с предыдущим сканом. Потом для каждого пользователя из разницы выбираются интересующие файлы в соотвествии с введенными пользователем фильтрами и результат отправляется на его [[JID]].  
+
== Алгоритм ==
 +
Бот работает по следующему алгоритму: периодически производится сканирование FTP-сервера&nbsp;&mdash; создается снимок дерева файлов. Далее определяется разница по сравнению с предыдущим снимком. Из этой разницы для каждого пользователя отдельно выбираются интересующие его изменения и полученный отчет отправляется на его [[JID]].  
  
== Команды ==
+
Сам бот состоит из двух частей:
 +
* Первая часть является постоянно запущенным ботом, созданным на основе бота neutron. Он принимает команды, общается с пользователями, сохраняет настройки и рассылает отчеты.
 +
* Вторая часть&nbsp;&mdash; многопоточный FTP-сканер. Он создает снимок, высчитывает разницу и статистику и полученные данные отправляет боту.
  
 +
 +
 +
== Команды ==
 
=== Работа со списками ===
 
=== Работа со списками ===
* '''!list''' -- просмотреть списки. (Include -- то, что интересно. Exclude -- то что надо пропустить)
+
* '''list'''&nbsp;&mdash; просмотреть списки. (Include&nbsp;&mdash; то, что интересно. Exclude&nbsp;&mdash; то что надо пропустить)
* '''!add''' -- добавить полный URL или его часть в список Include
+
* '''add'''&nbsp;&mdash; добавить полный URL или его часть в список Include
* '''!exclude''' -- добавить полный URL или его часть в список Exclude
+
* '''exclude'''&nbsp;&mdash; добавить полный URL или его часть в список Exclude
* '''!del''' -- удалить адрес. Можно указать сам URL или его номер из !list
+
* '''del'''&nbsp;&mdash; удалить адрес. Можно указать сам URL или его номер из !list
* '''!clear (all, include, exclude)''' -- очистить все или какой-то из фильтров отдельно.
+
* '''clear (all, include, exclude)'''&nbsp;&mdash; очистить все или какой-то из фильтров отдельно.
  
 
=== Личные предпочтения ===
 
=== Личные предпочтения ===
* '''!show''' -- в каком виде высылать url:
+
* '''show'''&nbsp;&mdash; в каком виде высылать url:
** unquoted -- неэкранированный
+
** unquoted&nbsp;&mdash; неэкранированный
** quoted -- экранированный (по-умолчанию)
+
** quoted&nbsp;&mdash; экранированный (по-умолчанию)
** full -- полный (по-умолчанию)
+
** full&nbsp;&mdash; полный (по-умолчанию)
** path -- только путь без сервера
+
** path&nbsp;&mdash; только путь без сервера
* '''!mode''' -- в каком виде вы предпочитаете получать информацию:
+
* '''mode'''&nbsp;&mdash; в каком виде вы предпочитаете получать информацию:
** message -- простое сообщение
+
** message&nbsp;&mdash; простое сообщение
** chat -- в чате (по-умолчанию)
+
** chat&nbsp;&mdash; в чате (по-умолчанию)
** headline -- как новость (должен поддерживать клиент)
+
** headline&nbsp;&mdash; как новость (должен поддерживать клиент)
* '''!filter''' -- тип информации:  
+
* '''filter'''&nbsp;&mdash; тип информации:  
** add -- то, что добавленно (по-умолчанию)
+
** add&nbsp;&mdash; то, что добавленно (по-умолчанию)
** del -- то, что удалено
+
** del&nbsp;&mdash; то, что удалено
** all -- и то и другое
+
** all&nbsp;&mdash; и то и другое
  
 
=== Работа со статистикой ===
 
=== Работа со статистикой ===
* '''!stats''' -- показать статистику, собранную во время последнего обхода, и режим вашей подписки на неё
+
* '''stats'''&nbsp;&mdash; показать статистику, собранную во время последнего обхода, и режим вашей подписки на неё
* '''!stats <param>''' -- изменить режим подписки:
+
* '''stats <param>'''&nbsp;&mdash; изменить режим подписки:
** full -- получать полную статистику, как её показывает !stats без параметров
+
** full&nbsp;&mdash; получать полную статистику, как её показывает !stats без параметров
** brief -- получать сокращенный вариант
+
** brief&nbsp;&mdash; получать сокращенный вариант
** none -- не получать статистику (по-умолчанию)
+
** none&nbsp;&mdash; не получать статистику (по-умолчанию)
  
 
=== Помощь ===
 
=== Помощь ===
* '''!commands''' -- список команд
+
* '''commands'''&nbsp;&mdash; список команд
* '''!help''' -- справка с примерами
+
* '''help'''&nbsp;&mdash; справка с примерами
 
+
  
 
=== Остальное ===
 
=== Остальное ===
* '''!quote''' -- экранировать переданный адрес (один!)
+
* '''quote'''&nbsp;&mdash; экранировать переданный адрес (один!)
* '''!unquote''' -- разэкранировать переданные адреса (сколько угодно)
+
* '''unquote'''&nbsp;&mdash; разэкранировать переданные адреса (сколько угодно)
* '''!test''' -- выслать пример сообщения и статистики для проверки настроек команд !mode, !filter, !show, !stats
+
* '''test'''&nbsp;&mdash; выслать пример сообщения и статистики для проверки настроек команд !mode, !filter, !show, !stats
* '''!unregister''' -- удалить себя из базы и больше ничего не получать
+
* '''unregister'''&nbsp;&mdash; удалить себя из базы и больше ничего не получать
  
 
== FtpSpider и FtpInfo ==
 
== FtpSpider и FtpInfo ==
Бот по сути является "серверной" реализацией известной программы [[http://www.ftpinfo.ru/ FtpInfo]], точнее не её полностью, а той части, которая показывает изменения на FTP. Принцип работы тот же самый, но данная серверная реализация имеет следующие плюсы и минусы по сравнению с клиентской:
+
Бот по сути является «серверной» реализацией известной программы [http://www.ftpinfo.ru/ FtpInfo], точнее не её полностью, а той части, которая показывает изменения на FTP. Принцип работы тот же самый, но данная серверная реализация имеет следующие плюсы и минусы по сравнению с клиентской:
  
 
Плюсы:
 
Плюсы:
Line 56: Line 71:
  
 
Минусы:
 
Минусы:
* Меньше контроля и опций.  
+
* Меньше контроля и опций.
* Нельзя запустить сканирование вручную, приходится ждать.
+
* Нельзя запустить сканирование вручную когда хочется.
  
 +
Кроме того, я не учитываю, что у программы FtpInfo есть другие возможности, которых пока нет у бота: поиск в просканированных файлах и т.п.
  
== См. также ==
+
== Смотри также ==
 
* [[Neutron]]
 
* [[Neutron]]
  
[[Category:Bot]]
+
== Ссылки ==
 +
* [http://bugs.jrudevels.org/index.php?tasks=all&project=7 багтрекер ftpspider-а]
 +
* [https://svn.jrudevels.org/ftpspider/ репозитарий]
 +
* [http://jrudevels.org/index.php?pg=downloads.php&dir=ftpspider стабильные версии]

Latest revision as of 22:09, 26 July 2009

FtpSpider
Информация
Сайт: запись в блоге
Язык: Python
Библиотека: xmpppy
Лицензия: GPL
Характеристики
Мультиязычность: да
Расширяемость: да
Discovery: нет
Ad-hoc команды: нет

Бот является ответвлением (форком) Нейтрона. Основное предназначение — следить за деревом файлов на определенном FTP-сервере и сообщать пользователями о тех изменениях, которые их интересуют.

Исходный код можно получить из SVN-репозитария или скачать стабильную версию.

Алгоритм[edit]

Бот работает по следующему алгоритму: периодически производится сканирование FTP-сервера — создается снимок дерева файлов. Далее определяется разница по сравнению с предыдущим снимком. Из этой разницы для каждого пользователя отдельно выбираются интересующие его изменения и полученный отчет отправляется на его JID.

Сам бот состоит из двух частей:

  • Первая часть является постоянно запущенным ботом, созданным на основе бота neutron. Он принимает команды, общается с пользователями, сохраняет настройки и рассылает отчеты.
  • Вторая часть — многопоточный FTP-сканер. Он создает снимок, высчитывает разницу и статистику и полученные данные отправляет боту.


Команды[edit]

Работа со списками[edit]

  • list — просмотреть списки. (Include — то, что интересно. Exclude — то что надо пропустить)
  • add — добавить полный URL или его часть в список Include
  • exclude — добавить полный URL или его часть в список Exclude
  • del — удалить адрес. Можно указать сам URL или его номер из !list
  • clear (all, include, exclude) — очистить все или какой-то из фильтров отдельно.

Личные предпочтения[edit]

  • show — в каком виде высылать url:
    • unquoted — неэкранированный
    • quoted — экранированный (по-умолчанию)
    • full — полный (по-умолчанию)
    • path — только путь без сервера
  • mode — в каком виде вы предпочитаете получать информацию:
    • message — простое сообщение
    • chat — в чате (по-умолчанию)
    • headline — как новость (должен поддерживать клиент)
  • filter — тип информации:
    • add — то, что добавленно (по-умолчанию)
    • del — то, что удалено
    • all — и то и другое

Работа со статистикой[edit]

  • stats — показать статистику, собранную во время последнего обхода, и режим вашей подписки на неё
  • stats <param> — изменить режим подписки:
    • full — получать полную статистику, как её показывает !stats без параметров
    • brief — получать сокращенный вариант
    • none — не получать статистику (по-умолчанию)

Помощь[edit]

  • commands — список команд
  • help — справка с примерами

Остальное[edit]

  • quote — экранировать переданный адрес (один!)
  • unquote — разэкранировать переданные адреса (сколько угодно)
  • test — выслать пример сообщения и статистики для проверки настроек команд !mode, !filter, !show, !stats
  • unregister — удалить себя из базы и больше ничего не получать

FtpSpider и FtpInfo[edit]

Бот по сути является «серверной» реализацией известной программы FtpInfo, точнее не её полностью, а той части, которая показывает изменения на FTP. Принцип работы тот же самый, но данная серверная реализация имеет следующие плюсы и минусы по сравнению с клиентской:

Плюсы:

  • Не надо ждать пока дерево просканируется. Вообще не надо об этом заботится: как только данные появятся, вам придет письмо.
  • Меньше нагрузки на сервер (один сканер, а не много).

Минусы:

  • Меньше контроля и опций.
  • Нельзя запустить сканирование вручную когда хочется.

Кроме того, я не учитываю, что у программы FtpInfo есть другие возможности, которых пока нет у бота: поиск в просканированных файлах и т.п.

Смотри также[edit]

Ссылки[edit]