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