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