5 @subsection Релиз 6.5.0
9 Исправлено падение в @command{nncp-daemon} когда SP рукопожатие не было успешно.
12 Исправлено возможное игнорирование плохого кода возврата автоматического tosser.
15 Убирать показ прогресса передачи пакетов когда вызов уже завершён в
16 @command{nncp-daemon}, @command{nncp-call} and @command{nncp-caller}.
21 @subsection Релиз 6.4.0
25 Исправлена возможная гонка в online протоколе, приводящая к падению
31 @subsection Релиз 6.3.0
35 Исправлено возможное падение программы во время показа прогресса online
41 @subsection Релиз 6.2.1
45 В трёх местах сообщений журналов по ошибке остались лишние @code{%s}.
50 @subsection Релиз 6.2.0
54 Возвращена работоспособность @option{-autotoss*} опций @command{nncp-caller}.
57 Очередной рефакторинг и упрощение системы журналирования.
58 Не должно быть видимых изменений для конечного пользователя.
63 @subsection Релиз 6.1.0
67 Оптимизация: большинство команд теперь не держат открытыми файловые
68 дескрипторы. Прежде вы легко могли выйти за пределы максимально
69 допустимого количества открытых файлов, если у вас было много пакетов в
73 Оптимизация: не закрывать файловый дескриптор файла который мы качаем.
74 Прежде каждый его кусочек приводил к дорогим open/close вызовам.
77 Скачиваемые в режиме online файлы теперь сохраняются с @file{.nock}
78 суффиксом (non-checksummed), ожидая пока либо @command{nncp-check}, либо
79 online демоны не выполнят проверку целостности.
82 Оптимизация: для файлов, скачивание которых не было продолжено, сразу же
83 вычисляет контрольная сумма, пропуская промежуточный @file{.nock} шаг.
86 Возможность хранения заголовков зашифрованных пакетов в @file{.hdr}
87 файлах, рядом с самими пакетами. Это может существенно повысить скорость
88 получения списка пакетов на файловых системах с большим размером блока.
93 @subsection Релиз 6.0.0
97 Журнал использует человеко-читаемый и легко обрабатываемый машиной
98 @url{https://www.gnu.org/software/recutils/, recfile} формат для своих
99 записей, вместо структурированных строчек RFC 3339. Старый формат
100 журналов не поддерживается @command{nncp-log}.
103 Работоспособность @option{-autotoss*} опции с @option{-inetd} режимом
104 @command{nncp-daemon}.
107 @option{when-tx-exists} опция вызова в конфигурационном файле позволяет
108 делать вызов только если имеются исходящие сообщения. Совмещённая с cron
109 выражением содержащим секунды, это можно использовать как возможность
110 вызова только при появлении исходящих пакетов.
113 @command{nncp-cronexpr} команда позволяет проверить корректность и
114 ожидаемый результат от указанного cron выражения.
119 @subsection Релиз 5.6.0
123 @option{-autotoss*} опции запускают tosser не после завершения вызова, а
124 во время него ежесекундно.
127 В @option{calls} секции конфигурации появились опции
128 @option{autotoss}, @option{autotoss-doseen},
129 @option{autotoss-nofile}, @option{autotoss-nofreq},
130 @option{autotoss-noexec}, @option{autotoss-notrns}.
131 Вы можете настраивать опции автоматического tosser для каждого вызова.
134 Использовать vendoring вместо переопределения @env{GOPATH} во время
135 установки tarball, так как текущая минимальная версия Go это 1.12,
136 поддерживающая модули.
141 @subsection Релиз 5.5.1
145 Уважать @env{BINDIR}, @env{INFODIR} и @env{DOCDIR} переменные окружения
146 в @file{config} во время установки.
151 @subsection Релиз 5.5.0
155 Исправления ошибок в @command{nncp-call(er)}/@command{nncp-daemon},
156 @command{nncp-bundle}, @command{nncp-stat} командах.
159 У команды @command{nncp-rm} появились @option{-dryrun} и @option{-older} опции.
162 У команды @command{nncp-exec} появились @option{-use-tmp} и
163 @option{-nocompress} опции. Несжатые пакеты не совместимы с предыдущими
167 У команд @command{nncp-call}, @command{nncp-caller} и @command{nncp-daemon}
168 появились @option{-autotoss*} опции для запуска tosser после завершения звонка.
171 Обновлены зависимые библиотеки. Минимальная требуемая версия Go 1.12.
176 @subsection Релиз 5.4.1
180 Исправлена ошибка с учётом @code{SENDMAIL} переменной при сборке.
185 @subsection Релиз 5.4.0
189 Обновлены зависимые библиотеки.
192 Система сборки переведена с Makefile-ов на @url{http://cr.yp.to/redo.html, redo}.
193 Это не должно повлиять на мейнтейнеров пакетов, так как минимальная
194 реализация @command{redo} включена в tarball.
199 @subsection Релиз 5.3.3
203 Больше различных проверок в коде на ошибки.
206 Обновлены зависимые библиотеки.
211 @subsection Релиз 5.3.2
215 Исправлена некорректная логика @option{onlinedeadline} timeout-а, при
216 котором соединение могло не учитывать факты прихода пакетов и обрывать
222 @subsection Релиз 5.3.1
226 Исправлена работоспособность @option{onlinedeadline} с адресами вызова
227 использующими внешние команды (@verb{#"|somecmd"#}).
230 @command{nncp-stat} имеет опцию @option{-pkt} показывающую информацию по
231 каждому пакету в spool.
236 @subsection Релиз 5.3.0
240 Сообщения прогресса содержат префикс, поясняющий выполняемое действие.
243 Исправлено не происходящее дополнение (padding) handshake сообщений.
246 Завершать все порождаемые в SP протоколе горутины, меньше утечек памяти.
249 SP протокол порождает меньше вызовов записей (соответственно, и TCP
253 Проверять @option{onlinedeadline} и @option{maxonlinetime} ежесекундно,
254 независимо от чтения из сокета (раз в 10 секунд в худшем случае).
257 Раз в минуту, если нет более никакого другого трафика, посылаются PING
258 пакеты в SP-соединении. Это позволит быстрее понимать что соединение
259 более не работоспособно.
262 @command{nncp-toss} использует lock-file для предотвращения
263 одновременной обработки зашифрованных пакетов.
268 @subsection Релиз 5.2.1
272 Исправлена обработка ошибки SP протокола, иногда вызывающая панику программы.
277 @subsection Релиз 5.2.0
281 Большинство команд по умолчанию показывают однострочный прогресс
282 выполнения операции. Появились @option{-progress}, @option{-noprogress}
283 опции командной строки, @option{noprogress} опция конфигурационного
287 Исправлен некорректный код возврата @command{nncp-check} команды,
288 который возвращал ошибку когда всё хорошо.
291 Проверка свободного места для пакетов, во время выполнения
292 @command{nncp-bundle -rx}.
297 @subsection Релиз 5.1.2
301 Исправлена @strong{критичная} уязвимость: аутентификация online нод
302 могла приводить к некорректной идентификации удалённой стороны, позволяя
303 скачивать чужие зашифрованные пакеты.
306 Исправлена ошибка: в новосозданных конфигурационных файлах, приватный
307 публичный ключ Noise были поменяны местами, что приводило к
308 невозможности online аутентификации нод.
311 Явная синхронизация (fsync) директорий для гарантированного
312 переименования файлов.
317 @subsection Релиз 5.1.1
321 Исправлена работоспособность @command{nncp-file} с @option{-chunked 0} опцией.
326 @subsection Релиз 5.1.0
330 @command{nncp-file} может отправлять директории, автоматически на лету
334 Во время создания исходящих сообщений проверяется наличие свободного
335 места на файловой системе.
338 @option{freq}, @option{freqminsize}, @option{freqchunked} опции
339 конфигурационного файла заменены на структуру
340 @option{freq: @{path: ..., minsize: ..., chunked: ...@}}.
343 Добавлена @option{freq.maxsize} опция конфигурационного файл,
344 запрещающая ответ на файловый запрос больше заданного размера.
347 Возможность оповещения об успешно выполненных командах (exec) через
348 @option{notify.exec} опцию конфигурационного файла.
353 @subsection Релиз 5.0.0
357 @strong{Несовместимое} изменение формата конфигурационного файла:
358 YAML заменён на Hjson, из-за его гораздо большей простоты, без
359 заметной потери функционала и удобства.
362 @strong{Несовместимое} изменение формата простых пакетов. Работа со
363 старыми версиями не поддерживается. @code{zlib} сжатие заменено на
364 @code{Zstandard}, так как оно значительно быстрее и эффективнее, не
365 смотря на то, что версия библиотеки ещё не проверена временем.
368 Возможность соединяться с удалёнными нодами не только по TCP, но и через
369 pipe вызов сторонней команды.
372 @command{nncp-cfgnew} генерирует конфигурационный файл с множеством
373 комментариев. Можно использовать @option{-nocomments} опцию для старого
377 Дубликаты имён файлов имеют суффикс @file{.CTR}, вместо @file{CTR},
378 чтобы избежать возможных коллизий с @file{.nncp.chunkCTR}.
381 Возможность переопределить umask процесса через опцию конфигурационного
385 По умолчанию файлы и директории создаются с 666/777 правами доступа,
386 позволяя управлять ими @command{umask}-ом.
389 Обновлены зависимости.
392 Полное использование go модулей для управления зависимостями
393 (используется @code{go.cypherpunks.ru/nncp/v5} namespace).
396 Отмена автоматического использования более новых версий GNU GPL
397 (лицензия проекта GNU GPLv3-только).
402 @subsection Релиз 4.1
404 @item Восстановлена работоспособность на GNU/Linux системах и Go версии 1.10.
408 @subsection Релиз 4.0
412 @strong{Несовместимое} изменение формата зашифрованных и eblob пакетов:
413 используется AEAD режим шифрования с 128 КиБ блоками, так как раньше
414 @command{nncp-toss} не проверял MAC зашифрованного пакета прежде чем
415 отсылать дешифрованные данные внешней команде. Старые версии не
419 Проверка доступного места перед копированием во время работы
420 @command{nncp-xfer}, @command{nncp-daemon}, @command{nncp-call(er)}.
423 @command{nncp-call} имеет возможность только показывать список пакетов
424 на удалённой машине, без их передачи.
427 @command{nncp-call} имеет возможность передавать только чётко указанные пакеты.
430 Восстановлена работоспособность @option{xxrate} настройки в
431 @option{calls} секции конфигурационного файла.
434 Зависимые библиотеки обновлены.
437 Небольшие исправления ошибок.
440 Начало использования @code{go.mod} подсистемы.
445 @subsection Релиз 3.4
447 @item @command{nncp-daemon} может быть запущен как @command{inetd}-служба.
451 @subsection Релиз 3.3
455 @command{nncp-daemon}, @command{nncp-call}, @command{nncp-caller}
456 проверяют существование @file{.seen} файла и расценивают его как то, что
457 файл уже был скачан. Возможно передача данных была осуществлена
458 сторонним способом и удалённая сторона должна быть оповещена об этом.
461 Если более высокоприоритетный пакет попадает в спул, то
462 @command{nncp-daemon} добавит его в очередь отправки первым, прерывая
463 низкоприоритетные передачи.
466 К средствам связанным с online-соединениями (@command{nncp-daemon},
467 @command{nncp-call}, @command{nncp-caller}) добавлен простой
468 ограничитель скорости.
471 Возможность задания приоритета символьными обозначениями:
472 @verb{|NORMAL|}, @verb{|BULK+10|}, @verb{|PRIORITY-5|}, итд.
475 Изменены значения приоритетов по-умолчанию:
476 для @command{nncp-exec} с 64 на 96,
477 для @command{nncp-freq} с 64 на 160,
478 для @command{nncp-file} с 196 на 224.
483 @subsection Релиз 3.2
486 @strong{Несовместимое} изменение формата @emph{bundle} архивов и
487 работоспособность @command{nncp-bundle} команды с Go 1.10+. Bundle
488 должен быть корректным tar архивом, но Go 1.9 делал его недействительным
489 из-за длинных путей внутри. NNCP нечаянно был зависим от этой баги.
490 Явное добавление @file{NNCP/} директории в архив восстанавливает
491 работоспособность с корректными tar архивами.
495 @subsection Релиз 3.1
498 Возможность отключать пересылку через промежуточные ноды используя
499 @verb{|-via -|} опцию командной строки.
503 @subsection Релиз 3.0
507 @strong{Несовместимое} изменение формата простых пакетов. Работа со
508 старыми версиями не поддерживается.
511 Добавлена возможность удалённого исполнения команд, путём
512 конфигурирования @option{exec} опции конфигурационного файла и
513 использования команды @command{nncp-exec}:
516 Команда @command{nncp-mail} заменена более гибкой и широкой
517 @command{nncp-exec}. Вместо вызова @verb{|nncp-mail NODE RECIPIENT|}
518 нужно использовать @verb{|nncp-exec NODE sendmail RECIPIENT|}.
520 @option{sendmail} опция конфигурационного файла заменена на более гибкую
521 @option{exec}. @verb{|sendmail: [...]|} нужно заменить на @verb{|exec:
526 Возможность переопределить @option{via} опцию конфигурации для целевого
527 узла через @option{-via} опцию командной строки для следующих команд:
528 @command{nncp-file}, @command{nncp-freq}, @command{nncp-exec}.
531 Chunked файлы, меньшего размера чем указанный chunk, отправляются просто
535 Exec команды вызываются с дополнительными переменными окружения
536 @env{NNCP_NICE} и @env{NNCP_SELF}.
539 Отправляемые файлы в ответ на запрос имеют приоритет указанный в запросе.
540 Указать их желаемый приоритет во время вызова @command{nncp-freq} можно
541 аргументом @option{-replynice}.
544 Команде @command{nncp-toss} можно сказать не обрабатывать определённые
545 типы пакетов, за счёт опций @option{-nofile}, @option{-nofreq},
546 @option{-noexec}, @option{-notrns}.
549 По-умолчанию @command{nncp-file} команда для
550 @option{-minsize}/@option{-chunked} опций использует
551 @option{FreqMinSize}/@option{FreqChunked} из конфигурационного файла.
552 Это можно отключить указав нулевое значение.
557 @subsection Релиз 2.0
561 @strong{Несовместимое} изменение формата зашифрованных и eblob пакетов.
562 Работа со старыми версиями не поддерживается.
565 Алгоритм шифрования Twofish заменён на ChaCha20. Он намного быстрее.
566 Одним криптографическим примитивом меньше.
569 HKDF-BLAKE2b-256 KDF алгоритм заменён на BLAKE2Xb XOF. Ещё одним
570 криптографическим примитивом меньше (предполагая, что BLAKE2X
571 практически идентичен BLAKE2).
576 @subsection Релиз 1.0
580 @strong{Несовместимое} изменение формата зашифрованных пакетов. Работа
581 со старыми версиями не поддерживается.
584 @command{nncp-bundle} команда может создавать потоки зашифрованных
585 пакетов или потреблять их. Это полезно когда речь идёт о
586 @code{stdin}/@code{stdout} методах передачи (например запись на CD-ROM
587 без создания промежуточного подготовленного ISO образа или работа с
588 ленточными накопителями).
591 @command{nncp-toss} команда может создавать @file{.seen} файлы,
592 предотвращая приём дублированных пакетов.
595 В команде @command{nncp-call} разрешается иметь только одного
596 обработчика контрольной суммы в фоне. Это полезно когда тысячи маленьких
597 входящих пакетов могут создать много горутин.
600 Возможность переопределить путь до spool директории и файла журнала
601 через аргумент командной строки или переменную окружения.
604 @command{nncp-rm} команда может удалять все исходящие/входящие,
605 @file{.seen}, @file{.part}, @file{.lock} и временные файлы.
610 @subsection Релиз 0.12
612 @item Команда sendmail вызывается с @env{NNCP_SENDER} переменной окружения.
616 @subsection Релиз 0.11
618 @item Вывод команды @command{nncp-stat} отсортирован по имени ноды.
622 @subsection Релиз 0.10
625 @file{DST} аргумент @command{nncp-freq} команды теперь опционален.
626 По-умолчанию будет подставлен последний элемент @file{SRC} пути.
630 @subsection Релиз 0.9
633 Исправлена обработка @option{-rx}/@option{-tx} опций @command{nncp-call}
634 команды. Они игнорировались.
638 @subsection Релиз 0.8
641 Небольшое исправление ошибки в команде @command{nncp-file}, где опция
642 @option{-minsize} для передачи без разбиения на части была в байтах, а
647 @subsection Релиз 0.7
651 Возможность предоставлять данные для @command{nncp-file} через
652 стандартный ввод, используя временный зашифрованный файл для этого.
655 Появилась возможность передачи файлов разбитых на части, с сопутствующей
656 @command{nncp-reass} командой и @option{freqchunked} опцией
657 конфигурационного файла. Полезно для передачи больших файлов через
658 маленькие устройства хранения.
661 @option{freqminsize} опция конфигурационного файла, аналогичная
665 Опция @option{-force} команды @command{nncp-xfer} переименована в
666 @option{-mkdir} для ясности.
669 Опция @option{-minsize} задаётся в KiB, а не байтах, для удобства.
672 Команда @command{nncp-newcfg} переименована в @command{nncp-cfgnew},
673 а @command{nncp-mincfg} в @command{nncp-cfgmin}, для того чтобы они
674 имели общий префикс и были сгруппированы для удобства.
677 Появилась команда @command{nncp-cfgenc}, позволяющая
678 шифровать/дешифровать конфигурационный файл, чтобы безопасно его хранить
679 без использования OpenPGP или других подобных инструментов.
682 Обновлены зависимые криптографические библиотеки.
687 @subsection Релиз 0.6
689 @item Появилась небольшая команда @command{nncp-rm}.
690 @item Обновлены зависимые криптографические библиотеки.
694 @subsection Релиз 0.5
697 Тривиальное небольшое исправление в значениях приоритетов по-умолчанию в
698 @command{nncp-file} и @command{nncp-freq} командах.
702 @subsection Релиз 0.4
706 Небольшое исправление в @command{nncp-call}, @command{nncp-caller},
707 @command{nncp-daemon}: иногда они могли падать с segmentation fault
708 ошибкой (данные не терялись).
711 @command{nncp-newnode} переименована в @command{nncp-newcfg} --
712 это короче и удобнее для использования.
715 Появилась команда @command{nncp-mincfg}: вспомогательная утилита
716 позволяющая создать минималистичный урезанный конфигурационный файл без
717 приватных ключей, что полезно во время использования @command{nncp-xfer}.
722 @subsection Релиз 0.3
724 @item Исправлена совместимость с Go 1.6.
728 @subsection Релиз 0.2
732 @strong{Несовместимое} изменение формата пакета (магическое число тоже
733 изменено): поле размера пакета шифруется и не посылается в открытом виде.
736 @option{-minsize} опция даёт возможность автоматически дополнять
737 исходящие пакеты до указанного минимального размера.
740 @command{nncp-daemon} и @command{nncp-call}/@command{nncp-caller} всегда
741 в фоне проверяют появление исходящих @emph{tx} пакетов пока подключены.
742 Удалённая сторона сразу же оповещается об этом.
745 @option{-onlinedeadline} опция даёт возможность выставления timeout-а на
746 неактивность в online соединении, когда оно должно быть отключено. Она
747 может быть использована для сохранения соединения на долгое время.
750 @option{-maxonlinetime} опция даёт возможность указания максимального
751 возможного времени жизни соединения.
754 Появилась @command{nncp-caller} команда: клиент TCP-демона работающий по
758 @command{nncp-pkt} команда может разжимать данные.