5 @subsection Релиз 5.3.2
9 Исправлена некорректная логика @option{onlinedeadline} timeout-а, при
10 котором соединение могло не учитывать факты прихода пакетов и обрывать
16 @subsection Релиз 5.3.1
20 Исправлена работоспособность @option{onlinedeadline} с адресами вызова
21 использующими внешние команды (@verb{#"|somecmd"#}).
24 @command{nncp-stat} имеет опцию @option{-pkt} показывающую информацию по
25 каждому пакету в spool.
30 @subsection Релиз 5.3.0
34 Сообщения прогресса содержат префикс, поясняющий выполняемое действие.
37 Исправлено не происходящее дополнение (padding) handshake сообщений.
40 Завершать все порождаемые в SP протоколе горутины, меньше утечек памяти.
43 SP протокол порождает меньше вызовов записей (соответственно, и TCP
47 Проверять @option{onlinedeadline} и @option{maxonlinetime} ежесекундно,
48 независимо от чтения из сокета (раз в 10 секунд в худшем случае).
51 Раз в минуту, если нет более никакого другого трафика, посылаются PING
52 пакеты в SP-соединении. Это позволит быстрее понимать что соединение
53 более не работоспособно.
56 @command{nncp-toss} использует lock-file для предотвращения
57 одновременной обработки зашифрованных пакетов.
62 @subsection Релиз 5.2.1
66 Исправлена обработка ошибки SP протокола, иногда вызывающая панику программы.
71 @subsection Релиз 5.2.0
75 Большинство команд по умолчанию показывают однострочный прогресс
76 выполнения операции. Появились @option{-progress}, @option{-noprogress}
77 опции командной строки, @option{noprogress} опция конфигурационного
81 Исправлен некорректный код возврата @command{nncp-check} команды,
82 который возвращал ошибку когда всё хорошо.
85 Проверка свободного места для пакетов, во время выполнения
86 @command{nncp-bundle -rx}.
91 @subsection Релиз 5.1.2
95 Исправлена @strong{критичная} уязвимость: аутентификация online нод
96 могла приводить к некорректной идентификации удалённой стороны, позволяя
97 скачивать чужие зашифрованные пакеты.
100 Исправлена ошибка: в новосозданных конфигурационных файлах, приватный
101 публичный ключ Noise были поменяны местами, что приводило к
102 невозможности online аутентификации нод.
105 Явная синхронизация (fsync) директорий для гарантированного
106 переименования файлов.
111 @subsection Релиз 5.1.1
115 Исправлена работоспособность @command{nncp-file} с @option{-chunked 0} опцией.
120 @subsection Релиз 5.1.0
124 @command{nncp-file} может отправлять директории, автоматически на лету
128 Во время создания исходящих сообщений проверяется наличие свободного
129 места на файловой системе.
132 @option{freq}, @option{freqminsize}, @option{freqchunked} опции
133 конфигурационного файла заменены на структуру
134 @option{freq: @{path: ..., minsize: ..., chunked: ...@}}.
137 Добавлена @option{freq.maxsize} опция конфигурационного файл,
138 запрещающая ответ на файловый запрос больше заданного размера.
141 Возможность оповещения об успешно выполненных командах (exec) через
142 @option{notify.exec} опцию конфигурационного файла.
147 @subsection Релиз 5.0.0
151 @strong{Несовместимое} изменение формата конфигурационного файла:
152 YAML заменён на Hjson, из-за его гораздо большей простоты, без
153 заметной потери функционала и удобства.
156 @strong{Несовместимое} изменение формата простых пакетов. Работа со
157 старыми версиями не поддерживается. @code{zlib} сжатие заменено на
158 @code{Zstandard}, так как оно значительно быстрее и эффективнее, не
159 смотря на то, что версия библиотеки ещё не проверена временем.
162 Возможность соединяться с удалёнными нодами не только по TCP, но и через
163 pipe вызов сторонней команды.
166 @command{nncp-cfgnew} генерирует конфигурационный файл с множеством
167 комментариев. Можно использовать @option{-nocomments} опцию для старого
171 Дубликаты имён файлов имеют суффикс @file{.CTR}, вместо @file{CTR},
172 чтобы избежать возможных коллизий с @file{.nncp.chunkCTR}.
175 Возможность переопределить umask процесса через опцию конфигурационного
179 По умолчанию файлы и директории создаются с 666/777 правами доступа,
180 позволяя управлять ими @command{umask}-ом.
183 Обновлены зависимости.
186 Полное использование go модулей для управления зависимостями
187 (используется @code{go.cypherpunks.ru/nncp/v5} namespace).
190 Отмена автоматического использования более новых версий GNU GPL
191 (лицензия проекта GNU GPLv3-только).
196 @subsection Релиз 4.1
198 @item Восстановлена работоспособность на GNU/Linux системах и Go версии 1.10.
202 @subsection Релиз 4.0
206 @strong{Несовместимое} изменение формата зашифрованных и eblob пакетов:
207 используется AEAD режим шифрования с 128 КиБ блоками, так как раньше
208 @command{nncp-toss} не проверял MAC зашифрованного пакета прежде чем
209 отсылать дешифрованные данные внешней команде. Старые версии не
213 Проверка доступного места перед копированием во время работы
214 @command{nncp-xfer}, @command{nncp-daemon}, @command{nncp-call(er)}.
217 @command{nncp-call} имеет возможность только показывать список пакетов
218 на удалённой машине, без их передачи.
221 @command{nncp-call} имеет возможность передавать только чётко указанные пакеты.
224 Восстановлена работоспособность @option{xxrate} настройки в
225 @option{calls} секции конфигурационного файла.
228 Зависимые библиотеки обновлены.
231 Небольшие исправления ошибок.
234 Начало использования @code{go.mod} подсистемы.
239 @subsection Релиз 3.4
241 @item @command{nncp-daemon} может быть запущен как @command{inetd}-служба.
245 @subsection Релиз 3.3
249 @command{nncp-daemon}, @command{nncp-call}, @command{nncp-caller}
250 проверяют существование @file{.seen} файла и расценивают его как то, что
251 файл уже был скачан. Возможно передача данных была осуществлена
252 сторонним способом и удалённая сторона должна быть оповещена об этом.
255 Если более высокоприоритетный пакет попадает в спул, то
256 @command{nncp-daemon} добавит его в очередь отправки первым, прерывая
257 низкоприоритетные передачи.
260 К средствам связанным с online-соединениями (@command{nncp-daemon},
261 @command{nncp-call}, @command{nncp-caller}) добавлен простой
262 ограничитель скорости.
265 Возможность задания приоритета символьными обозначениями:
266 @verb{|NORMAL|}, @verb{|BULK+10|}, @verb{|PRIORITY-5|}, итд.
269 Изменены значения приоритетов по-умолчанию:
270 для @command{nncp-exec} с 64 на 96,
271 для @command{nncp-freq} с 64 на 160,
272 для @command{nncp-file} с 196 на 224.
277 @subsection Релиз 3.2
280 @strong{Несовместимое} изменение формата @emph{bundle} архивов и
281 работоспособность @command{nncp-bundle} команды с Go 1.10+. Bundle
282 должен быть корректным tar архивом, но Go 1.9 делал его недействительным
283 из-за длинных путей внутри. NNCP нечаянно был зависим от этой баги.
284 Явное добавление @file{NNCP/} директории в архив восстанавливает
285 работоспособность с корректными tar архивами.
289 @subsection Релиз 3.1
292 Возможность отключать пересылку через промежуточные ноды используя
293 @verb{|-via -|} опцию командной строки.
297 @subsection Релиз 3.0
301 @strong{Несовместимое} изменение формата простых пакетов. Работа со
302 старыми версиями не поддерживается.
305 Добавлена возможность удалённого исполнения команд, путём
306 конфигурирования @option{exec} опции конфигурационного файла и
307 использования команды @command{nncp-exec}:
310 Команда @command{nncp-mail} заменена более гибкой и широкой
311 @command{nncp-exec}. Вместо вызова @verb{|nncp-mail NODE RECIPIENT|}
312 нужно использовать @verb{|nncp-exec NODE sendmail RECIPIENT|}.
314 @option{sendmail} опция конфигурационного файла заменена на более гибкую
315 @option{exec}. @verb{|sendmail: [...]|} нужно заменить на @verb{|exec:
320 Возможность переопределить @option{via} опцию конфигурации для целевого
321 узла через @option{-via} опцию командной строки для следующих команд:
322 @command{nncp-file}, @command{nncp-freq}, @command{nncp-exec}.
325 Chunked файлы, меньшего размера чем указанный chunk, отправляются просто
329 Exec команды вызываются с дополнительными переменными окружения
330 @env{NNCP_NICE} и @env{NNCP_SELF}.
333 Отправляемые файлы в ответ на запрос имеют приоритет указанный в запросе.
334 Указать их желаемый приоритет во время вызова @command{nncp-freq} можно
335 аргументом @option{-replynice}.
338 Команде @command{nncp-toss} можно сказать не обрабатывать определённые
339 типы пакетов, за счёт опций @option{-nofile}, @option{-nofreq},
340 @option{-noexec}, @option{-notrns}.
343 По-умолчанию @command{nncp-file} команда для
344 @option{-minsize}/@option{-chunked} опций использует
345 @option{FreqMinSize}/@option{FreqChunked} из конфигурационного файла.
346 Это можно отключить указав нулевое значение.
351 @subsection Релиз 2.0
355 @strong{Несовместимое} изменение формата зашифрованных и eblob пакетов.
356 Работа со старыми версиями не поддерживается.
359 Алгоритм шифрования Twofish заменён на ChaCha20. Он намного быстрее.
360 Одним криптографическим примитивом меньше.
363 HKDF-BLAKE2b-256 KDF алгоритм заменён на BLAKE2Xb XOF. Ещё одним
364 криптографическим примитивом меньше (предполагая, что BLAKE2X
365 практически идентичен BLAKE2).
370 @subsection Релиз 1.0
374 @strong{Несовместимое} изменение формата зашифрованных пакетов. Работа
375 со старыми версиями не поддерживается.
378 @command{nncp-bundle} команда может создавать потоки зашифрованных
379 пакетов или потреблять их. Это полезно когда речь идёт о stdin/stdout
380 методах передачи (например запись на CD-ROM без создания промежуточного
381 подготовленного ISO образа или работа с ленточными накопителями).
384 @command{nncp-toss} команда может создавать @file{.seen} файлы,
385 предотвращая приём дублированных пакетов.
388 В команде @command{nncp-call} разрешается иметь только одного
389 обработчика контрольной суммы в фоне. Это полезно когда тысячи маленьких
390 входящих пакетов могут создать много горутин.
393 Возможность переопределить путь до spool директории и файла журнала
394 через аргумент командной строки или переменную окружения.
397 @command{nncp-rm} команда может удалять все исходящие/входящие,
398 @file{.seen}, @file{.part}, @file{.lock} и временные файлы.
403 @subsection Релиз 0.12
405 @item Команда sendmail вызывается с @env{NNCP_SENDER} переменной окружения.
409 @subsection Релиз 0.11
411 @item Вывод команды @command{nncp-stat} отсортирован по имени ноды.
415 @subsection Релиз 0.10
418 @file{DST} аргумент @command{nncp-freq} команды теперь опционален.
419 По-умолчанию будет подставлен последний элемент @file{SRC} пути.
423 @subsection Релиз 0.9
426 Исправлена обработка @option{-rx}/@option{-tx} опций @command{nncp-call}
427 команды. Они игнорировались.
431 @subsection Релиз 0.8
434 Небольшое исправление ошибки в команде @command{nncp-file}, где опция
435 @option{-minsize} для передачи без разбиения на части была в байтах, а
440 @subsection Релиз 0.7
444 Возможность предоставлять данные для @command{nncp-file} через
445 стандартный ввод, используя временный зашифрованный файл для этого.
448 Появилась возможность передачи файлов разбитых на части, с сопутствующей
449 @command{nncp-reass} командой и @option{freqchunked} опцией
450 конфигурационного файла. Полезно для передачи больших файлов через
451 маленькие устройства хранения.
454 @option{freqminsize} опция конфигурационного файла, аналогичная
458 Опция @option{-force} команды @command{nncp-xfer} переименована в
459 @option{-mkdir} для ясности.
462 Опция @option{-minsize} задаётся в KiB, а не байтах, для удобства.
465 Команда @command{nncp-newcfg} переименована в @command{nncp-cfgnew},
466 а @command{nncp-mincfg} в @command{nncp-cfgmin}, для того чтобы они
467 имели общий префикс и были сгруппированы для удобства.
470 Появилась команда @command{nncp-cfgenc}, позволяющая
471 шифровать/дешифровать конфигурационный файл, чтобы безопасно его хранить
472 без использования OpenPGP или других подобных инструментов.
475 Обновлены зависимые криптографические библиотеки.
480 @subsection Релиз 0.6
482 @item Появилась небольшая команда @command{nncp-rm}.
483 @item Обновлены зависимые криптографические библиотеки.
487 @subsection Релиз 0.5
490 Тривиальное небольшое исправление в значениях приоритетов по-умолчанию в
491 @command{nncp-file} и @command{nncp-freq} командах.
495 @subsection Релиз 0.4
499 Небольшое исправление в @command{nncp-call}, @command{nncp-caller},
500 @command{nncp-daemon}: иногда они могли падать с segmentation fault
501 ошибкой (данные не терялись).
504 @command{nncp-newnode} переименована в @command{nncp-newcfg} --
505 это короче и удобнее для использования.
508 Появилась команда @command{nncp-mincfg}: вспомогательная утилита
509 позволяющая создать минималистичный урезанный конфигурационный файл без
510 приватных ключей, что полезно во время использования @command{nncp-xfer}.
515 @subsection Релиз 0.3
517 @item Исправлена совместимость с Go 1.6.
521 @subsection Релиз 0.2
525 @strong{Несовместимое} изменение формата пакета (магическое число тоже
526 изменено): поле размера пакета шифруется и не посылается в открытом виде.
529 @option{-minsize} опция даёт возможность автоматически дополнять
530 исходящие пакеты до указанного минимального размера.
533 @command{nncp-daemon} и @command{nncp-call}/@command{nncp-caller} всегда
534 в фоне проверяют появление исходящих @emph{tx} пакетов пока подключены.
535 Удалённая сторона сразу же оповещается об этом.
538 @option{-onlinedeadline} опция даёт возможность выставления timeout-а на
539 неактивность в online соединении, когда оно должно быть отключено. Она
540 может быть использована для сохранения соединения на долгое время.
543 @option{-maxonlinetime} опция даёт возможность указания максимального
544 возможного времени жизни соединения.
547 Появилась @command{nncp-caller} команда: клиент TCP-демона работающий по
551 @command{nncp-pkt} команда может разжимать данные.