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