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