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