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