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