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