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