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