]> Cypherpunks.ru repositories - nncp.git/blob - doc/news.ru.texi
Keep downloading file opened
[nncp.git] / doc / news.ru.texi
1 @node Новости
2 @section Новости
3
4 @node Релиз 6.1.0
5 @subsection Релиз 6.1.0
6 @itemize
7
8 @item
9 Оптимизация: большинство команд теперь не держат открытыми файловые
10 дескрипторы. Прежде вы легко могли выйти за пределы максимально
11 допустимого количества открытых файлов, если у вас было много пакетов в
12 spool директории.
13
14 @item
15 Оптимизация: не закрывать файловый дескриптор файла который мы качаем.
16 Прежде каждый его кусочек приводил к дорогим open/close вызовам.
17
18 @end itemize
19
20 @node Релиз 6.0.0
21 @subsection Релиз 6.0.0
22 @itemize
23
24 @item
25 Журнал использует человеко-читаемый и легко обрабатываемый машиной
26 @url{https://www.gnu.org/software/recutils/, recfile} формат для своих
27 записей, вместо структурированных строчек RFC 3339. Старый формат
28 журналов не поддерживается @command{nncp-log}.
29
30 @item
31 Работоспособность @option{-autotoss*} опции с @option{-inetd} режимом
32 @command{nncp-daemon}.
33
34 @item
35 @option{when-tx-exists} опция вызова в конфигурационном файле позволяет
36 делать вызов только если имеются исходящие сообщения. Совмещённая с cron
37 выражением содержащим секунды, это можно использовать как возможность
38 вызова только при появлении исходящих пакетов.
39
40 @item
41 @command{nncp-cronexpr} команда позволяет проверить корректность и
42 ожидаемый результат от указанного cron выражения.
43
44 @end itemize
45
46 @node Релиз 5.6.0
47 @subsection Релиз 5.6.0
48 @itemize
49
50 @item
51 @option{-autotoss*} опции запускают tosser не после завершения вызова, а
52 во время него ежесекундно.
53
54 @item
55 В @option{calls} секции конфигурации появились опции
56 @option{autotoss}, @option{autotoss-doseen},
57 @option{autotoss-nofile}, @option{autotoss-nofreq},
58 @option{autotoss-noexec}, @option{autotoss-notrns}.
59 Вы можете настраивать опции автоматического tosser для каждого вызова.
60
61 @item
62 Использовать vendoring вместо переопределения @env{GOPATH} во время
63 установки tarball, так как текущая минимальная версия Go это 1.12,
64 поддерживающая модули.
65
66 @end itemize
67
68 @node Релиз 5.5.1
69 @subsection Релиз 5.5.1
70 @itemize
71
72 @item
73 Уважать @env{BINDIR}, @env{INFODIR} и @env{DOCDIR} переменные окружения
74 в @file{config} во время установки.
75
76 @end itemize
77
78 @node Релиз 5.5.0
79 @subsection Релиз 5.5.0
80 @itemize
81
82 @item
83 Исправления ошибок в @command{nncp-call(er)}/@command{nncp-daemon},
84 @command{nncp-bundle}, @command{nncp-stat} командах.
85
86 @item
87 У команды @command{nncp-rm} появились @option{-dryrun} и @option{-older} опции.
88
89 @item
90 У команды @command{nncp-exec} появились @option{-use-tmp} и
91 @option{-nocompress} опции. Несжатые пакеты не совместимы с предыдущими
92 версиями NNCP.
93
94 @item
95 У команд @command{nncp-call}, @command{nncp-caller} и @command{nncp-daemon}
96 появились @option{-autotoss*} опции для запуска tosser после завершения звонка.
97
98 @item
99 Обновлены зависимые библиотеки. Минимальная требуемая версия Go 1.12.
100
101 @end itemize
102
103 @node Релиз 5.4.1
104 @subsection Релиз 5.4.1
105 @itemize
106
107 @item
108 Исправлена ошибка с учётом @code{SENDMAIL} переменной при сборке.
109
110 @end itemize
111
112 @node Релиз 5.4.0
113 @subsection Релиз 5.4.0
114 @itemize
115
116 @item
117 Обновлены зависимые библиотеки.
118
119 @item
120 Система сборки переведена с Makefile-ов на @url{http://cr.yp.to/redo.html, redo}.
121 Это не должно повлиять на мейнтейнеров пакетов, так как минимальная
122 реализация @command{redo} включена в tarball.
123
124 @end itemize
125
126 @node Релиз 5.3.3
127 @subsection Релиз 5.3.3
128 @itemize
129
130 @item
131 Больше различных проверок в коде на ошибки.
132
133 @item
134 Обновлены зависимые библиотеки.
135
136 @end itemize
137
138 @node Релиз 5.3.2
139 @subsection Релиз 5.3.2
140 @itemize
141
142 @item
143 Исправлена некорректная логика @option{onlinedeadline} timeout-а, при
144 котором соединение могло не учитывать факты прихода пакетов и обрывать
145 связь.
146
147 @end itemize
148
149 @node Релиз 5.3.1
150 @subsection Релиз 5.3.1
151 @itemize
152
153 @item
154 Исправлена работоспособность @option{onlinedeadline} с адресами вызова
155 использующими внешние команды (@verb{#"|somecmd"#}).
156
157 @item
158 @command{nncp-stat} имеет опцию @option{-pkt} показывающую информацию по
159 каждому пакету в spool.
160
161 @end itemize
162
163 @node Релиз 5.3.0
164 @subsection Релиз 5.3.0
165 @itemize
166
167 @item
168 Сообщения прогресса содержат префикс, поясняющий выполняемое действие.
169
170 @item
171 Исправлено не происходящее дополнение (padding) handshake сообщений.
172
173 @item
174 Завершать все порождаемые в SP протоколе горутины, меньше утечек памяти.
175
176 @item
177 SP протокол порождает меньше вызовов записей (соответственно, и TCP
178 пакетов) в сокет.
179
180 @item
181 Проверять @option{onlinedeadline} и @option{maxonlinetime} ежесекундно,
182 независимо от чтения из сокета (раз в 10 секунд в худшем случае).
183
184 @item
185 Раз в минуту, если нет более никакого другого трафика, посылаются PING
186 пакеты в SP-соединении. Это позволит быстрее понимать что соединение
187 более не работоспособно.
188
189 @item
190 @command{nncp-toss} использует lock-file для предотвращения
191 одновременной обработки зашифрованных пакетов.
192
193 @end itemize
194
195 @node Релиз 5.2.1
196 @subsection Релиз 5.2.1
197 @itemize
198
199 @item
200 Исправлена обработка ошибки SP протокола, иногда вызывающая панику программы.
201
202 @end itemize
203
204 @node Релиз 5.2.0
205 @subsection Релиз 5.2.0
206 @itemize
207
208 @item
209 Большинство команд по умолчанию показывают однострочный прогресс
210 выполнения операции. Появились @option{-progress}, @option{-noprogress}
211 опции командной строки, @option{noprogress} опция конфигурационного
212 файла.
213
214 @item
215 Исправлен некорректный код возврата @command{nncp-check} команды,
216 который возвращал ошибку когда всё хорошо.
217
218 @item
219 Проверка свободного места для пакетов, во время выполнения
220 @command{nncp-bundle -rx}.
221
222 @end itemize
223
224 @node Релиз 5.1.2
225 @subsection Релиз 5.1.2
226 @itemize
227
228 @item
229 Исправлена @strong{критичная} уязвимость: аутентификация online нод
230 могла приводить к некорректной идентификации удалённой стороны, позволяя
231 скачивать чужие зашифрованные пакеты.
232
233 @item
234 Исправлена ошибка: в новосозданных конфигурационных файлах, приватный
235 публичный ключ Noise были поменяны местами, что приводило к
236 невозможности online аутентификации нод.
237
238 @item
239 Явная синхронизация (fsync) директорий для гарантированного
240 переименования файлов.
241
242 @end itemize
243
244 @node Релиз 5.1.1
245 @subsection Релиз 5.1.1
246 @itemize
247
248 @item
249 Исправлена работоспособность @command{nncp-file} с @option{-chunked 0} опцией.
250
251 @end itemize
252
253 @node Релиз 5.1.0
254 @subsection Релиз 5.1.0
255 @itemize
256
257 @item
258 @command{nncp-file} может отправлять директории, автоматически на лету
259 создавая pax архив.
260
261 @item
262 Во время создания исходящих сообщений проверяется наличие свободного
263 места на файловой системе.
264
265 @item
266 @option{freq}, @option{freqminsize}, @option{freqchunked} опции
267 конфигурационного файла заменены на структуру
268 @option{freq: @{path: ..., minsize: ..., chunked: ...@}}.
269
270 @item
271 Добавлена @option{freq.maxsize} опция конфигурационного файл,
272 запрещающая ответ на файловый запрос больше заданного размера.
273
274 @item
275 Возможность оповещения об успешно выполненных командах (exec) через
276 @option{notify.exec} опцию конфигурационного файла.
277
278 @end itemize
279
280 @node Релиз 5.0.0
281 @subsection Релиз 5.0.0
282 @itemize
283
284 @item
285 @strong{Несовместимое} изменение формата конфигурационного файла:
286 YAML заменён на Hjson, из-за его гораздо большей простоты, без
287 заметной потери функционала и удобства.
288
289 @item
290 @strong{Несовместимое} изменение формата простых пакетов. Работа со
291 старыми версиями не поддерживается. @code{zlib} сжатие заменено на
292 @code{Zstandard}, так как оно значительно быстрее и эффективнее, не
293 смотря на то, что версия библиотеки ещё не проверена временем.
294
295 @item
296 Возможность соединяться с удалёнными нодами не только по TCP, но и через
297 pipe вызов сторонней команды.
298
299 @item
300 @command{nncp-cfgnew} генерирует конфигурационный файл с множеством
301 комментариев. Можно использовать @option{-nocomments} опцию для старого
302 поведения.
303
304 @item
305 Дубликаты имён файлов имеют суффикс @file{.CTR}, вместо @file{CTR},
306 чтобы избежать возможных коллизий с @file{.nncp.chunkCTR}.
307
308 @item
309 Возможность переопределить umask процесса через опцию конфигурационного
310 файла.
311
312 @item
313 По умолчанию файлы и директории создаются с 666/777 правами доступа,
314 позволяя управлять ими @command{umask}-ом.
315
316 @item
317 Обновлены зависимости.
318
319 @item
320 Полное использование go модулей для управления зависимостями
321 (используется @code{go.cypherpunks.ru/nncp/v5} namespace).
322
323 @item
324 Отмена автоматического использования более новых версий GNU GPL
325 (лицензия проекта GNU GPLv3-только).
326
327 @end itemize
328
329 @node Релиз 4.1
330 @subsection Релиз 4.1
331 @itemize
332 @item Восстановлена работоспособность на GNU/Linux системах и Go версии 1.10.
333 @end itemize
334
335 @node Релиз 4.0
336 @subsection Релиз 4.0
337 @itemize
338
339 @item
340 @strong{Несовместимое} изменение формата зашифрованных и eblob пакетов:
341 используется AEAD режим шифрования с 128 КиБ блоками, так как раньше
342 @command{nncp-toss} не проверял MAC зашифрованного пакета прежде чем
343 отсылать дешифрованные данные внешней команде. Старые версии не
344 поддерживаются.
345
346 @item
347 Проверка доступного места перед копированием во время работы
348 @command{nncp-xfer}, @command{nncp-daemon}, @command{nncp-call(er)}.
349
350 @item
351 @command{nncp-call} имеет возможность только показывать список пакетов
352 на удалённой машине, без их передачи.
353
354 @item
355 @command{nncp-call} имеет возможность передавать только чётко указанные пакеты.
356
357 @item
358 Восстановлена работоспособность @option{xxrate} настройки в
359 @option{calls} секции конфигурационного файла.
360
361 @item
362 Зависимые библиотеки обновлены.
363
364 @item
365 Небольшие исправления ошибок.
366
367 @item
368 Начало использования @code{go.mod} подсистемы.
369
370 @end itemize
371
372 @node Релиз 3.4
373 @subsection Релиз 3.4
374 @itemize
375 @item @command{nncp-daemon} может быть запущен как @command{inetd}-служба.
376 @end itemize
377
378 @node Релиз 3.3
379 @subsection Релиз 3.3
380 @itemize
381
382 @item
383 @command{nncp-daemon}, @command{nncp-call}, @command{nncp-caller}
384 проверяют существование @file{.seen} файла и расценивают его как то, что
385 файл уже был скачан. Возможно передача данных была осуществлена
386 сторонним способом и удалённая сторона должна быть оповещена об этом.
387
388 @item
389 Если более высокоприоритетный пакет попадает в спул, то
390 @command{nncp-daemon} добавит его в очередь отправки первым, прерывая
391 низкоприоритетные передачи.
392
393 @item
394 К средствам связанным с online-соединениями (@command{nncp-daemon},
395 @command{nncp-call}, @command{nncp-caller}) добавлен простой
396 ограничитель скорости.
397
398 @item
399 Возможность задания приоритета символьными обозначениями:
400 @verb{|NORMAL|}, @verb{|BULK+10|}, @verb{|PRIORITY-5|}, итд.
401
402 @item
403 Изменены значения приоритетов по-умолчанию:
404 для @command{nncp-exec} с 64 на 96,
405 для @command{nncp-freq} с 64 на 160,
406 для @command{nncp-file} с 196 на 224.
407
408 @end itemize
409
410 @node Релиз 3.2
411 @subsection Релиз 3.2
412 @itemize
413 @item
414 @strong{Несовместимое} изменение формата @emph{bundle} архивов и
415 работоспособность @command{nncp-bundle} команды с Go 1.10+. Bundle
416 должен быть корректным tar архивом, но Go 1.9 делал его недействительным
417 из-за длинных путей внутри. NNCP нечаянно был зависим от этой баги.
418 Явное добавление @file{NNCP/} директории в архив восстанавливает
419 работоспособность с корректными tar архивами.
420 @end itemize
421
422 @node Релиз 3.1
423 @subsection Релиз 3.1
424 @itemize
425 @item
426 Возможность отключать пересылку через промежуточные ноды используя
427 @verb{|-via -|} опцию командной строки.
428 @end itemize
429
430 @node Релиз 3.0
431 @subsection Релиз 3.0
432 @itemize
433
434 @item
435 @strong{Несовместимое} изменение формата простых пакетов. Работа со
436 старыми версиями не поддерживается.
437
438 @item
439 Добавлена возможность удалённого исполнения команд, путём
440 конфигурирования @option{exec} опции конфигурационного файла и
441 использования команды @command{nncp-exec}:
442     @itemize
443     @item
444     Команда @command{nncp-mail} заменена более гибкой и широкой
445     @command{nncp-exec}. Вместо вызова @verb{|nncp-mail NODE RECIPIENT|}
446     нужно использовать @verb{|nncp-exec NODE sendmail RECIPIENT|}.
447     @item
448     @option{sendmail} опция конфигурационного файла заменена на более гибкую
449     @option{exec}. @verb{|sendmail: [...]|} нужно заменить на @verb{|exec:
450     sendmail: [...]|}.
451     @end itemize
452
453 @item
454 Возможность переопределить @option{via} опцию конфигурации для целевого
455 узла через @option{-via} опцию командной строки для следующих команд:
456 @command{nncp-file}, @command{nncp-freq}, @command{nncp-exec}.
457
458 @item
459 Chunked файлы, меньшего размера чем указанный chunk, отправляются просто
460 в виде одного файла.
461
462 @item
463 Exec команды вызываются с дополнительными переменными окружения
464 @env{NNCP_NICE} и @env{NNCP_SELF}.
465
466 @item
467 Отправляемые файлы в ответ на запрос имеют приоритет указанный в запросе.
468 Указать их желаемый приоритет во время вызова @command{nncp-freq} можно
469 аргументом @option{-replynice}.
470
471 @item
472 Команде @command{nncp-toss} можно сказать не обрабатывать определённые
473 типы пакетов, за счёт опций @option{-nofile}, @option{-nofreq},
474 @option{-noexec}, @option{-notrns}.
475
476 @item
477 По-умолчанию @command{nncp-file} команда для
478 @option{-minsize}/@option{-chunked} опций использует
479 @option{FreqMinSize}/@option{FreqChunked} из конфигурационного файла.
480 Это можно отключить указав нулевое значение.
481
482 @end itemize
483
484 @node Релиз 2.0
485 @subsection Релиз 2.0
486 @itemize
487
488 @item
489 @strong{Несовместимое} изменение формата зашифрованных и eblob пакетов.
490 Работа со старыми версиями не поддерживается.
491
492 @item
493 Алгоритм шифрования Twofish заменён на ChaCha20. Он намного быстрее.
494 Одним криптографическим примитивом меньше.
495
496 @item
497 HKDF-BLAKE2b-256 KDF алгоритм заменён на BLAKE2Xb XOF. Ещё одним
498 криптографическим примитивом меньше (предполагая, что BLAKE2X
499 практически идентичен BLAKE2).
500
501 @end itemize
502
503 @node Релиз 1.0
504 @subsection Релиз 1.0
505 @itemize
506
507 @item
508 @strong{Несовместимое} изменение формата зашифрованных пакетов. Работа
509 со старыми версиями не поддерживается.
510
511 @item
512 @command{nncp-bundle} команда может создавать потоки зашифрованных
513 пакетов или потреблять их. Это полезно когда речь идёт о
514 @code{stdin}/@code{stdout} методах передачи (например запись на CD-ROM
515 без создания промежуточного подготовленного ISO образа или работа с
516 ленточными накопителями).
517
518 @item
519 @command{nncp-toss} команда может создавать @file{.seen} файлы,
520 предотвращая приём дублированных пакетов.
521
522 @item
523 В команде @command{nncp-call} разрешается иметь только одного
524 обработчика контрольной суммы в фоне. Это полезно когда тысячи маленьких
525 входящих пакетов могут создать много горутин.
526
527 @item
528 Возможность переопределить путь до spool директории и файла журнала
529 через аргумент командной строки или переменную окружения.
530
531 @item
532 @command{nncp-rm} команда может удалять все исходящие/входящие,
533 @file{.seen}, @file{.part}, @file{.lock} и временные файлы.
534
535 @end itemize
536
537 @node Релиз 0.12
538 @subsection Релиз 0.12
539 @itemize
540 @item Команда sendmail вызывается с @env{NNCP_SENDER} переменной окружения.
541 @end itemize
542
543 @node Релиз 0.11
544 @subsection Релиз 0.11
545 @itemize
546 @item Вывод команды @command{nncp-stat} отсортирован по имени ноды.
547 @end itemize
548
549 @node Релиз 0.10
550 @subsection Релиз 0.10
551 @itemize
552 @item
553 @file{DST} аргумент @command{nncp-freq} команды теперь опционален.
554 По-умолчанию будет подставлен последний элемент @file{SRC} пути.
555 @end itemize
556
557 @node Релиз 0.9
558 @subsection Релиз 0.9
559 @itemize
560 @item
561 Исправлена обработка @option{-rx}/@option{-tx} опций @command{nncp-call}
562 команды. Они игнорировались.
563 @end itemize
564
565 @node Релиз 0.8
566 @subsection Релиз 0.8
567 @itemize
568 @item
569 Небольшое исправление ошибки в команде @command{nncp-file}, где опция
570 @option{-minsize} для передачи без разбиения на части была в байтах, а
571 не KiB-ах.
572 @end itemize
573
574 @node Релиз 0.7
575 @subsection Релиз 0.7
576 @itemize
577
578 @item
579 Возможность предоставлять данные для @command{nncp-file} через
580 стандартный ввод, используя временный зашифрованный файл для этого.
581
582 @item
583 Появилась возможность передачи файлов разбитых на части, с сопутствующей
584 @command{nncp-reass} командой и @option{freqchunked} опцией
585 конфигурационного файла. Полезно для передачи больших файлов через
586 маленькие устройства хранения.
587
588 @item
589 @option{freqminsize} опция конфигурационного файла, аналогичная
590 @option{-minsize}.
591
592 @item
593 Опция @option{-force} команды @command{nncp-xfer} переименована в
594 @option{-mkdir} для ясности.
595
596 @item
597 Опция @option{-minsize} задаётся в KiB, а не байтах, для удобства.
598
599 @item
600 Команда @command{nncp-newcfg} переименована в @command{nncp-cfgnew},
601 а @command{nncp-mincfg} в @command{nncp-cfgmin}, для того чтобы они
602 имели общий префикс и были сгруппированы для удобства.
603
604 @item
605 Появилась команда @command{nncp-cfgenc}, позволяющая
606 шифровать/дешифровать конфигурационный файл, чтобы безопасно его хранить
607 без использования OpenPGP или других подобных инструментов.
608
609 @item
610 Обновлены зависимые криптографические библиотеки.
611
612 @end itemize
613
614 @node Релиз 0.6
615 @subsection Релиз 0.6
616 @itemize
617 @item Появилась небольшая команда @command{nncp-rm}.
618 @item Обновлены зависимые криптографические библиотеки.
619 @end itemize
620
621 @node Релиз 0.5
622 @subsection Релиз 0.5
623 @itemize
624 @item
625 Тривиальное небольшое исправление в значениях приоритетов по-умолчанию в
626 @command{nncp-file} и @command{nncp-freq} командах.
627 @end itemize
628
629 @node Релиз 0.4
630 @subsection Релиз 0.4
631 @itemize
632
633 @item
634 Небольшое исправление в @command{nncp-call}, @command{nncp-caller},
635 @command{nncp-daemon}: иногда они могли падать с segmentation fault
636 ошибкой (данные не терялись).
637
638 @item
639 @command{nncp-newnode} переименована в @command{nncp-newcfg} --
640 это короче и удобнее для использования.
641
642 @item
643 Появилась команда @command{nncp-mincfg}: вспомогательная утилита
644 позволяющая создать минималистичный урезанный конфигурационный файл без
645 приватных ключей, что полезно во время использования @command{nncp-xfer}.
646
647 @end itemize
648
649 @node Релиз 0.3
650 @subsection Релиз 0.3
651 @itemize
652 @item Исправлена совместимость с Go 1.6.
653 @end itemize
654
655 @node Релиз 0.2
656 @subsection Релиз 0.2
657 @itemize
658
659 @item
660 @strong{Несовместимое} изменение формата пакета (магическое число тоже
661 изменено): поле размера пакета шифруется и не посылается в открытом виде.
662
663 @item
664 @option{-minsize} опция даёт возможность автоматически дополнять
665 исходящие пакеты до указанного минимального размера.
666
667 @item
668 @command{nncp-daemon} и @command{nncp-call}/@command{nncp-caller} всегда
669 в фоне проверяют появление исходящих @emph{tx} пакетов пока подключены.
670 Удалённая сторона сразу же оповещается об этом.
671
672 @item
673 @option{-onlinedeadline} опция даёт возможность выставления timeout-а на
674 неактивность в online соединении, когда оно должно быть отключено. Она
675 может быть использована для сохранения соединения на долгое время.
676
677 @item
678 @option{-maxonlinetime} опция даёт возможность указания максимального
679 возможного времени жизни соединения.
680
681 @item
682 Появилась @command{nncp-caller} команда: клиент TCP-демона работающий по
683 cron-у.
684
685 @item
686 @command{nncp-pkt} команда может разжимать данные.
687
688 @end itemize