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