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