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