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