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