]> Cypherpunks.ru repositories - nncp.git/blob - doc/news.ru.texi
Streamed NNCPE format
[nncp.git] / doc / news.ru.texi
1 @node Новости
2 @section Новости
3
4 @node Релиз 8.0.0
5 @subsection Релиз 8.0.0
6 @itemize
7
8 @item
9 @strong{Несовместимое} изменение формата зашифрованных пакетов: размеры
10 полезной нагрузки и дополнения посылаются прямо внутри зашифрованного
11 потока. Это даёт возможность потоково создавать шифрованные пакеты, без
12 знания размеров заранее, без создания временного файла или буферизации в
13 памяти.
14
15 @item
16 Производится корректная проверка дополнения зашифрованного пакета. Это
17 не критичная проблема, но прежде ни размер, ни значение дополнения не
18 были аутентифицированы, позволяя циклично откусывать по байту с конца и
19 узнавать размер полезной нагрузки, наблюдая за реакцией по обработке
20 такого зашифрованного пакета.
21
22 @item
23 @command{nncp-exec} больше не имеет @option{-use-tmp} опции, из-за
24 совместимого с потоковой работой формата зашифрованных пакетов.
25
26 @item
27 У @command{nncp-file} и @command{nncp-exec} команд появилась опция
28 @option{-maxsize}, ограничивающая максимальный результирующий размер
29 зашифрованного пакета (возвращая ошибку если он превышен). Может быть
30 полезно, так как размер полезной нагрузки может быть неизвестен заранее.
31
32 @end itemize
33
34 @node Релиз 7.7.0
35 @subsection Релиз 7.7.0
36 @itemize
37
38 @item
39 Экспериментальная поддержка @code{kqueue} и @code{inotify} оповещений об
40 изменениях в spool директориях, для сокращения накладных расходов на их
41 частое чтение.
42
43 @item
44 @file{.seen} и @file{.hdr} файлы находятся в @file{seen/} и @file{hdr/}
45 поддиректориях теперь, дабы ускорить сканирование spool областей.
46 Необходима миграция текущих файлов:
47
48 @example
49 $ find $NNCPSPOOL -type f -name "*.hdr" -exec rm @{@} +
50
51 $ find $NNCPSPOOL -type d -name rx | while read rx ; do
52     cd $rx
53     mkdir -p seen
54     find . -type f -name "*.seen" | while read fn ; do
55         mv $fn seen/$@{fn%.seen@}
56     done
57 done
58
59 $ find $NNCPSPOOL -type d -name area | while read area ; do
60     find $area -type f -name "*.seen" | while read fn ; do
61         mv $fn $@{fn%.seen@}
62     done
63 done
64 @end example
65
66 @end itemize
67
68 @node Релиз 7.6.0
69 @subsection Релиз 7.6.0
70 @itemize
71
72 @item
73 Журналирование может производиться в назначенный открытый файловый
74 дескриптор (@env{$NNCPLOG=FD:5} например).
75 Что дружелюбно к использованию под @command{daemontools}.
76
77 @item
78 Добавлены дополнительные проверки наличия публичных ключей в
79 конфигурационном файле, предотвращающие падения некоторых команд.
80
81 @end itemize
82
83 @node Релиз 7.5.1
84 @subsection Релиз 7.5.1
85 @itemize
86
87 @item
88 NNCP собирается на NetBSD.
89
90 @end itemize
91
92 @node Релиз 7.5.0
93 @subsection Релиз 7.5.0
94 @itemize
95
96 @item
97 @command{nncp-daemon} соблюдает UCSPI-TCP интерфейс, благодаря чему в
98 журнале будет присутствовать адрес удалённой системы (при запуске под
99 совместимой утилитой). Желательно применять @option{-ucspi} опцию вместо
100 @option{-inetd}.
101
102 @item
103 @command{nncp-call} может быть UCSPI-TCP клиентом, используя
104 @option{-ucspi} опцию.
105
106 @item
107 Не выходить если не получается слушать на каком-либо MCD сетевом
108 интерфейсе -- только предупреждать об ошибке.
109
110 @end itemize
111
112 @node Релиз 7.4.0
113 @subsection Релиз 7.4.0
114 @itemize
115
116 @item
117 Исправлена работоспособность MCD при одновременном использовании
118 @command{nncp-daemon} и @command{nncp-caller}.
119
120 @end itemize
121
122 @node Релиз 7.3.2
123 @subsection Релиз 7.3.2
124 @itemize
125
126 @item
127 @command{hjson-cli} утилита теперь собирается в vendor-режиме.
128
129 @end itemize
130
131 @node Релиз 7.3.1
132 @subsection Релиз 7.3.1
133 @itemize
134
135 @item
136 Исправлена проблема с возможно остающимся открытым файловым
137 дескриптором в online командах.
138
139 @item
140 Существенно снижено потребление памяти MTH хэширования.
141
142 @end itemize
143
144 @node Релиз 7.3.0
145 @subsection Релиз 7.3.0
146 @itemize
147
148 @item
149 Поправлены проблемы работоспособности на 32-бит системах с большими файлами.
150
151 @item
152 Возможность использовать конфигурацию в виде директории с набором
153 файлов. Появилась команда @command{nncp-cfgdir}.
154
155 @end itemize
156
157 @node Релиз 7.2.1
158 @subsection Релиз 7.2.1
159 @itemize
160
161 @item
162 Небольшие оптимизации в online командах.
163
164 @end itemize
165
166 @node Релиз 7.2.0
167 @subsection Релиз 7.2.0
168 @itemize
169
170 @item
171 Появилась @command{nncp-trns} команда для ручного создания транзитных пакетов.
172
173 @item
174 Если у целевой ноды транзитного пакета задан @option{via} маршрут, то
175 использовать его, а не игнорировать.
176
177 @item
178 Не отправлять multicast пакет оригинатору сообщения, очевидно точно
179 видящего свой собственный пакет.
180
181 @item
182 Намного меньшее потребление памяти во время MTH хэширования когда
183 смещение равно нулю: когда пакет не является докачиванием, а например
184 проверяется @command{nncp-check} командой.
185
186 @end itemize
187
188 @node Релиз 7.1.1
189 @subsection Релиз 7.1.1
190 @itemize
191
192 @item
193 Исправлено падение при fsync директорий после создания @file{.seen} файлов.
194
195 @end itemize
196
197 @node Релиз 7.1.0
198 @subsection Релиз 7.1.0
199 @itemize
200
201 @item
202 Появилась возможность мультивещательной (multicast) рассылки пакетов.
203 Реализовано всего лишь дополнительным типом простых пакетов и изменением
204 @command{nncp-toss}, @command{nncp-file} и @command{nncp-exec} команд.
205
206 @item
207 Исправлена работоспособность @command{nncp-file} и @command{nncp-exec}
208 команд использующих временный файл (stdin и @option{-use-tmp}).
209
210 @item
211 Исправлен пропадающий плохой код возврата в @command{nncp-exec} команде.
212
213 @item
214 Исправлено некорректное генерирование @file{.hdr} при использовании
215 транзитных пакетов.
216
217 @item
218 У @command{nncp-rm} команды появилась @option{-all} опция, применяемая
219 ко всем нодам сразу.
220
221 @item
222 У @command{nncp-check} команды появилась @option{-cycle} опция, вводящая
223 проверку в бесконечный цикл.
224
225 @item
226 У @command{nncp-rm} команды можно указывать alias-ы имён нод.
227
228 @item
229 @command{nncp-pkt} может парсить @file{.hdr} файлы.
230
231 @end itemize
232
233 @node Релиз 7.0.0
234 @subsection Релиз 7.0.0
235 @itemize
236
237 @item
238 Минимальная требуемая версия Go 1.13.
239
240 @item
241 Хэширование с BLAKE3 на базе деревьев Меркле (Merkle Tree Hashing, MTH)
242 используется вместо BLAKE2b. Из-за этого, обратно @strong{несовместимое}
243 изменение формата шифрованных файлов (всего что находится в spool
244 области) и формата @file{.meta} файла при chunked передаче.
245
246 Текущая реализация далека от оптимальной: в ней нет распараллеливания
247 вычислений и имеет повышенное потребление памяти: около 512 KiB на
248 каждый 1 GiB данных файла. Будущая оптимизация производительности и
249 потребления памяти не должна привести к изменению формата пакетов. Но
250 это всё равно в несколько раз быстрее BLAKE2b.
251
252 @item
253 Из-за использования MTH, докачиваемые в online режиме файлы потребуют
254 чтения с диска только предшествующей части, а не полностью всего файла,
255 как было прежде.
256
257 @item
258 Добавлена @command{nncp-hash} утилита для вычисления MTH хэша файла.
259
260 @item
261 В шифрованных пакетах BLAKE2 KDF и XOF функции заменены на BLAKE3. Ещё
262 уменьшая количество примитивов. А также заголовок шифрованного файла
263 теперь является ассоциированными данными при шифровании.
264
265 @item
266 MultiCast Discovery использует
267 @verb{|ff02::4e4e:4350|} адрес вместо @verb{|ff02::1|}.
268
269 @item
270 @command{nncp-cfgenc} ошибочно трижды спрашивал парольную фразу при шифровании.
271
272 @item
273 @command{nncp-stat} выводит сводку о частично скачанных пакетах.
274
275 @item
276 Обновлены зависимые библиотеки.
277
278 @end itemize
279
280 @node Релиз 6.6.0
281 @subsection Релиз 6.6.0
282 @itemize
283
284 @item
285 @command{nncp-daemon}, @command{nncp-call} и @command{nncp-caller}
286 ожидают завершения всех процессов фоновой проверки контрольных сумм,
287 после того как соединение закрыто.
288
289 @item
290 Добавлена возможность определения адреса через multicast оповещение в
291 локальной сети, так называемый MCD (MultiCast Discovery).
292
293 @end itemize
294
295 @node Релиз 6.5.0
296 @subsection Релиз 6.5.0
297 @itemize
298
299 @item
300 Исправлено падение в @command{nncp-daemon} когда SP рукопожатие не было успешно.
301
302 @item
303 Исправлено возможное игнорирование плохого кода возврата автоматического tosser.
304
305 @item
306 Исправлена гонка при закрытии файловых дескрипторов во время завершения
307 работы online протокола, которая могла привести к ошибке записи
308 принятого фрагмента пакета.
309
310 @item
311 Убирать показ прогресса передачи пакетов когда вызов уже завершён в
312 @command{nncp-daemon}, @command{nncp-call} и @command{nncp-caller}.
313
314 @end itemize
315
316 @node Релиз 6.4.0
317 @subsection Релиз 6.4.0
318 @itemize
319
320 @item
321 Исправлена возможная гонка в online протоколе, приводящая к падению
322 программы.
323
324 @end itemize
325
326 @node Релиз 6.3.0
327 @subsection Релиз 6.3.0
328 @itemize
329
330 @item
331 Исправлено возможное падение программы во время показа прогресса online
332 протокола.
333
334 @end itemize
335
336 @node Релиз 6.2.1
337 @subsection Релиз 6.2.1
338 @itemize
339
340 @item
341 В трёх местах сообщений журналов по ошибке остались лишние @code{%s}.
342
343 @end itemize
344
345 @node Релиз 6.2.0
346 @subsection Релиз 6.2.0
347 @itemize
348
349 @item
350 Возвращена работоспособность @option{-autotoss*} опций @command{nncp-caller}.
351
352 @item
353 Очередной рефакторинг и упрощение системы журналирования.
354 Не должно быть видимых изменений для конечного пользователя.
355
356 @end itemize
357
358 @node Релиз 6.1.0
359 @subsection Релиз 6.1.0
360 @itemize
361
362 @item
363 Оптимизация: большинство команд теперь не держат открытыми файловые
364 дескрипторы. Прежде вы легко могли выйти за пределы максимально
365 допустимого количества открытых файлов, если у вас было много пакетов в
366 spool директории.
367
368 @item
369 Оптимизация: не закрывать файловый дескриптор файла который мы качаем.
370 Прежде каждый его кусочек приводил к дорогим open/close вызовам.
371
372 @item
373 Скачиваемые в режиме online файлы теперь сохраняются с @file{.nock}
374 суффиксом (non-checksummed), ожидая пока либо @command{nncp-check}, либо
375 online демоны не выполнят проверку целостности.
376
377 @item
378 Оптимизация: для файлов, скачивание которых не было продолжено, сразу же
379 вычисляет контрольная сумма, пропуская промежуточный @file{.nock} шаг.
380
381 @item
382 Возможность хранения заголовков зашифрованных пакетов в @file{.hdr}
383 файлах, рядом с самими пакетами. Это может существенно повысить скорость
384 получения списка пакетов на файловых системах с большим размером блока.
385
386 @end itemize
387
388 @node Релиз 6.0.0
389 @subsection Релиз 6.0.0
390 @itemize
391
392 @item
393 Журнал использует человеко-читаемый и легко обрабатываемый машиной
394 @url{https://www.gnu.org/software/recutils/, recfile} формат для своих
395 записей, вместо структурированных строчек RFC 3339. Старый формат
396 журналов не поддерживается @command{nncp-log}.
397
398 @item
399 Работоспособность @option{-autotoss*} опции с @option{-inetd} режимом
400 @command{nncp-daemon}.
401
402 @item
403 @option{when-tx-exists} опция вызова в конфигурационном файле позволяет
404 делать вызов только если имеются исходящие сообщения. Совмещённая с cron
405 выражением содержащим секунды, это можно использовать как возможность
406 вызова только при появлении исходящих пакетов.
407
408 @item
409 @command{nncp-cronexpr} команда позволяет проверить корректность и
410 ожидаемый результат от указанного cron выражения.
411
412 @end itemize
413
414 @node Релиз 5.6.0
415 @subsection Релиз 5.6.0
416 @itemize
417
418 @item
419 @option{-autotoss*} опции запускают tosser не после завершения вызова, а
420 во время него ежесекундно.
421
422 @item
423 В @option{calls} секции конфигурации появились опции
424 @option{autotoss}, @option{autotoss-doseen},
425 @option{autotoss-nofile}, @option{autotoss-nofreq},
426 @option{autotoss-noexec}, @option{autotoss-notrns}.
427 Вы можете настраивать опции автоматического tosser для каждого вызова.
428
429 @item
430 Использовать vendoring вместо переопределения @env{$GOPATH} во время
431 установки tarball, так как текущая минимальная версия Go это 1.12,
432 поддерживающая модули.
433
434 @end itemize
435
436 @node Релиз 5.5.1
437 @subsection Релиз 5.5.1
438 @itemize
439
440 @item
441 Уважать @env{$BINDIR}, @env{$INFODIR} и @env{$DOCDIR} переменные окружения
442 в @file{config} во время установки.
443
444 @end itemize
445
446 @node Релиз 5.5.0
447 @subsection Релиз 5.5.0
448 @itemize
449
450 @item
451 Исправления ошибок в @command{nncp-call(er)}/@command{nncp-daemon},
452 @command{nncp-bundle}, @command{nncp-stat} командах.
453
454 @item
455 У команды @command{nncp-rm} появились @option{-dryrun} и @option{-older} опции.
456
457 @item
458 У команды @command{nncp-exec} появились @option{-use-tmp} и
459 @option{-nocompress} опции. Несжатые пакеты не совместимы с предыдущими
460 версиями NNCP.
461
462 @item
463 У команд @command{nncp-call}, @command{nncp-caller} и @command{nncp-daemon}
464 появились @option{-autotoss*} опции для запуска tosser после завершения звонка.
465
466 @item
467 Обновлены зависимые библиотеки. Минимальная требуемая версия Go 1.12.
468
469 @end itemize
470
471 @node Релиз 5.4.1
472 @subsection Релиз 5.4.1
473 @itemize
474
475 @item
476 Исправлена ошибка с учётом @code{SENDMAIL} переменной при сборке.
477
478 @end itemize
479
480 @node Релиз 5.4.0
481 @subsection Релиз 5.4.0
482 @itemize
483
484 @item
485 Обновлены зависимые библиотеки.
486
487 @item
488 Система сборки переведена с Makefile-ов на @url{http://cr.yp.to/redo.html, redo}.
489 Это не должно повлиять на мейнтейнеров пакетов, так как минимальная
490 реализация @command{redo} включена в tarball.
491
492 @end itemize
493
494 @node Релиз 5.3.3
495 @subsection Релиз 5.3.3
496 @itemize
497
498 @item
499 Больше различных проверок в коде на ошибки.
500
501 @item
502 Обновлены зависимые библиотеки.
503
504 @end itemize
505
506 @node Релиз 5.3.2
507 @subsection Релиз 5.3.2
508 @itemize
509
510 @item
511 Исправлена некорректная логика @option{onlinedeadline} timeout-а, при
512 котором соединение могло не учитывать факты прихода пакетов и обрывать
513 связь.
514
515 @end itemize
516
517 @node Релиз 5.3.1
518 @subsection Релиз 5.3.1
519 @itemize
520
521 @item
522 Исправлена работоспособность @option{onlinedeadline} с адресами вызова
523 использующими внешние команды (@verb{#"|somecmd"#}).
524
525 @item
526 @command{nncp-stat} имеет опцию @option{-pkt} показывающую информацию по
527 каждому пакету в spool.
528
529 @end itemize
530
531 @node Релиз 5.3.0
532 @subsection Релиз 5.3.0
533 @itemize
534
535 @item
536 Сообщения прогресса содержат префикс, поясняющий выполняемое действие.
537
538 @item
539 Исправлено не происходящее дополнение (padding) handshake сообщений.
540
541 @item
542 Завершать все порождаемые в SP протоколе горутины, меньше утечек памяти.
543
544 @item
545 SP протокол порождает меньше вызовов записей (соответственно, и TCP
546 пакетов) в сокет.
547
548 @item
549 Проверять @option{onlinedeadline} и @option{maxonlinetime} ежесекундно,
550 независимо от чтения из сокета (раз в 10 секунд в худшем случае).
551
552 @item
553 Раз в минуту, если нет более никакого другого трафика, посылаются PING
554 пакеты в SP-соединении. Это позволит быстрее понимать что соединение
555 более не работоспособно.
556
557 @item
558 @command{nncp-toss} использует lock-file для предотвращения
559 одновременной обработки зашифрованных пакетов.
560
561 @end itemize
562
563 @node Релиз 5.2.1
564 @subsection Релиз 5.2.1
565 @itemize
566
567 @item
568 Исправлена обработка ошибки SP протокола, иногда вызывающая панику программы.
569
570 @end itemize
571
572 @node Релиз 5.2.0
573 @subsection Релиз 5.2.0
574 @itemize
575
576 @item
577 Большинство команд по умолчанию показывают однострочный прогресс
578 выполнения операции. Появились @option{-progress}, @option{-noprogress}
579 опции командной строки, @option{noprogress} опция конфигурационного
580 файла.
581
582 @item
583 Исправлен некорректный код возврата @command{nncp-check} команды,
584 который возвращал ошибку когда всё хорошо.
585
586 @item
587 Проверка свободного места для пакетов, во время выполнения
588 @command{nncp-bundle -rx}.
589
590 @end itemize
591
592 @node Релиз 5.1.2
593 @subsection Релиз 5.1.2
594 @itemize
595
596 @item
597 Исправлена @strong{критичная} уязвимость: аутентификация online нод
598 могла приводить к некорректной идентификации удалённой стороны, позволяя
599 скачивать чужие зашифрованные пакеты.
600
601 @item
602 Исправлена ошибка: в новосозданных конфигурационных файлах, приватный
603 публичный ключ Noise были поменяны местами, что приводило к
604 невозможности online аутентификации нод.
605
606 @item
607 Явная синхронизация (fsync) директорий для гарантированного
608 переименования файлов.
609
610 @end itemize
611
612 @node Релиз 5.1.1
613 @subsection Релиз 5.1.1
614 @itemize
615
616 @item
617 Исправлена работоспособность @command{nncp-file} с @option{-chunked 0} опцией.
618
619 @end itemize
620
621 @node Релиз 5.1.0
622 @subsection Релиз 5.1.0
623 @itemize
624
625 @item
626 @command{nncp-file} может отправлять директории, автоматически на лету
627 создавая pax архив.
628
629 @item
630 Во время создания исходящих сообщений проверяется наличие свободного
631 места на файловой системе.
632
633 @item
634 @option{freq}, @option{freqminsize}, @option{freqchunked} опции
635 конфигурационного файла заменены на структуру
636 @option{freq: @{path: @dots{}, minsize: @dots{}, chunked: @dots{}@}}.
637
638 @item
639 Добавлена @option{freq.maxsize} опция конфигурационного файл,
640 запрещающая ответ на файловый запрос больше заданного размера.
641
642 @item
643 Возможность оповещения об успешно выполненных командах (exec) через
644 @option{notify.exec} опцию конфигурационного файла.
645
646 @end itemize
647
648 @node Релиз 5.0.0
649 @subsection Релиз 5.0.0
650 @itemize
651
652 @item
653 @strong{Несовместимое} изменение формата конфигурационного файла:
654 YAML заменён на Hjson, из-за его гораздо большей простоты, без
655 заметной потери функционала и удобства.
656
657 @item
658 @strong{Несовместимое} изменение формата простых пакетов. Работа со
659 старыми версиями не поддерживается. @code{zlib} сжатие заменено на
660 @code{Zstandard}, так как оно значительно быстрее и эффективнее, не
661 смотря на то, что версия библиотеки ещё не проверена временем.
662
663 @item
664 Возможность соединяться с удалёнными нодами не только по TCP, но и через
665 pipe вызов сторонней команды.
666
667 @item
668 @command{nncp-cfgnew} генерирует конфигурационный файл с множеством
669 комментариев. Можно использовать @option{-nocomments} опцию для старого
670 поведения.
671
672 @item
673 Дубликаты имён файлов имеют суффикс @file{.CTR}, вместо @file{CTR},
674 чтобы избежать возможных коллизий с @file{.nncp.chunkCTR}.
675
676 @item
677 Возможность переопределить umask процесса через опцию конфигурационного
678 файла.
679
680 @item
681 По умолчанию файлы и директории создаются с 666/777 правами доступа,
682 позволяя управлять ими @command{umask}-ом.
683
684 @item
685 Обновлены зависимости.
686
687 @item
688 Полное использование go модулей для управления зависимостями
689 (используется @code{go.cypherpunks.ru/nncp/v5} namespace).
690
691 @item
692 Отмена автоматического использования более новых версий GNU GPL
693 (лицензия проекта GNU GPLv3-только).
694
695 @end itemize
696
697 @node Релиз 4.1
698 @subsection Релиз 4.1
699 @itemize
700 @item Восстановлена работоспособность на GNU/Linux системах и Go версии 1.10.
701 @end itemize
702
703 @node Релиз 4.0
704 @subsection Релиз 4.0
705 @itemize
706
707 @item
708 @strong{Несовместимое} изменение формата зашифрованных и eblob пакетов:
709 используется AEAD режим шифрования с 128 КиБ блоками, так как раньше
710 @command{nncp-toss} не проверял MAC зашифрованного пакета прежде чем
711 отсылать дешифрованные данные внешней команде. Старые версии не
712 поддерживаются.
713
714 @item
715 Проверка доступного места перед копированием во время работы
716 @command{nncp-xfer}, @command{nncp-daemon}, @command{nncp-call(er)}.
717
718 @item
719 @command{nncp-call} имеет возможность только показывать список пакетов
720 на удалённой машине, без их передачи.
721
722 @item
723 @command{nncp-call} имеет возможность передавать только чётко указанные пакеты.
724
725 @item
726 Восстановлена работоспособность @option{xxrate} настройки в
727 @option{calls} секции конфигурационного файла.
728
729 @item
730 Зависимые библиотеки обновлены.
731
732 @item
733 Небольшие исправления ошибок.
734
735 @item
736 Начало использования @code{go.mod} подсистемы.
737
738 @end itemize
739
740 @node Релиз 3.4
741 @subsection Релиз 3.4
742 @itemize
743 @item @command{nncp-daemon} может быть запущен как @command{inetd}-служба.
744 @end itemize
745
746 @node Релиз 3.3
747 @subsection Релиз 3.3
748 @itemize
749
750 @item
751 @command{nncp-daemon}, @command{nncp-call}, @command{nncp-caller}
752 проверяют существование @file{.seen} файла и расценивают его как то, что
753 файл уже был скачан. Возможно передача данных была осуществлена
754 сторонним способом и удалённая сторона должна быть оповещена об этом.
755
756 @item
757 Если более высокоприоритетный пакет попадает в спул, то
758 @command{nncp-daemon} добавит его в очередь отправки первым, прерывая
759 низкоприоритетные передачи.
760
761 @item
762 К средствам связанным с online-соединениями (@command{nncp-daemon},
763 @command{nncp-call}, @command{nncp-caller}) добавлен простой
764 ограничитель скорости.
765
766 @item
767 Возможность задания приоритета символьными обозначениями:
768 @verb{|NORMAL|}, @verb{|BULK+10|}, @verb{|PRIORITY-5|}, итд.
769
770 @item
771 Изменены значения приоритетов по-умолчанию:
772 для @command{nncp-exec} с 64 на 96,
773 для @command{nncp-freq} с 64 на 160,
774 для @command{nncp-file} с 196 на 224.
775
776 @end itemize
777
778 @node Релиз 3.2
779 @subsection Релиз 3.2
780 @itemize
781 @item
782 @strong{Несовместимое} изменение формата @emph{bundle} архивов и
783 работоспособность @command{nncp-bundle} команды с Go 1.10+. Bundle
784 должен быть корректным tar архивом, но Go 1.9 делал его недействительным
785 из-за длинных путей внутри. NNCP нечаянно был зависим от этой баги.
786 Явное добавление @file{NNCP/} директории в архив восстанавливает
787 работоспособность с корректными tar архивами.
788 @end itemize
789
790 @node Релиз 3.1
791 @subsection Релиз 3.1
792 @itemize
793 @item
794 Возможность отключать пересылку через промежуточные ноды используя
795 @verb{|-via -|} опцию командной строки.
796 @end itemize
797
798 @node Релиз 3.0
799 @subsection Релиз 3.0
800 @itemize
801
802 @item
803 @strong{Несовместимое} изменение формата простых пакетов. Работа со
804 старыми версиями не поддерживается.
805
806 @item
807 Добавлена возможность удалённого исполнения команд, путём
808 конфигурирования @option{exec} опции конфигурационного файла и
809 использования команды @command{nncp-exec}:
810     @itemize
811     @item
812     Команда @command{nncp-mail} заменена более гибкой и широкой
813     @command{nncp-exec}. Вместо вызова @verb{|nncp-mail NODE RECIPIENT|}
814     нужно использовать @verb{|nncp-exec NODE sendmail RECIPIENT|}.
815     @item
816     @option{sendmail} опция конфигурационного файла заменена на более гибкую
817     @option{exec}. @verb{|sendmail: [...]|} нужно заменить на @verb{|exec:
818     sendmail: [...]|}.
819     @end itemize
820
821 @item
822 Возможность переопределить @option{via} опцию конфигурации для целевого
823 узла через @option{-via} опцию командной строки для следующих команд:
824 @command{nncp-file}, @command{nncp-freq}, @command{nncp-exec}.
825
826 @item
827 Chunked файлы, меньшего размера чем указанный chunk, отправляются просто
828 в виде одного файла.
829
830 @item
831 Exec команды вызываются с дополнительными переменными окружения
832 @env{$NNCP_NICE} и @env{$NNCP_SELF}.
833
834 @item
835 Отправляемые файлы в ответ на запрос имеют приоритет указанный в запросе.
836 Указать их желаемый приоритет во время вызова @command{nncp-freq} можно
837 аргументом @option{-replynice}.
838
839 @item
840 Команде @command{nncp-toss} можно сказать не обрабатывать определённые
841 типы пакетов, за счёт опций @option{-nofile}, @option{-nofreq},
842 @option{-noexec}, @option{-notrns}.
843
844 @item
845 По-умолчанию @command{nncp-file} команда для
846 @option{-minsize}/@option{-chunked} опций использует
847 @option{FreqMinSize}/@option{FreqChunked} из конфигурационного файла.
848 Это можно отключить указав нулевое значение.
849
850 @end itemize
851
852 @node Релиз 2.0
853 @subsection Релиз 2.0
854 @itemize
855
856 @item
857 @strong{Несовместимое} изменение формата зашифрованных и eblob пакетов.
858 Работа со старыми версиями не поддерживается.
859
860 @item
861 Алгоритм шифрования Twofish заменён на ChaCha20. Он намного быстрее.
862 Одним криптографическим примитивом меньше.
863
864 @item
865 HKDF-BLAKE2b-256 KDF алгоритм заменён на BLAKE2Xb XOF. Ещё одним
866 криптографическим примитивом меньше (предполагая, что BLAKE2X
867 практически идентичен BLAKE2).
868
869 @end itemize
870
871 @node Релиз 1.0
872 @subsection Релиз 1.0
873 @itemize
874
875 @item
876 @strong{Несовместимое} изменение формата зашифрованных пакетов. Работа
877 со старыми версиями не поддерживается.
878
879 @item
880 @command{nncp-bundle} команда может создавать потоки зашифрованных
881 пакетов или потреблять их. Это полезно когда речь идёт о
882 @code{stdin}/@code{stdout} методах передачи (например запись на CD-ROM
883 без создания промежуточного подготовленного ISO образа или работа с
884 ленточными накопителями).
885
886 @item
887 @command{nncp-toss} команда может создавать @file{.seen} файлы,
888 предотвращая приём дублированных пакетов.
889
890 @item
891 В команде @command{nncp-call} разрешается иметь только одного
892 обработчика контрольной суммы в фоне. Это полезно когда тысячи маленьких
893 входящих пакетов могут создать много горутин.
894
895 @item
896 Возможность переопределить путь до spool директории и файла журнала
897 через аргумент командной строки или переменную окружения.
898
899 @item
900 @command{nncp-rm} команда может удалять все исходящие/входящие,
901 @file{.seen}, @file{.part}, @file{.lock} и временные файлы.
902
903 @end itemize
904
905 @node Релиз 0.12
906 @subsection Релиз 0.12
907 @itemize
908 @item Команда sendmail вызывается с @env{$NNCP_SENDER} переменной окружения.
909 @end itemize
910
911 @node Релиз 0.11
912 @subsection Релиз 0.11
913 @itemize
914 @item Вывод команды @command{nncp-stat} отсортирован по имени ноды.
915 @end itemize
916
917 @node Релиз 0.10
918 @subsection Релиз 0.10
919 @itemize
920 @item
921 @file{DST} аргумент @command{nncp-freq} команды теперь опционален.
922 По-умолчанию будет подставлен последний элемент @file{SRC} пути.
923 @end itemize
924
925 @node Релиз 0.9
926 @subsection Релиз 0.9
927 @itemize
928 @item
929 Исправлена обработка @option{-rx}/@option{-tx} опций @command{nncp-call}
930 команды. Они игнорировались.
931 @end itemize
932
933 @node Релиз 0.8
934 @subsection Релиз 0.8
935 @itemize
936 @item
937 Небольшое исправление ошибки в команде @command{nncp-file}, где опция
938 @option{-minsize} для передачи без разбиения на части была в байтах, а
939 не KiB-ах.
940 @end itemize
941
942 @node Релиз 0.7
943 @subsection Релиз 0.7
944 @itemize
945
946 @item
947 Возможность предоставлять данные для @command{nncp-file} через
948 стандартный ввод, используя временный зашифрованный файл для этого.
949
950 @item
951 Появилась возможность передачи файлов разбитых на части, с сопутствующей
952 @command{nncp-reass} командой и @option{freqchunked} опцией
953 конфигурационного файла. Полезно для передачи больших файлов через
954 маленькие устройства хранения.
955
956 @item
957 @option{freqminsize} опция конфигурационного файла, аналогичная
958 @option{-minsize}.
959
960 @item
961 Опция @option{-force} команды @command{nncp-xfer} переименована в
962 @option{-mkdir} для ясности.
963
964 @item
965 Опция @option{-minsize} задаётся в KiB, а не байтах, для удобства.
966
967 @item
968 Команда @command{nncp-newcfg} переименована в @command{nncp-cfgnew},
969 а @command{nncp-mincfg} в @command{nncp-cfgmin}, для того чтобы они
970 имели общий префикс и были сгруппированы для удобства.
971
972 @item
973 Появилась команда @command{nncp-cfgenc}, позволяющая
974 шифровать/дешифровать конфигурационный файл, чтобы безопасно его хранить
975 без использования OpenPGP или других подобных инструментов.
976
977 @item
978 Обновлены зависимые криптографические библиотеки.
979
980 @end itemize
981
982 @node Релиз 0.6
983 @subsection Релиз 0.6
984 @itemize
985 @item Появилась небольшая команда @command{nncp-rm}.
986 @item Обновлены зависимые криптографические библиотеки.
987 @end itemize
988
989 @node Релиз 0.5
990 @subsection Релиз 0.5
991 @itemize
992 @item
993 Тривиальное небольшое исправление в значениях приоритетов по-умолчанию в
994 @command{nncp-file} и @command{nncp-freq} командах.
995 @end itemize
996
997 @node Релиз 0.4
998 @subsection Релиз 0.4
999 @itemize
1000
1001 @item
1002 Небольшое исправление в @command{nncp-call}, @command{nncp-caller},
1003 @command{nncp-daemon}: иногда они могли падать с segmentation fault
1004 ошибкой (данные не терялись).
1005
1006 @item
1007 @command{nncp-newnode} переименована в @command{nncp-newcfg} --
1008 это короче и удобнее для использования.
1009
1010 @item
1011 Появилась команда @command{nncp-mincfg}: вспомогательная утилита
1012 позволяющая создать минималистичный урезанный конфигурационный файл без
1013 приватных ключей, что полезно во время использования @command{nncp-xfer}.
1014
1015 @end itemize
1016
1017 @node Релиз 0.3
1018 @subsection Релиз 0.3
1019 @itemize
1020 @item Исправлена совместимость с Go 1.6.
1021 @end itemize
1022
1023 @node Релиз 0.2
1024 @subsection Релиз 0.2
1025 @itemize
1026
1027 @item
1028 @strong{Несовместимое} изменение формата пакета (магическое число тоже
1029 изменено): поле размера пакета шифруется и не посылается в открытом виде.
1030
1031 @item
1032 @option{-minsize} опция даёт возможность автоматически дополнять
1033 исходящие пакеты до указанного минимального размера.
1034
1035 @item
1036 @command{nncp-daemon} и @command{nncp-call}/@command{nncp-caller} всегда
1037 в фоне проверяют появление исходящих @emph{tx} пакетов пока подключены.
1038 Удалённая сторона сразу же оповещается об этом.
1039
1040 @item
1041 @option{-onlinedeadline} опция даёт возможность выставления timeout-а на
1042 неактивность в online соединении, когда оно должно быть отключено. Она
1043 может быть использована для сохранения соединения на долгое время.
1044
1045 @item
1046 @option{-maxonlinetime} опция даёт возможность указания максимального
1047 возможного времени жизни соединения.
1048
1049 @item
1050 Появилась @command{nncp-caller} команда: клиент TCP-демона работающий по
1051 cron-у.
1052
1053 @item
1054 @command{nncp-pkt} команда может разжимать данные.
1055
1056 @end itemize