5 @subsection Релиз 5.5.1
9 Уважать @env{BINDIR}, @env{INFODIR} и @env{DOCDIR} переменные окружения
10 в @file{config} во время установки.
15 @subsection Релиз 5.5.0
19 Исправления ошибок в @command{nncp-call(er)}/@command{nncp-daemon},
20 @command{nncp-bundle}, @command{nncp-stat} командах.
23 У команды @command{nncp-rm} появились @option{-dryrun} и @option{-older} опции.
26 У команды @command{nncp-exec} появились @option{-use-tmp} и
27 @option{-nocompress} опции. Несжатые пакеты не совместимы с предыдущими
31 У команд @command{nncp-call}, @command{nncp-caller} и @command{nncp-daemon}
32 появились @option{-autotoss*} опции для запуска tosser после завершения звонка.
35 Обновлены зависимые библиотеки. Минимальная требуемая версия Go 1.12.
40 @subsection Релиз 5.4.1
44 Исправлена ошибка с учётом @code{SENDMAIL} переменной при сборке.
49 @subsection Релиз 5.4.0
53 Обновлены зависимые библиотеки.
56 Система сборки переведена с Makefile-ов на @url{http://cr.yp.to/redo.html, redo}.
57 Это не должно повлиять на мейнтейнеров пакетов, так как минимальная
58 реализация @command{redo} включена в tarball.
63 @subsection Релиз 5.3.3
67 Больше различных проверок в коде на ошибки.
70 Обновлены зависимые библиотеки.
75 @subsection Релиз 5.3.2
79 Исправлена некорректная логика @option{onlinedeadline} timeout-а, при
80 котором соединение могло не учитывать факты прихода пакетов и обрывать
86 @subsection Релиз 5.3.1
90 Исправлена работоспособность @option{onlinedeadline} с адресами вызова
91 использующими внешние команды (@verb{#"|somecmd"#}).
94 @command{nncp-stat} имеет опцию @option{-pkt} показывающую информацию по
95 каждому пакету в spool.
100 @subsection Релиз 5.3.0
104 Сообщения прогресса содержат префикс, поясняющий выполняемое действие.
107 Исправлено не происходящее дополнение (padding) handshake сообщений.
110 Завершать все порождаемые в SP протоколе горутины, меньше утечек памяти.
113 SP протокол порождает меньше вызовов записей (соответственно, и TCP
117 Проверять @option{onlinedeadline} и @option{maxonlinetime} ежесекундно,
118 независимо от чтения из сокета (раз в 10 секунд в худшем случае).
121 Раз в минуту, если нет более никакого другого трафика, посылаются PING
122 пакеты в SP-соединении. Это позволит быстрее понимать что соединение
123 более не работоспособно.
126 @command{nncp-toss} использует lock-file для предотвращения
127 одновременной обработки зашифрованных пакетов.
132 @subsection Релиз 5.2.1
136 Исправлена обработка ошибки SP протокола, иногда вызывающая панику программы.
141 @subsection Релиз 5.2.0
145 Большинство команд по умолчанию показывают однострочный прогресс
146 выполнения операции. Появились @option{-progress}, @option{-noprogress}
147 опции командной строки, @option{noprogress} опция конфигурационного
151 Исправлен некорректный код возврата @command{nncp-check} команды,
152 который возвращал ошибку когда всё хорошо.
155 Проверка свободного места для пакетов, во время выполнения
156 @command{nncp-bundle -rx}.
161 @subsection Релиз 5.1.2
165 Исправлена @strong{критичная} уязвимость: аутентификация online нод
166 могла приводить к некорректной идентификации удалённой стороны, позволяя
167 скачивать чужие зашифрованные пакеты.
170 Исправлена ошибка: в новосозданных конфигурационных файлах, приватный
171 публичный ключ Noise были поменяны местами, что приводило к
172 невозможности online аутентификации нод.
175 Явная синхронизация (fsync) директорий для гарантированного
176 переименования файлов.
181 @subsection Релиз 5.1.1
185 Исправлена работоспособность @command{nncp-file} с @option{-chunked 0} опцией.
190 @subsection Релиз 5.1.0
194 @command{nncp-file} может отправлять директории, автоматически на лету
198 Во время создания исходящих сообщений проверяется наличие свободного
199 места на файловой системе.
202 @option{freq}, @option{freqminsize}, @option{freqchunked} опции
203 конфигурационного файла заменены на структуру
204 @option{freq: @{path: ..., minsize: ..., chunked: ...@}}.
207 Добавлена @option{freq.maxsize} опция конфигурационного файл,
208 запрещающая ответ на файловый запрос больше заданного размера.
211 Возможность оповещения об успешно выполненных командах (exec) через
212 @option{notify.exec} опцию конфигурационного файла.
217 @subsection Релиз 5.0.0
221 @strong{Несовместимое} изменение формата конфигурационного файла:
222 YAML заменён на Hjson, из-за его гораздо большей простоты, без
223 заметной потери функционала и удобства.
226 @strong{Несовместимое} изменение формата простых пакетов. Работа со
227 старыми версиями не поддерживается. @code{zlib} сжатие заменено на
228 @code{Zstandard}, так как оно значительно быстрее и эффективнее, не
229 смотря на то, что версия библиотеки ещё не проверена временем.
232 Возможность соединяться с удалёнными нодами не только по TCP, но и через
233 pipe вызов сторонней команды.
236 @command{nncp-cfgnew} генерирует конфигурационный файл с множеством
237 комментариев. Можно использовать @option{-nocomments} опцию для старого
241 Дубликаты имён файлов имеют суффикс @file{.CTR}, вместо @file{CTR},
242 чтобы избежать возможных коллизий с @file{.nncp.chunkCTR}.
245 Возможность переопределить umask процесса через опцию конфигурационного
249 По умолчанию файлы и директории создаются с 666/777 правами доступа,
250 позволяя управлять ими @command{umask}-ом.
253 Обновлены зависимости.
256 Полное использование go модулей для управления зависимостями
257 (используется @code{go.cypherpunks.ru/nncp/v5} namespace).
260 Отмена автоматического использования более новых версий GNU GPL
261 (лицензия проекта GNU GPLv3-только).
266 @subsection Релиз 4.1
268 @item Восстановлена работоспособность на GNU/Linux системах и Go версии 1.10.
272 @subsection Релиз 4.0
276 @strong{Несовместимое} изменение формата зашифрованных и eblob пакетов:
277 используется AEAD режим шифрования с 128 КиБ блоками, так как раньше
278 @command{nncp-toss} не проверял MAC зашифрованного пакета прежде чем
279 отсылать дешифрованные данные внешней команде. Старые версии не
283 Проверка доступного места перед копированием во время работы
284 @command{nncp-xfer}, @command{nncp-daemon}, @command{nncp-call(er)}.
287 @command{nncp-call} имеет возможность только показывать список пакетов
288 на удалённой машине, без их передачи.
291 @command{nncp-call} имеет возможность передавать только чётко указанные пакеты.
294 Восстановлена работоспособность @option{xxrate} настройки в
295 @option{calls} секции конфигурационного файла.
298 Зависимые библиотеки обновлены.
301 Небольшие исправления ошибок.
304 Начало использования @code{go.mod} подсистемы.
309 @subsection Релиз 3.4
311 @item @command{nncp-daemon} может быть запущен как @command{inetd}-служба.
315 @subsection Релиз 3.3
319 @command{nncp-daemon}, @command{nncp-call}, @command{nncp-caller}
320 проверяют существование @file{.seen} файла и расценивают его как то, что
321 файл уже был скачан. Возможно передача данных была осуществлена
322 сторонним способом и удалённая сторона должна быть оповещена об этом.
325 Если более высокоприоритетный пакет попадает в спул, то
326 @command{nncp-daemon} добавит его в очередь отправки первым, прерывая
327 низкоприоритетные передачи.
330 К средствам связанным с online-соединениями (@command{nncp-daemon},
331 @command{nncp-call}, @command{nncp-caller}) добавлен простой
332 ограничитель скорости.
335 Возможность задания приоритета символьными обозначениями:
336 @verb{|NORMAL|}, @verb{|BULK+10|}, @verb{|PRIORITY-5|}, итд.
339 Изменены значения приоритетов по-умолчанию:
340 для @command{nncp-exec} с 64 на 96,
341 для @command{nncp-freq} с 64 на 160,
342 для @command{nncp-file} с 196 на 224.
347 @subsection Релиз 3.2
350 @strong{Несовместимое} изменение формата @emph{bundle} архивов и
351 работоспособность @command{nncp-bundle} команды с Go 1.10+. Bundle
352 должен быть корректным tar архивом, но Go 1.9 делал его недействительным
353 из-за длинных путей внутри. NNCP нечаянно был зависим от этой баги.
354 Явное добавление @file{NNCP/} директории в архив восстанавливает
355 работоспособность с корректными tar архивами.
359 @subsection Релиз 3.1
362 Возможность отключать пересылку через промежуточные ноды используя
363 @verb{|-via -|} опцию командной строки.
367 @subsection Релиз 3.0
371 @strong{Несовместимое} изменение формата простых пакетов. Работа со
372 старыми версиями не поддерживается.
375 Добавлена возможность удалённого исполнения команд, путём
376 конфигурирования @option{exec} опции конфигурационного файла и
377 использования команды @command{nncp-exec}:
380 Команда @command{nncp-mail} заменена более гибкой и широкой
381 @command{nncp-exec}. Вместо вызова @verb{|nncp-mail NODE RECIPIENT|}
382 нужно использовать @verb{|nncp-exec NODE sendmail RECIPIENT|}.
384 @option{sendmail} опция конфигурационного файла заменена на более гибкую
385 @option{exec}. @verb{|sendmail: [...]|} нужно заменить на @verb{|exec:
390 Возможность переопределить @option{via} опцию конфигурации для целевого
391 узла через @option{-via} опцию командной строки для следующих команд:
392 @command{nncp-file}, @command{nncp-freq}, @command{nncp-exec}.
395 Chunked файлы, меньшего размера чем указанный chunk, отправляются просто
399 Exec команды вызываются с дополнительными переменными окружения
400 @env{NNCP_NICE} и @env{NNCP_SELF}.
403 Отправляемые файлы в ответ на запрос имеют приоритет указанный в запросе.
404 Указать их желаемый приоритет во время вызова @command{nncp-freq} можно
405 аргументом @option{-replynice}.
408 Команде @command{nncp-toss} можно сказать не обрабатывать определённые
409 типы пакетов, за счёт опций @option{-nofile}, @option{-nofreq},
410 @option{-noexec}, @option{-notrns}.
413 По-умолчанию @command{nncp-file} команда для
414 @option{-minsize}/@option{-chunked} опций использует
415 @option{FreqMinSize}/@option{FreqChunked} из конфигурационного файла.
416 Это можно отключить указав нулевое значение.
421 @subsection Релиз 2.0
425 @strong{Несовместимое} изменение формата зашифрованных и eblob пакетов.
426 Работа со старыми версиями не поддерживается.
429 Алгоритм шифрования Twofish заменён на ChaCha20. Он намного быстрее.
430 Одним криптографическим примитивом меньше.
433 HKDF-BLAKE2b-256 KDF алгоритм заменён на BLAKE2Xb XOF. Ещё одним
434 криптографическим примитивом меньше (предполагая, что BLAKE2X
435 практически идентичен BLAKE2).
440 @subsection Релиз 1.0
444 @strong{Несовместимое} изменение формата зашифрованных пакетов. Работа
445 со старыми версиями не поддерживается.
448 @command{nncp-bundle} команда может создавать потоки зашифрованных
449 пакетов или потреблять их. Это полезно когда речь идёт о
450 @code{stdin}/@code{stdout} методах передачи (например запись на CD-ROM
451 без создания промежуточного подготовленного ISO образа или работа с
452 ленточными накопителями).
455 @command{nncp-toss} команда может создавать @file{.seen} файлы,
456 предотвращая приём дублированных пакетов.
459 В команде @command{nncp-call} разрешается иметь только одного
460 обработчика контрольной суммы в фоне. Это полезно когда тысячи маленьких
461 входящих пакетов могут создать много горутин.
464 Возможность переопределить путь до spool директории и файла журнала
465 через аргумент командной строки или переменную окружения.
468 @command{nncp-rm} команда может удалять все исходящие/входящие,
469 @file{.seen}, @file{.part}, @file{.lock} и временные файлы.
474 @subsection Релиз 0.12
476 @item Команда sendmail вызывается с @env{NNCP_SENDER} переменной окружения.
480 @subsection Релиз 0.11
482 @item Вывод команды @command{nncp-stat} отсортирован по имени ноды.
486 @subsection Релиз 0.10
489 @file{DST} аргумент @command{nncp-freq} команды теперь опционален.
490 По-умолчанию будет подставлен последний элемент @file{SRC} пути.
494 @subsection Релиз 0.9
497 Исправлена обработка @option{-rx}/@option{-tx} опций @command{nncp-call}
498 команды. Они игнорировались.
502 @subsection Релиз 0.8
505 Небольшое исправление ошибки в команде @command{nncp-file}, где опция
506 @option{-minsize} для передачи без разбиения на части была в байтах, а
511 @subsection Релиз 0.7
515 Возможность предоставлять данные для @command{nncp-file} через
516 стандартный ввод, используя временный зашифрованный файл для этого.
519 Появилась возможность передачи файлов разбитых на части, с сопутствующей
520 @command{nncp-reass} командой и @option{freqchunked} опцией
521 конфигурационного файла. Полезно для передачи больших файлов через
522 маленькие устройства хранения.
525 @option{freqminsize} опция конфигурационного файла, аналогичная
529 Опция @option{-force} команды @command{nncp-xfer} переименована в
530 @option{-mkdir} для ясности.
533 Опция @option{-minsize} задаётся в KiB, а не байтах, для удобства.
536 Команда @command{nncp-newcfg} переименована в @command{nncp-cfgnew},
537 а @command{nncp-mincfg} в @command{nncp-cfgmin}, для того чтобы они
538 имели общий префикс и были сгруппированы для удобства.
541 Появилась команда @command{nncp-cfgenc}, позволяющая
542 шифровать/дешифровать конфигурационный файл, чтобы безопасно его хранить
543 без использования OpenPGP или других подобных инструментов.
546 Обновлены зависимые криптографические библиотеки.
551 @subsection Релиз 0.6
553 @item Появилась небольшая команда @command{nncp-rm}.
554 @item Обновлены зависимые криптографические библиотеки.
558 @subsection Релиз 0.5
561 Тривиальное небольшое исправление в значениях приоритетов по-умолчанию в
562 @command{nncp-file} и @command{nncp-freq} командах.
566 @subsection Релиз 0.4
570 Небольшое исправление в @command{nncp-call}, @command{nncp-caller},
571 @command{nncp-daemon}: иногда они могли падать с segmentation fault
572 ошибкой (данные не терялись).
575 @command{nncp-newnode} переименована в @command{nncp-newcfg} --
576 это короче и удобнее для использования.
579 Появилась команда @command{nncp-mincfg}: вспомогательная утилита
580 позволяющая создать минималистичный урезанный конфигурационный файл без
581 приватных ключей, что полезно во время использования @command{nncp-xfer}.
586 @subsection Релиз 0.3
588 @item Исправлена совместимость с Go 1.6.
592 @subsection Релиз 0.2
596 @strong{Несовместимое} изменение формата пакета (магическое число тоже
597 изменено): поле размера пакета шифруется и не посылается в открытом виде.
600 @option{-minsize} опция даёт возможность автоматически дополнять
601 исходящие пакеты до указанного минимального размера.
604 @command{nncp-daemon} и @command{nncp-call}/@command{nncp-caller} всегда
605 в фоне проверяют появление исходящих @emph{tx} пакетов пока подключены.
606 Удалённая сторона сразу же оповещается об этом.
609 @option{-onlinedeadline} опция даёт возможность выставления timeout-а на
610 неактивность в online соединении, когда оно должно быть отключено. Она
611 может быть использована для сохранения соединения на долгое время.
614 @option{-maxonlinetime} опция даёт возможность указания максимального
615 возможного времени жизни соединения.
618 Появилась @command{nncp-caller} команда: клиент TCP-демона работающий по
622 @command{nncp-pkt} команда может разжимать данные.