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