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