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