]> Cypherpunks.ru repositories - nncp.git/blobdiff - doc/usecases.ru.texi
Remote command execution
[nncp.git] / doc / usecases.ru.texi
index 78902e5327b2834771ab66dcf860ac8215b65c05..3e3caba2dbdd889cb32f761c52ebb3db131401c2 100644 (file)
@@ -1,4 +1,4 @@
-@node Сценарии использования
+@node Сценарии
 @section Сценарии использования
 
 @menu
@@ -7,6 +7,7 @@
 * Ненадёжный/дорогой канал связи: UsecaseUnreliableRU.
 * Медленная/дорогая связь для больших объёмов данных, плохой QoS: UsecaseQoSRU.
 * Экстремальные наземные окружающие условия, нет связи: UsecaseNoLinkRU.
+* Односторонняя широковещательная связь: UsecaseBroadcastRU.
 * Частные, изолированные MitM/Sybil-устойчивые сети: UsecaseF2FRU.
 * Высоко защищённые изолированные компьютеры с воздушным зазором: UsecaseAirgapRU.
 * Обход сетевой цензуры, здоровье: UsecaseCensorRU.
@@ -24,7 +25,7 @@ Postfix} SMTP сервер подключённый к Интернету. Но
 
 Одна из возможностей это войти на сервер и сделать что-то типа
 @command{postqueue -f}, но по-умолчанию у вас есть только несколько дней
-на это, плюс отправитель будет получать уведомления о том что его
+на это, плюс отправитель будет получать уведомления о том, что его
 сообщение всё ещё не доставлено. Кроме того, вы должны использовать
 безопасный канал связи (SSH, VPN, итд).
 
@@ -34,30 +35,30 @@ Postfix} SMTP сервер подключённый к Интернету. Но
 KISS}!
 
 Просто скажите вашим обоим Postfix-ам (на сервере и ноутбуке) отправлять
-сообщения через NNCP (@ref{nncp-mail}) на заданный узел. Это делается
+сообщения через NNCP (@ref{nncp-exec}) на заданный узел. Это делается
 аналогично тому как с UUCP, и описано в
 @url{http://www.postfix.org/UUCP_README.html, документации Postfix}.
 
 Читайте @ref{Postfix, здесь} для более подробной информации. Вся почта
 будет сохранятся в NNCP @ref{Spool, спуле}, который после обмена данных
 и распаковки вызовет локальный @command{sendmail} для доставки почты,
-как будто это произошло на этой же машине.
+как-будто это произошло на этой же машине.
 
 @node UsecasePOPRU
 @subsection Легковесная и быстрая замена POP3/IMAP4
 
 @ref{nncp-daemon} может быть соединён с @ref{nncp-caller} длительное
 время -- он создаёт TCP соединение на многие часы. Когда SMTP сервер
-получает письмо, то вызывает @ref{nncp-mail} для создания исходящего
+получает письмо, то вызывает @ref{nncp-exec} для создания исходящего
 зашифрованного пакета. Демон ежесекундно проверяет исходящую директорию
 и сразу же посылает оповещение о недоставленных пакетах противоположной
 стороне, которая сразу же их может скачать.
 
-Всего несколько дюжин байтов оповещают о входящих пакетах, дюжины байт
+Всего несколько дюжин байт оповещают о входящих пакетах, дюжины байт
 начинающие доставку этих пакетов. Почтовые пакеты сжимаются (POP3 и
-IMAP4, как правило, нет). У вас легковесный, сжатый, надёжный, с низкими
-задержками канал связи для почты с сильным шифрованием и двусторонней
-аутентификацией!
+IMAP4, как правило, нет). У вас легковесный, сжатый, надёжный канал
+связи с низкими задержками для почты, с сильным шифрованием и
´Ð²Ñ\83Ñ\81Ñ\82оÑ\80онней Ð°Ñ\83Ñ\82енÑ\82иÑ\84икаÑ\86ией!
 
 @node UsecaseUnreliableRU
 @subsection Ненадёжный/дорогой канал связи
@@ -65,11 +66,11 @@ IMAP4, как правило, нет). У вас легковесный, сжа
 Представьте, что у вас медленный модем/радио/спутниковый канал связи,
 который часто обрывается и вызывает timeout у TCP. Не все HTTP серверы
 поддерживают возобновляемые скачивания. SMTP вообще не поддерживает
²Ð¾Ð·Ð¾Ð±Ð½Ð¾Ð²Ð»ение оборванного приёма и тяжёлые сообщения становится очень
¿Ñ\80одолжение оборванного приёма и тяжёлые сообщения становится очень
 проблематично получить. Более того, каждый обрыв может приводить к
 отсылке данных с самого начала, что не всегда по карману.
 
-Просто отправьте вашу @ref{nncp-mail, почту} и @ref{nncp-file, файлы}
+Просто отправьте вашу @ref{nncp-exec, почту} и @ref{nncp-file, файлы}
 через NNCP. Вы сможете использовать или offline методы доставки --
 читайте о них в следующем разделе, либо использовать поставляемый NNCP
 @ref{nncp-daemon, TCP демон}.
@@ -113,6 +114,13 @@ NNCP поддерживает @ref{Niceness, приоритезацию траф
 давая возможность передачи, по сути, любых объёмов используя накопители
 небольших размеров.
 
+Вы также можете использовать CD-ROM и ленточные накопители:
+
+@verbatim
+% nncp-bundle -tx bob | cdrecord -tao -
+% nncp-bundle -tx bob | dd of=/dev/sa0 bs=10240
+@end verbatim
+
 @node UsecaseNoLinkRU
 @subsection Экстремальные наземные окружающие условия, нет связи
 
@@ -122,7 +130,8 @@ NNCP поддерживает @ref{Niceness, приоритезацию траф
 передачи пакетов другим узлам.
 
 Представьте, что вы послали два файла узлу @emph{bob}. Вставьте USB
-устройство хранения, подмонтируйте и запустите @ref{nncp-xfer}:
+устройство (SD гораздо предпочтительнее!) хранения, подмонтируйте и
+запустите @ref{nncp-xfer}:
 
 @verbatim
 % nncp-xfer -node bob /media/usbstick
@@ -152,6 +161,27 @@ NNCP поддерживает @ref{Niceness, приоритезацию траф
 дальнейшей обработки. @command{nncp-xfer} это единственная команда
 используемая с переносными устройствами хранения.
 
+@node UsecaseBroadcastRU
+@subsection Односторонняя широковещательная связь
+
+Иногда у вас есть ёмкий, но односторонний, канал связи, например
+широковещательный сигнал со спутника. Вы не можете использовать online
+@ref{Sync, протокол синхронизации}, потому что он требует двустороннего
+взаимодействия.
+
+Вы можете использовать, так называемые, @ref{Bundles, пачки} и потоково
+отсылать их. Они -- всего-лишь последовательность @ref{Encrypted,
+зашифрованных пакетов}, которые вы можете принять.
+
+@verbatim
+% nncp-bundle -tx alice bob eve ... | команда для отправки широковещательной рассылки
+% команда для приёма широковещательной рассылки | nncp-bundle -rx
+@end verbatim
+
+Встроенная возможность определять дубляжи пакетов позволит вам
+переотправлять широковещательные рассылки время от времени, повышая
+шансы на то, что получатель примет их, регулярно слушая рассылку.
+
 @node UsecaseF2FRU
 @subsection Частные, изолированные MitM/Sybil-устойчивые сети
 
@@ -206,8 +236,8 @@ NNCP поддерживает @ref{Niceness, приоритезацию траф
 выбором. Компьютер без каких-либо модемов, проводных и беспроводных
 сетей. Очевидно, что единственная возможность обмениваться почтой и
 файлами -- использовать физически переносимые устройства хранения типа
-CD-ROM, жёстких дисков, лент и USB накопителей (худший вариант, из-за
-сложности подобных устройств).
+CD-ROM, жёстких дисков, SD, лент и USB накопителей (@strong{худший}
+вариант, из-за сложности подобных устройств).
 
 Предполагаем что у вас есть ещё один собственный узел, стоящий "до"
 безопасного, который делает базовые проверки полученных накопителей,
@@ -247,13 +277,13 @@ neigh:
 @subsection Обход сетевой цензуры, здоровье
 
 Это тоже подвид плохого канала связи. Некоторые правительства склонны к
-запрету @strong{любого} вида личного общения между людьми, разрешая
-только доставку развлекательного контента и доступ к популярным
+запрету @strong{любого} вида личного (приватного) общения между людьми,
\80азÑ\80еÑ\88аÑ\8f Ñ\82олÑ\8cко Ð´Ð¾Ñ\81Ñ\82авкÑ\83 Ñ\80азвлекаÑ\82елÑ\8cного ÐºÐ¾Ð½Ñ\82енÑ\82а Ð¸ Ð´Ð¾Ñ\81Ñ\82Ñ\83п Ðº Ð¿Ð¾Ð¿Ñ\83лÑ\8fÑ\80нÑ\8bм
 социальным сетям (которые уже вовсю наводнены рекламой, локально
 исполняемым @url{https://www.gnu.org/philosophy/free-sw.ru.html,
-проприетарным} JavaScript кодом (для слежкой за действиями
-пользователя, сбором данных), бесстыдно и бессовестно эксплуатируя
-базовые потребности человека в общении).
+проприетарным} JavaScript кодом (для слежкой за действиями пользователя,
+сбором данных), бесстыдно и бессовестно эксплуатируя базовые потребности
+человека в общении).
 
 Это их естественное желание. Но никто вас не заставляет насильно
 подчиняться огромным корпорациям типа Apple, Google или Microsoft. Ваш
@@ -265,12 +295,12 @@ neigh:
 @node UsecaseSpyRU
 @subsection Разведка, шпионаж, тайная агентура
 
-ЭÑ\82и Ñ\80ебÑ\8fÑ\82а Ð·Ð½Ð°Ñ\8eÑ\82 Ð½Ð°Ñ\81колÑ\8cко Ð½ÐµÐ±ÐµÐ·Ð¾Ð¿Ð°Ñ\81ное Ð¼ÐµÑ\81Ñ\82о Ð\98нÑ\82еÑ\80неÑ\82, Ð½ÐµÑ\81овмеÑ\81Ñ\82имое с
-понÑ\8fÑ\82ием Ð¿Ñ\80иваÑ\82ноÑ\81Ñ\82и. Ð\98м Ð½ÐµÐ¾Ð±Ñ\85одим Ð±Ñ\8bÑ\81Ñ\82Ñ\80Ñ\8bй Ñ\81бÑ\80оÑ\81 Ð¸ Ð·Ð°Ð±Ð¾Ñ\80 Ð´Ð°Ð½Ð½Ñ\8bÑ\85. Ð\91ез
-возможноÑ\81Ñ\82и Ð½ÐµÑ\81колÑ\8cкиÑ\85 Ð¸Ñ\82еÑ\80аÑ\86ий Ñ\82Ñ\83да-обÑ\80аÑ\82но (round trip) -- Ñ\82олÑ\8cко
-сбросить данные, выстрелить и забыть. Опять же, это может быть
+ЭÑ\82и Ñ\80ебÑ\8fÑ\82а Ð·Ð½Ð°Ñ\8eÑ\82 Ð½Ð°Ñ\81колÑ\8cко Ð½ÐµÐ±ÐµÐ·Ð¾Ð¿Ð°Ñ\81ен Ð\98нÑ\82еÑ\80неÑ\82, Ð½ÐµÑ\81овмеÑ\81Ñ\82им с
+понÑ\8fÑ\82ием Ð¿Ñ\80иваÑ\82ноÑ\81Ñ\82и. Ð\98м Ð½ÐµÐ¾Ð±Ñ\85одим Ð±Ñ\8bÑ\81Ñ\82Ñ\80Ñ\8bй Ñ\81бÑ\80оÑ\81 Ð¸ Ð·Ð°Ð±Ð¾Ñ\80 Ð´Ð°Ð½Ð½Ñ\8bÑ\85. Ð\9dеÑ\82
+возможноÑ\81Ñ\82и Ð¿Ñ\80овеÑ\81Ñ\82и Ð½ÐµÑ\81колÑ\8cко Ð¸Ñ\82еÑ\80аÑ\86ий Ñ\82Ñ\83да-обÑ\80аÑ\82но (round trip) --
\82олÑ\8cко Ñ\81бÑ\80оÑ\81иÑ\82Ñ\8c Ð´Ð°Ð½Ð½Ñ\8bе, Ð²Ñ\8bÑ\81Ñ\82Ñ\80елиÑ\82Ñ\8c Ð¸ Ð·Ð°Ð±Ñ\8bÑ\82Ñ\8c. Ð\9eпÑ\8fÑ\82Ñ\8c Ð¶Ðµ, Ñ\8dÑ\82о Ð¼Ð¾Ð¶ÐµÑ\82 Ð±Ñ\8bÑ\82Ñ\8c
 переносной накопитель и/или
-@url{https://en.wikipedia.org/wiki/USB_dead_drop, USB тайник},
+@url{https://en.wikipedia.org/wiki/USB_dead_drop, USB тайник} (dead drop),
 @url{https://en.wikipedia.org/wiki/PirateBox, PirateBox}ы,
 @url{https://en.wikipedia.org/wiki/Short-range_agent_communications,
 связь малой дальности (SRAC)}. Короткоживущие сети малой дальности типа
@@ -290,9 +320,9 @@ Bluetooth и WiFi могут быть и довольно быстрыми, по
 необходимо запустить другую фазу: @ref{nncp-toss, распаковку}, которая
 использует ваши приватные криптографические ключи. То есть, даже если вы
 потеряете свой компьютер, устройства хранения и тому прочее -- это не
-так плохо, потому-что вы не носите с собой приватные ключи (ведь так?),
+так плохо, потому что вы не носите с собой приватные ключи (ведь так?),
 вы не "распаковываете" эти пакеты сразу же на том же самом устройстве.
 Распаковка (чтение этих зашифрованных пакетов с извлечением переданных
 файлов и почтовых сообщений) может и должна бы быть произведена на
-отдельном компьютере (@ref{nncp-mincfg} команда может помочь с созданием
+отдельном компьютере (@ref{nncp-cfgmin} команда может помочь с созданием
 конфигурационного файла без приватных ключей для этой цели).