dashboard.json 106 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061
  1. {
  2. "actions": {
  3. "copy": "Копировать",
  4. "download": "Скачать",
  5. "copied": "Скопировано"
  6. },
  7. "title": {
  8. "costRanking": "Таблица расходов",
  9. "costRankingDescription": "Просмотр рейтинга расходов пользователей, данные обновляются каждые 5 минут",
  10. "usageLogs": "Журналы использования",
  11. "clients": "Клиенты",
  12. "userAndKeyManagement": "Управление пользователями и ключами",
  13. "requestMessages": "Сообщения запроса",
  14. "activeSessions": "Активные сеансы (последние 5 минут)",
  15. "sessionMonitoring": "Мониторинг сеансов",
  16. "sessionMonitoringDescription": "Отображение активных и неактивных сеансов в реальном времени (автоматическое обновление каждые 3 секунды)",
  17. "inactiveSessions": "Неактивные сеансы (более 5 минут, только просмотр)",
  18. "quotasManagement": "Управление квотами",
  19. "quotasManagementDescription": "Просмотр и управление квотами на всех уровнях",
  20. "usersQuotas": "Статистика квот пользователей",
  21. "keysQuotas": "Статистика квот ключей",
  22. "providersQuotas": "Статистика квот поставщиков",
  23. "usageLogsDescription": "Просмотр журналов вызовов API и статистики использования",
  24. "filterCriteria": "Критерии фильтрации",
  25. "filterCriteriaDescription": "Фильтруйте журналы по времени, пользователю, поставщику и другим параметрам"
  26. },
  27. "description": {
  28. "viewApiCallLogs": "Просмотр журналов вызовов API и статистики использования",
  29. "dashboard": "Просмотр системной статистики и информации мониторинга",
  30. "quotas": "Просмотр и управление квотами на всех уровнях",
  31. "clientInfo": "Заголовок запроса User-Agent",
  32. "requestMessagesDescription": "Содержимое сообщения, отправленного клиентом",
  33. "responseBodyDescription": "Полный ответ сервера (TTL 5 минут)"
  34. },
  35. "overview": {
  36. "title": "Обзор",
  37. "totalRequests": "Всего запросов",
  38. "totalCost": "Общие затраты",
  39. "totalUsers": "Всего пользователей",
  40. "totalProviders": "Всего поставщиков",
  41. "activeUsers": "Активные пользователи",
  42. "activeSessions": "Активные сеансы",
  43. "errorRate": "Коэффициент ошибок",
  44. "avgResponseTime": "Среднее время ответа"
  45. },
  46. "stats": {
  47. "title": "Статистика",
  48. "requests": "Запросы",
  49. "cost": "Стоимость",
  50. "tokens": "Токены",
  51. "period": {
  52. "hour": "Последний час",
  53. "day": "Сегодня",
  54. "week": "На этой неделе",
  55. "month": "В этом месяце"
  56. }
  57. },
  58. "logs": {
  59. "title": "Журналы использования",
  60. "description": "Просмотр и анализ записей вызовов API",
  61. "filters": {
  62. "user": "Пользователь",
  63. "provider": "Поставщик",
  64. "sessionId": "ID сессии",
  65. "searchUser": "Поиск пользователей...",
  66. "searchProvider": "Поиск провайдеров...",
  67. "searchSessionId": "Поиск ID сессии...",
  68. "noUserFound": "Пользователи не найдены",
  69. "noProviderFound": "Провайдеры не найдены",
  70. "noSessionFound": "ID сессии не найдены",
  71. "model": "Модель",
  72. "endpoint": "Эндпоинт",
  73. "status": "Статус",
  74. "timeRange": "Диапазон времени",
  75. "dateRange": "Диапазон дат",
  76. "startTime": "Время начала",
  77. "endTime": "Время окончания",
  78. "allUsers": "Все пользователи",
  79. "allKeys": "Все ключи",
  80. "selectUserFirst": "Сначала выберите пользователя",
  81. "allProviders": "Все поставщики",
  82. "allModels": "Все модели",
  83. "allEndpoints": "Все эндпоинты",
  84. "allStatusCodes": "Все коды состояния",
  85. "apiKey": "API ключ",
  86. "statusCode": "Код состояния",
  87. "minRetryCount": "Количество ретраев ≥",
  88. "minRetryCountPlaceholder": "Введите минимум (0 — без ограничения)",
  89. "apply": "Применить фильтр",
  90. "reset": "Сброс",
  91. "last7days": "7д",
  92. "last30days": "30д",
  93. "customRange": "Произвольный диапазон",
  94. "export": "Экспорт",
  95. "exporting": "Экспорт...",
  96. "exportSuccess": "Экспорт завершен",
  97. "exportError": "Ошибка экспорта",
  98. "exportPreparing": "Подготовка экспорта...",
  99. "exportProgress": "Экспортировано {current} / {total}",
  100. "quickFilters": {
  101. "today": "Сегодня",
  102. "thisWeek": "Эта неделя",
  103. "errorsOnly": "Только ошибки",
  104. "showRetries": "С ретраями"
  105. },
  106. "activeFilters": {
  107. "title": "Активные фильтры",
  108. "remove": "Удалить фильтр",
  109. "clearAll": "Очистить все"
  110. },
  111. "groups": {
  112. "time": "Период времени",
  113. "timeDesc": "Фильтр по дате и времени",
  114. "identity": "Идентификация",
  115. "identityDesc": "Фильтр по пользователю и ключу",
  116. "request": "Запрос",
  117. "requestDesc": "Фильтр по поставщику, модели, эндпоинту",
  118. "status": "Статус",
  119. "statusDesc": "Фильтр по коду состояния и ретраям"
  120. }
  121. },
  122. "columns": {
  123. "time": "Время",
  124. "user": "Пользователь",
  125. "key": "Ключ",
  126. "sessionId": "ID сессии",
  127. "provider": "Поставщик",
  128. "model": "Модель тарификации",
  129. "endpoint": "Эндпоинт",
  130. "inputTokens": "Вход",
  131. "outputTokens": "Выход",
  132. "tokens": "Tokens",
  133. "cacheWrite": "Запись в кэш",
  134. "cacheRead": "Чтение из кэша",
  135. "cache": "Cache",
  136. "cost": "Стоимость",
  137. "duration": "Продолжительность",
  138. "performance": "Perf",
  139. "status": "Статус"
  140. },
  141. "stats": {
  142. "title": "Сводка статистики",
  143. "description": "Агрегированная статистика по текущим фильтрам",
  144. "totalAmount": "Общая сумма расходов",
  145. "totalTokens": "Общее количество токенов",
  146. "cacheTokens": "Токены кэша",
  147. "input": "Вход",
  148. "output": "Выход",
  149. "write": "Запись",
  150. "read": "Чтение",
  151. "totalRequests": "Всего запросов",
  152. "loading": "Загрузка..."
  153. },
  154. "table": {
  155. "noData": "Нет данных",
  156. "pagination": "Всего {total} записей, страница {page} / {totalPages}",
  157. "prevPage": "Предыдущая",
  158. "nextPage": "Следующая",
  159. "blocked": "Заблокировано",
  160. "nonBilling": "Не тарифицируется",
  161. "skipped": "Пропущено",
  162. "specialSettings": "Особые",
  163. "anthropicEffort": "Effort: {effort}",
  164. "times": "раз",
  165. "loadedCount": "Загружено {count} записей",
  166. "loadingMore": "Загрузка...",
  167. "noMoreData": "Все записи загружены",
  168. "scrollToTop": "Наверх",
  169. "hideProviderColumn": "Скрыть столбец провайдера",
  170. "showProviderColumn": "Показать столбец провайдера",
  171. "columnVisibility": "Видимость столбцов"
  172. },
  173. "actions": {
  174. "refresh": "Обновить",
  175. "refreshing": "Обновление...",
  176. "stopAutoRefresh": "Остановить автообновление",
  177. "startAutoRefresh": "Начать автообновление",
  178. "view": "Просмотр",
  179. "fullscreen": "Полный экран",
  180. "exitFullscreen": "Выйти из полного экрана"
  181. },
  182. "error": {
  183. "loadFailed": "Ошибка загрузки",
  184. "loadKeysFailed": "Не удалось загрузить список ключей"
  185. },
  186. "details": {
  187. "title": "Детали запроса",
  188. "statusTitle": "Статус: {status}",
  189. "inProgress": "В процессе",
  190. "retrying": "Retrying",
  191. "unknown": "Неизвестно",
  192. "success": "Запрос успешно выполнен",
  193. "error": "Запрос не выполнен, ниже подробная информация об ошибке и цепочке решений поставщика",
  194. "processing": "Запрос находится в процессе выполнения и еще не завершен",
  195. "tabs": {
  196. "summary": "Обзор",
  197. "logicTrace": "Цепочка решений",
  198. "performance": "Производительность",
  199. "metadata": "Метаданные"
  200. },
  201. "summary": {
  202. "keyMetrics": "Ключевые показатели",
  203. "totalCost": "Общая стоимость",
  204. "totalTokens": "Всего токенов",
  205. "duration": "Длительность",
  206. "outputRate": "Скорость вывода",
  207. "viewFullError": "Показать полную ошибку",
  208. "viewSession": "Просмотр сеанса"
  209. },
  210. "specialSettings": {
  211. "title": "Особые настройки"
  212. },
  213. "skipped": {
  214. "title": "Пропущено",
  215. "reason": "Причина",
  216. "warmup": "Warmup быстрый ответ (CCH)",
  217. "desc": "Этот запрос был распознан как Warmup-проба и был обработан самим CCH без обращения к провайдерам; он не тарифицируется, не учитывается в лимитах и исключается из статистики."
  218. },
  219. "blocked": {
  220. "title": "Информация о блокировке",
  221. "type": "Тип блокировки",
  222. "sensitiveWord": "Блокировка по ключевым словам",
  223. "word": "Ключевое слово",
  224. "matchType": "Тип совпадения",
  225. "matchTypeContains": "Содержит",
  226. "matchTypeExact": "Точное совпадение",
  227. "matchTypeRegex": "Регулярное выражение",
  228. "matchedText": "Совпадающий контент"
  229. },
  230. "sessionId": "ID сеанса",
  231. "messagesCount": "Количество сообщений",
  232. "messagesLabel": "Сообщения",
  233. "messagesUnit": "шт.",
  234. "clientInfo": "Информация о клиенте",
  235. "modelRedirect": {
  236. "title": "Перенаправление модели",
  237. "requestModel": "Запрошенная модель",
  238. "actualModel": "Фактический вызов",
  239. "billing": "Описание тарификации",
  240. "billingDescription": "Система в первую очередь тарифицирует по цене запрошенной модели ({original}). Если эта модель отсутствует в прайс-листе, используется цена фактически вызванной модели ({current}).",
  241. "billingModel": "Модель тарификации",
  242. "actualModelTooltip": "Фактическая модель: {model}",
  243. "originalModelTooltip": "Исходная модель: {model}",
  244. "billingDescription_original": "Текущий режим тарификации: По исходной модели до перенаправления ({original})",
  245. "billingDescription_redirected": "Текущий режим тарификации: По фактической модели после перенаправления ({current})",
  246. "billingOriginal": "оплата: исх.",
  247. "billingRedirected": "оплата: факт."
  248. },
  249. "errorMessage": "Сообщение об ошибке",
  250. "fake200ForwardedNotice": "Примечание: для потоковых запросов эта ошибка может быть обнаружена только после завершения потока; содержимое ответа могло уже быть передано клиенту.",
  251. "fake200DetectedReason": "Причина обнаружения: {reason}",
  252. "fake200Reasons": {
  253. "emptyBody": "Пустое тело ответа",
  254. "htmlBody": "Получен HTML-документ (возможно, страница ошибки)",
  255. "jsonErrorNonEmpty": "В JSON непустое поле `error`",
  256. "jsonErrorMessageNonEmpty": "В JSON непустое `error.message`",
  257. "jsonMessageKeywordMatch": "В JSON `message` содержит слово \"error\" (эвристика)",
  258. "unknown": "Тело ответа указывает на ошибку"
  259. },
  260. "statusCodeInferredBadge": "Предположено",
  261. "statusCodeInferredTooltip": "Этот код состояния выведен по содержимому тела ответа (например, fake 200) и может отличаться от HTTP-кода апстрима.",
  262. "statusCodeInferredSuffix": "(предп.)",
  263. "filteredProviders": "Отфильтрованные поставщики",
  264. "providerChain": {
  265. "title": "Хронология цепочки решений поставщика",
  266. "totalDuration": "Общая продолжительность: {duration}мс"
  267. },
  268. "noError": {
  269. "processing": "Запрос обрабатывается, ожидание ответа...",
  270. "success": "Запрос успешно выполнен, ошибок нет",
  271. "default": "Подробная информация об ошибке отсутствует"
  272. },
  273. "clickStatusCode": "Нажмите на код состояния, чтобы просмотреть полную хронологию",
  274. "viewDetails": "Просмотр деталей",
  275. "reasons": {
  276. "rateLimited": "Лимит стоимости поставщика",
  277. "circuitOpen": "Размыкатель цепи открыт"
  278. },
  279. "billingDetails": {
  280. "title": "Детали биллинга",
  281. "input": "Входные",
  282. "output": "Выходные",
  283. "cacheWrite5m": "Запись кэша (5m)",
  284. "cacheWrite1h": "Запись кэша (1h)",
  285. "cacheRead": "Чтение кэша",
  286. "cacheTtl": "TTL кэша",
  287. "cacheTtlSwapped": "TTL биллинга (инверсия)",
  288. "multiplier": "Множитель поставщика",
  289. "totalCost": "Общая стоимость",
  290. "fast": "fast",
  291. "fastPriority": "Приоритетный уровень обслуживания (режим fast)",
  292. "context1m": "1M контекст",
  293. "context1mEnabled": "Окно контекста 1M включено",
  294. "pricingProvider": "Провайдер тарифа",
  295. "pricingSourceLabel": "Источник тарифа",
  296. "pricingSource": {
  297. "local_manual": "Локальная ручная цена",
  298. "cloud_exact": "Точная облачная цена провайдера",
  299. "cloud_model_fallback": "Цена провайдера из резервной модели",
  300. "priority_fallback": "Приоритетная резервная цена",
  301. "single_provider_top_level": "Цена верхнего уровня для одного провайдера",
  302. "official_fallback": "Официальная цена"
  303. }
  304. },
  305. "performance": {
  306. "title": "Производительность",
  307. "ttfb": "TTFB",
  308. "duration": "Общее время",
  309. "outputRate": "Скорость вывода"
  310. },
  311. "performanceTab": {
  312. "noPerformanceData": "Нет данных о производительности",
  313. "ttfbGauge": "Время до первого байта",
  314. "outputRateGauge": "Скорость вывода",
  315. "latencyBreakdown": "Разбивка задержки",
  316. "generationTime": "Время генерации",
  317. "assessment": {
  318. "excellent": "Отлично",
  319. "good": "Хорошо",
  320. "warning": "Предупреждение",
  321. "poor": "Плохо"
  322. },
  323. "thresholds": {
  324. "ttfbGood": "TTFB < 1с",
  325. "ttfbWarning": "TTFB 1-2с",
  326. "ttfbPoor": "TTFB > 3с"
  327. }
  328. },
  329. "metadata": {
  330. "noMetadata": "Нет метаданных",
  331. "sessionInfo": "Информация о сеансе",
  332. "clientInfo": "Информация о клиенте",
  333. "billingInfo": "Информация о биллинге",
  334. "technicalTimeline": "Техническая хронология",
  335. "copyTimeline": "Копировать хронологию"
  336. },
  337. "effort": {
  338. "label": "Effort",
  339. "overridden": "Переопределено провайдером"
  340. },
  341. "logicTrace": {
  342. "title": "Цепочка решений",
  343. "noDecisionData": "Нет данных о решениях",
  344. "providersCount": "{count} поставщиков",
  345. "healthyCount": "{count} исправных",
  346. "initialSelection": "Начальный выбор",
  347. "healthCheck": "Проверка работоспособности",
  348. "prioritySelection": "Выбор по приоритету",
  349. "attemptProvider": "Попытка: {provider}",
  350. "retryAttempt": "Повтор #{number}",
  351. "httpStatus": "HTTP {code}{inferredSuffix}",
  352. "sessionReuse": "Повторное использование сессии",
  353. "sessionReuseDesc": "Провайдер из кэша сессии",
  354. "sessionReuseTitle": "Привязка сессии",
  355. "sessionReuseSelection": "Выбор с повторным использованием сессии",
  356. "sessionReuseSelectionDesc": "Провайдер выбран из кэша сессии",
  357. "sessionInfo": "Информация о сессии",
  358. "sessionIdLabel": "ID сессии",
  359. "requestSequence": "Номер запроса",
  360. "sessionAge": "Возраст сессии",
  361. "reusedProvider": "Повторно используемый провайдер",
  362. "executeRequest": "Выполнить запрос",
  363. "cacheOptimizationHint": "Повторное использование сессии оптимизирует производительность, поддерживая привязку к провайдеру в рамках одного разговора, снижая накладные расходы на выбор и повышая частоту попаданий в кэш.",
  364. "originDecisionTitle": "Исходное решение выбора",
  365. "originDecisionDesc": "Как провайдер был изначально выбран для этой сессии",
  366. "originDecisionLoading": "Загрузка исходного решения...",
  367. "originDecisionUnavailable": "Запись исходного решения недоступна",
  368. "originDecisionExpand": "Просмотр исходного выбора"
  369. }
  370. },
  371. "providerChain": {
  372. "decisionChain": "Цепочка решений поставщика",
  373. "clickItemForDetails": "Нажмите на шаг, чтобы посмотреть детали"
  374. },
  375. "modelRedirect": {
  376. "redirected": "Перенаправлено",
  377. "targetModel": "Целевая модель"
  378. },
  379. "statusCodes": {
  380. "200": "200 (Успех)",
  381. "400": "400 (Неверный запрос)",
  382. "401": "401 (Не авторизован)",
  383. "429": "429 (Ограничение)",
  384. "500": "500 (Ошибка сервера)",
  385. "not200": "Не 200 (ошибки/блокировки)"
  386. },
  387. "billingDetails": {
  388. "input": "Входные",
  389. "output": "Выходные",
  390. "cacheWrite5m": "Запись кэша (5m)",
  391. "cacheWrite1h": "Запись кэша (1h)",
  392. "cacheRead": "Чтение кэша",
  393. "cacheTtl": "TTL кэша",
  394. "cacheTtlSwapped": "TTL биллинга (инверсия)",
  395. "multiplier": "Множитель поставщика",
  396. "totalCost": "Общая стоимость",
  397. "fast": "fast",
  398. "fastPriority": "Приоритетный уровень обслуживания (режим fast)",
  399. "context1m": "1M Контекст",
  400. "context1mEnabled": "Окно контекста 1M включено",
  401. "pricingProvider": "Провайдер тарифа",
  402. "pricingSourceLabel": "Источник тарифа",
  403. "pricingSource": {
  404. "local_manual": "Локальная ручная цена",
  405. "cloud_exact": "Точная облачная цена провайдера",
  406. "cloud_model_fallback": "Цена провайдера из резервной модели",
  407. "priority_fallback": "Приоритетная резервная цена",
  408. "single_provider_top_level": "Цена верхнего уровня для одного провайдера",
  409. "official_fallback": "Официальная цена"
  410. }
  411. }
  412. },
  413. "leaderboard": {
  414. "title": "Таблица расходов",
  415. "description": "Просмотр рейтинга расходов пользователей и ключей",
  416. "todayTitle": "Сегодняшний рейтинг",
  417. "viewAll": "Смотреть все",
  418. "userRankings": "Рейтинг пользователей",
  419. "providerRankings": "Рейтинг поставщиков",
  420. "modelRankings": "Рейтинг моделей",
  421. "noData": "Нет данных за сегодня",
  422. "requests": "запросов",
  423. "tokens": "токенов",
  424. "tabs": {
  425. "users": "Рейтинг пользователей",
  426. "keys": "Рейтинг ключей",
  427. "userRanking": "Рейтинг пользователей",
  428. "userCacheHitRateRanking": "Рейтинг пользователей по попаданиям в кэш",
  429. "providerRanking": "Рейтинг поставщиков",
  430. "providerCacheHitRateRanking": "Рейтинг по попаданиям в кэш",
  431. "modelRanking": "Рейтинг моделей",
  432. "dailyRanking": "Сегодня",
  433. "weeklyRanking": "Эта неделя",
  434. "monthlyRanking": "Этот месяц",
  435. "allTimeRanking": "Всё время"
  436. },
  437. "dateRange": {
  438. "to": "по",
  439. "prevPeriod": "Предыдущий период",
  440. "nextPeriod": "Следующий период",
  441. "customRange": "Произвольный диапазон"
  442. },
  443. "columns": {
  444. "rank": "Ранг",
  445. "name": "Имя",
  446. "totalCost": "Общие затраты",
  447. "totalRequests": "Всего запросов",
  448. "avgCost": "Средние затраты",
  449. "lastActive": "Последняя активность",
  450. "user": "Пользователь",
  451. "requests": "Количество запросов",
  452. "tokens": "Количество токенов",
  453. "consumedAmount": "Потраченная сумма",
  454. "provider": "Поставщик",
  455. "model": "Модель",
  456. "cost": "Стоимость",
  457. "cacheHitRequests": "Запросы (учтены в hit rate)",
  458. "cacheHitRate": "Попадания в кэш",
  459. "cacheReadTokens": "Токены чтения из кэша",
  460. "totalTokens": "Всего токенов",
  461. "cacheCreationConsumedAmount": "Расход на создание кэша",
  462. "totalConsumedAmount": "Общие расходы",
  463. "successRate": "Процент успеха",
  464. "avgResponseTime": "Среднее время ответа",
  465. "avgTtfbMs": "Средний TTFB",
  466. "avgTokensPerSecond": "Средн. ток/с",
  467. "avgCostPerRequest": "Ср. стоимость/запрос",
  468. "avgCostPerMillionTokens": "Ср. стоимость/1М токенов",
  469. "unknownModel": "Неизвестно"
  470. },
  471. "expandModelStats": "Развернуть модели",
  472. "collapseModelStats": "Свернуть модели",
  473. "states": {
  474. "loading": "Загрузка...",
  475. "noData": "Нет данных",
  476. "todayNoData": "Нет данных за сегодня",
  477. "weekNoData": "Нет данных за эту неделю",
  478. "monthNoData": "Нет данных за этот месяц",
  479. "fetchFailed": "Не удалось получить данные таблицы лидеров"
  480. },
  481. "permission": {
  482. "title": "Требуются разрешения",
  483. "restricted": "Доступ ограничен",
  484. "description": "Для функции таблицы лидеров администратору необходимо включить разрешение «Разрешить просмотр использования всего сайта».",
  485. "adminAction": "Включить это разрешение.",
  486. "userAction": "Пожалуйста, свяжитесь с администратором, чтобы включить это разрешение.",
  487. "systemSettings": "Настройки системы"
  488. },
  489. "filters": {
  490. "userTagsPlaceholder": "Фильтр по тегам пользователей...",
  491. "userGroupsPlaceholder": "Фильтр по группам пользователей..."
  492. },
  493. "userInsights": {
  494. "title": "Аналитика пользователя",
  495. "backToLeaderboard": "Вернуться к рейтингу",
  496. "overview": "Обзор",
  497. "keyTrend": "Тренд использования ключей",
  498. "modelBreakdown": "Разбивка по моделям",
  499. "requests": "Запросы",
  500. "cost": "Стоимость",
  501. "avgResponseTime": "Среднее время ответа",
  502. "errorRate": "Частота ошибок",
  503. "timeRange": {
  504. "today": "Сегодня",
  505. "7days": "Последние 7 дней",
  506. "30days": "Последние 30 дней",
  507. "thisMonth": "Этот месяц"
  508. },
  509. "unknownModel": "Неизвестная модель",
  510. "noData": "Нет данных",
  511. "dateRange": "Диапазон дат",
  512. "allTime": "Всё время",
  513. "providerBreakdown": "Разбивка по провайдерам",
  514. "unknownProvider": "Неизвестный провайдер",
  515. "apiKey": "API ключ",
  516. "provider": "Провайдер",
  517. "model": "Модель",
  518. "allKeys": "Все ключи",
  519. "allProviders": "Все провайдеры",
  520. "allModels": "Все модели",
  521. "dimensions": "Измерения",
  522. "filters": "Фильтры",
  523. "loadError": "Не удалось загрузить данные"
  524. }
  525. },
  526. "sessions": {
  527. "title": "Активные сеансы",
  528. "description": "Мониторинг активных сеансов API в режиме реального времени",
  529. "monitoring": "Мониторинг сеансов",
  530. "monitoringDescription": "Отображение активных и неактивных сеансов в реальном времени (автоматическое обновление каждые 3 секунды)",
  531. "activeSessions": "Активные сеансы (последние 5 минут)",
  532. "inactiveSessions": "Неактивные сеансы (более 5 минут, только просмотр)",
  533. "columns": {
  534. "sessionId": "ID сеанса",
  535. "user": "Пользователь",
  536. "key": "Ключ",
  537. "provider": "Поставщик",
  538. "model": "Модель",
  539. "startTime": "Время начала",
  540. "lastActivity": "Последняя активность",
  541. "requestCount": "Количество запросов",
  542. "totalInput": "Общий ввод",
  543. "totalOutput": "Общий вывод",
  544. "totalCost": "Общая стоимость",
  545. "totalDuration": "Общая продолжительность",
  546. "status": "Статус",
  547. "actions": "Действия"
  548. },
  549. "table": {
  550. "count": "Всего {count} {type} сеансов",
  551. "active": "Активные",
  552. "inactive": "Неактивные",
  553. "notCountedInConcurrency": "(не учитывается в параллельных запросах)",
  554. "refreshing": "Обновление...",
  555. "noActiveSessions": "Нет активных сеансов"
  556. },
  557. "pagination": {
  558. "total": "всего"
  559. },
  560. "details": {
  561. "title": "Сообщения сеанса",
  562. "messages": "Список сообщений",
  563. "info": "Информация сеанса",
  564. "timeline": "Хронология",
  565. "overview": "Обзор сеанса",
  566. "overviewDescription": "Сводная статистика",
  567. "providersAndModels": "Поставщики и модели",
  568. "providersAndModelsDescription": "Используемые поставщики и модели",
  569. "tokenUsage": "Использование токенов (всего)",
  570. "tokenUsageDescription": "Кумулятивная статистика по всем запросам",
  571. "costInfo": "Информация о стоимости (всего)",
  572. "costInfoDescription": "Кумулятивная стоимость по всем запросам",
  573. "totalRequests": "Всего запросов",
  574. "firstRequest": "Первый запрос",
  575. "lastRequest": "Последний запрос",
  576. "totalDuration": "Общая продолжительность",
  577. "totalInput": "Общий ввод",
  578. "totalOutput": "Общий вывод",
  579. "cacheCreation": "Создание кэша",
  580. "cacheTtlMixed": "Смешанный",
  581. "cacheRead": "Чтение из кэша",
  582. "total": "Всего",
  583. "totalFee": "Общая плата",
  584. "providers": "Поставщики",
  585. "models": "Модели",
  586. "noDetailedData": "Подробные данные отсутствуют",
  587. "storageTip": "Подробные данные не найдены. Возможные причины: Redis отключен/недоступен (REDIS_URL + ENABLE_RATE_LIMIT=true), данные истекли (SESSION_TTL, по умолчанию 300с), или сохранение тела ответа отключено (STORE_SESSION_RESPONSE_BODY=false, влияет только на тело ответа). Чтобы сохранять сообщения без маскировки, установите STORE_SESSION_MESSAGES=true.",
  588. "clientInfo": "Информация о клиенте",
  589. "requestHeaders": "Заголовки запроса",
  590. "requestBody": "Тело запроса",
  591. "requestMessages": "Сообщения запроса",
  592. "specialSettings": "Особые",
  593. "requestMessagesDescription": "Содержимое сообщения, отправленного клиентом",
  594. "responseHeaders": "Заголовки ответа",
  595. "responseBody": "Тело ответа",
  596. "responseBodyDescription": "Полный ответ сервера (TTL 5 минут)",
  597. "noHeaders": "Нет данных",
  598. "noData": "Нет данных",
  599. "prevRequest": "Предыдущий",
  600. "nextRequest": "Следующий"
  601. },
  602. "actions": {
  603. "back": "Назад",
  604. "view": "Просмотр",
  605. "copy": "Копировать",
  606. "download": "Скачать",
  607. "copyMessages": "Копировать запрос (заголовки и тело)",
  608. "downloadMessages": "Скачать запрос (заголовки и тело)",
  609. "copied": "Скопировано",
  610. "copyResponse": "Копировать тело ответа",
  611. "terminate": "Прервать",
  612. "terminateTitle": "Прервать сессию",
  613. "terminateDescription": "Вы уверены, что хотите прервать эту сессию? После прерывания привязка поставщика будет очищена, и следующий запрос выберет нового поставщика.",
  614. "sessionIdLabel": "ID сессии: {sessionId}",
  615. "cancel": "Отмена",
  616. "confirmTerminate": "Прервать",
  617. "terminating": "Прерывание...",
  618. "terminateSuccess": "Сессия успешно прервана",
  619. "terminateFailed": "Не удалось прервать сессию",
  620. "terminateSelected": "Прервать выбранные",
  621. "selectedCount": "Выбрано: {count}",
  622. "selectAll": "Выбрать все",
  623. "selectSessionLabel": "Выбрать сессию",
  624. "multiSelect": "Множественный выбор",
  625. "cancelMultiSelect": "Отмена",
  626. "terminateSessionTitle": "Прервать сессию",
  627. "terminateSessionDescription": "Вы уверены, что хотите прервать эту сессию? Это действие нельзя отменить.",
  628. "batchTerminateSuccess": "Прервано {count} сессий",
  629. "batchTerminatePartial": "Без прав: {unauthorized} · Отсутствуют: {missing}",
  630. "batchTerminateAllowedFailed": "Не удалось прервать {count} разрешённых сессий",
  631. "batchTerminateNone": "Не удалось прервать ни одной сессии",
  632. "noSelection": "Выберите хотя бы одну сессию"
  633. },
  634. "codeDisplay": {
  635. "raw": "Сырой",
  636. "pretty": "Форматированный",
  637. "searchPlaceholder": "Поиск",
  638. "expand": "Развернуть",
  639. "collapse": "Свернуть",
  640. "themeAuto": "Авто",
  641. "themeLight": "Светлая",
  642. "themeDark": "Тёмная",
  643. "noMatches": "Нет совпадений",
  644. "onlyMatches": "Только совпадения",
  645. "showAll": "Показать всё",
  646. "prevPage": "Назад",
  647. "nextPage": "Вперёд",
  648. "pageInfo": "Страница {page} / {total}",
  649. "sseEvent": "Событие",
  650. "sseData": "Данные",
  651. "hardLimit": {
  652. "title": "Содержимое слишком большое",
  653. "size": "Размер: {sizeMB} MB ({sizeBytes} bytes)",
  654. "maximum": "Максимум: {maxSizeMB} MB или {maxLines} строк",
  655. "hint": "Пожалуйста, скачайте файл, чтобы посмотреть весь контент.",
  656. "download": "Скачать"
  657. }
  658. },
  659. "status": {
  660. "loading": "Загрузка...",
  661. "loadError": "Ошибка загрузки",
  662. "fetchFailed": "Не удалось получить",
  663. "unknownError": "Неизвестная ошибка",
  664. "storageNotEnabled": "Не сохранено",
  665. "storageNotEnabledHint": "Подсказка: проверьте REDIS_URL и ENABLE_RATE_LIMIT=true (кэш деталей сессии). Чтобы сохранять сообщения без маскировки, установите STORE_SESSION_MESSAGES=true."
  666. },
  667. "errors": {
  668. "copyFailed": "Не удалось скопировать"
  669. },
  670. "requestList": {
  671. "title": "Список запросов",
  672. "noRequests": "Запросы не найдены",
  673. "fetchFailed": "Не удалось получить список запросов",
  674. "unknownError": "Неизвестная ошибка",
  675. "prev": "Назад",
  676. "next": "Вперед",
  677. "orderAsc": "Переключить на прямой порядок (старые первыми)",
  678. "orderDesc": "Переключить на обратный порядок (новые первыми)"
  679. },
  680. "back": "Назад",
  681. "loadingError": "Не удалось загрузить"
  682. },
  683. "quotas": {
  684. "title": "Управление квотами",
  685. "description": "Управление квотами пользователей, ключей и поставщиков",
  686. "tabs": {
  687. "overview": "Обзор",
  688. "users": "Квоты пользователей",
  689. "keys": "Квоты ключей",
  690. "providers": "Квоты поставщиков"
  691. },
  692. "columns": {
  693. "name": "Имя",
  694. "limit": "Лимит",
  695. "used": "Использовано",
  696. "remaining": "Осталось",
  697. "resetTime": "Время сброса",
  698. "status": "Статус"
  699. },
  700. "labels": {
  701. "byName": "По имени",
  702. "byUsageRate": "По уровню использования",
  703. "all": "Все",
  704. "warning": "Приближается к лимиту (>60%)",
  705. "exceeded": "Превышено (≥100%)"
  706. },
  707. "users": {
  708. "title": "Статистика квот пользователей",
  709. "totalUsers": "Всего {count} пользователей"
  710. },
  711. "keys": {
  712. "title": "Статистика квот ключей",
  713. "totalKeysInfo": "Всего {userCount} пользователей, {keyCount} ключей",
  714. "setKeyQuota": "Установить квоту ключа",
  715. "setUserQuota": "Установить квоту пользователя",
  716. "onlyKeyQuota": "Только квота ключа",
  717. "onlyUserQuota": "Только квота пользователя",
  718. "success": "Квота пользователя установлена успешно"
  719. },
  720. "providers": {
  721. "title": "Статистика квот поставщиков",
  722. "totalProviders": "Всего {count} поставщиков"
  723. }
  724. },
  725. "labels": {
  726. "byName": "По имени",
  727. "byUsageRate": "По уровню использования"
  728. },
  729. "all": "Все",
  730. "nav": {
  731. "mobileMenuTitle": "Меню навигации",
  732. "dashboard": "Панель",
  733. "usageLogs": "Журналы",
  734. "leaderboard": "Лидеры",
  735. "availability": "Мониторинг",
  736. "myQuota": "Моя квота",
  737. "quotasManagement": "Квоты",
  738. "userManagement": "Пользователи",
  739. "providers": "Поставщики",
  740. "documentation": "Доки",
  741. "systemSettings": "Настройки",
  742. "feedback": "Обратная связь",
  743. "login": "Вход",
  744. "logout": "Выход"
  745. },
  746. "statistics": {
  747. "title": "Статистика",
  748. "cost": "Сумма расходов",
  749. "calls": "Количество вызовов API",
  750. "totalCost": "Общая сумма расходов",
  751. "totalCalls": "Общее количество вызовов API",
  752. "timeRange": {
  753. "today": "Сегодня",
  754. "todayDescription": "Использование за сегодня",
  755. "7days": "7д",
  756. "7daysDescription": "Использование за последние 7 дней",
  757. "30days": "30д",
  758. "30daysDescription": "Использование за последние 30 дней",
  759. "thisMonth": "Этот месяц",
  760. "thisMonthDescription": "Использование за этот месяц",
  761. "default": "Использование"
  762. },
  763. "mode": {
  764. "keys": "Только ваши ключи",
  765. "mixed": "Показать детали ваших ключей и сводку других пользователей",
  766. "users": "Показать для всех"
  767. },
  768. "legend": {
  769. "selectAll": "Выбрать все",
  770. "deselectAll": "Очистить",
  771. "selected": "Выбрано"
  772. },
  773. "chartMode": {
  774. "label": "Режим отображения",
  775. "overlay": "Сравнение",
  776. "stacked": "Накопление"
  777. },
  778. "states": {
  779. "noData": "Нет статистических данных",
  780. "fetchFailed": "Не удалось получить статистические данные"
  781. },
  782. "othersAggregate": "Другие пользователи"
  783. },
  784. "errors": {
  785. "fetchSystemSettingsFailed": "Не удалось получить параметры системы",
  786. "fetchFailed": "Ошибка загрузки",
  787. "fetchSessionListFailed": "Не удалось получить список сеансов"
  788. },
  789. "keyList": {
  790. "columns": {
  791. "name": "Название",
  792. "key": "Ключ",
  793. "todayCalls": "Вызовы сегодня",
  794. "todayCost": "Расходы сегодня",
  795. "lastUsed": "Последнее использование",
  796. "actions": "Действия"
  797. },
  798. "detailsButton": "Подробная информация",
  799. "modelStats": "Статистика моделей",
  800. "modelStatsColumns": {
  801. "model": "Модель",
  802. "calls": "Вызовы",
  803. "cost": "Расходы"
  804. },
  805. "limitUsage": "Использование лимита",
  806. "copyKeyTooltip": "Скопировать полный ключ",
  807. "showKeyTooltip": "Показать полный ключ",
  808. "hideKeyTooltip": "Скрыть ключ",
  809. "copyFailed": "Не удалось скопировать:",
  810. "timesUnit": "раз",
  811. "provider": "Провайдер",
  812. "neverUsed": "Не использовался",
  813. "viewLogsTooltip": "Просмотр подробных журналов",
  814. "logsButton": "Журналы",
  815. "emptyState": {
  816. "title": "Нет ключей",
  817. "description": "Нажмите кнопку \"Добавить ключ\" в правом верхнем углу, чтобы добавить ключ"
  818. }
  819. },
  820. "userList": {
  821. "title": "Список пользователей",
  822. "badge": "{count} ключей",
  823. "activeKeys": "Активные ключи",
  824. "totalKeys": "Всего ключей",
  825. "expiresAt": "Срок действия",
  826. "status": {
  827. "active": "Активен",
  828. "expiringSoon": "Скоро истечет",
  829. "expired": "Истек",
  830. "disabled": "Отключен"
  831. },
  832. "actions": {
  833. "renew": "Продлить",
  834. "renew30d": "Продлить на 30 дней",
  835. "renew90d": "Продлить на 90 дней",
  836. "renew1y": "Продлить на 1 год",
  837. "renewCustom": "Настроить...",
  838. "customPrompt": "Введите новую дату истечения (ГГГГ-ММ-ДД). Оставьте пустым для отмены.",
  839. "invalidDate": "Пожалуйста, введите действительную дату",
  840. "enable": "Включить",
  841. "disable": "Отключить",
  842. "success": "Операция выполнена успешно",
  843. "failed": "Операция не удалась, попробуйте еще раз"
  844. },
  845. "emptyState": {
  846. "title": "Нет пользователей",
  847. "description": "Вы еще не создали ни одного пользователя. Пользователи являются основой для управления API-ключами и квотами использования. Создайте первого пользователя, чтобы начать!",
  848. "action": "Создать первого пользователя"
  849. },
  850. "addUser": "Добавить пользователя"
  851. },
  852. "keyListHeader": {
  853. "todayUsage": "Использование сегодня",
  854. "userStatus": {
  855. "disabled": "Отключен",
  856. "expired": "Истек",
  857. "expiringSoon": "Скоро истечет",
  858. "active": "Активен"
  859. },
  860. "allowedModels": {
  861. "label": "Разрешённые модели",
  862. "noRestrictions": "Разрешённые модели: без ограничений"
  863. },
  864. "expiresAt": "Истекает",
  865. "proxyStatus": {
  866. "loading": "Загрузка статуса прокси",
  867. "fetchFailed": "Не удалось получить статус прокси",
  868. "noStatus": "Нет статуса прокси",
  869. "activeRequests": "Активные запросы",
  870. "lastRequest": "Последний запрос",
  871. "noRecord": "Нет записи",
  872. "timeAgo": {
  873. "justNow": "Только что",
  874. "secondsAgo": "{count}с назад",
  875. "minutesAgo": "{count} мин назад",
  876. "hoursAgo": "{count}ч назад",
  877. "daysAgo": "{count}д назад"
  878. }
  879. },
  880. "addKey": "Добавить ключ",
  881. "keyCreatedDialog": {
  882. "title": "Ключ успешно создан",
  883. "description": "Ваш API-ключ был успешно создан. Пожалуйста, скопируйте и сохраните его в безопасном месте, так как он будет показан только один раз.",
  884. "apiKeyLabel": "API ключ",
  885. "warningText": "Пожалуйста, скопируйте и сохраните перед закрытием. После закрытия вы не сможете снова просмотреть этот ключ",
  886. "httpWarningText": "Обнаружен HTTP-доступ. Ограничения браузера не позволяют использовать функцию копирования. Нажмите на значок глаза, чтобы показать ключ и скопировать его вручную.",
  887. "copyTooltip": "Скопировать в буфер обмена",
  888. "showTooltip": "Показать полный ключ",
  889. "hideTooltip": "Скрыть ключ",
  890. "closeButton": "Закрыть"
  891. },
  892. "allowedClients": {
  893. "label": "Разрешённые клиенты",
  894. "noRestrictions": "Разрешённые клиенты: без ограничений"
  895. }
  896. },
  897. "keyLimitUsage": {
  898. "loading": "Загрузка...",
  899. "error": "Ошибка загрузки",
  900. "networkError": "Сетевая ошибка",
  901. "cost5h": "Расход за 5 часов",
  902. "costDaily": "Дневной расход",
  903. "costWeekly": "Недельный расход",
  904. "costMonthly": "Месячный расход",
  905. "concurrentSessions": "Параллельные сеансы",
  906. "noLimit": "Без ограничений"
  907. },
  908. "addKeyForm": {
  909. "title": "Добавить ключ",
  910. "description": "Создать новый API-ключ для текущего пользователя. Значение ключа будет сгенерировано автоматически.",
  911. "submitText": "Создать ключ",
  912. "loadingText": "Создание...",
  913. "keyName": {
  914. "label": "Имя ключа",
  915. "placeholder": "Введите имя ключа"
  916. },
  917. "expiresAt": {
  918. "label": "Срок действия",
  919. "placeholder": "Выберите срок действия",
  920. "description": "Оставьте пустым для бессрочного ключа"
  921. },
  922. "canLoginWebUi": {
  923. "label": "Разрешить вход в веб-интерфейс",
  924. "description": "При отключении этот ключ можно использовать только для вызовов API и нельзя использовать для входа в панель администрирования"
  925. },
  926. "limit5hUsd": {
  927. "label": "Лимит расходов за 5 часов (USD)",
  928. "placeholder": "Оставьте пустым для неограниченного",
  929. "description": "Максимальный расход в течение 5 часов",
  930. "descriptionWithUserLimit": "Максимальный расход за 5 часов (Лимит пользователя: {limit})"
  931. },
  932. "limitDailyUsd": {
  933. "label": "Дневной лимит расходов (USD)",
  934. "placeholder": "Оставьте пустым для неограниченного",
  935. "description": "Максимальный расход в день"
  936. },
  937. "dailyResetMode": {
  938. "label": "Режим ежедневного сброса",
  939. "options": {
  940. "fixed": "Сброс в фиксированное время",
  941. "rolling": "Скользящее окно (24 часа)"
  942. },
  943. "desc": {
  944. "fixed": "Сброс квоты в определенное время каждый день",
  945. "rolling": "24-часовое скользящее окно от первого запроса"
  946. }
  947. },
  948. "dailyResetTime": {
  949. "label": "Время ежедневного сброса",
  950. "placeholder": "HH:mm",
  951. "description": "Когда сбрасывается дневной лимит (использует системный часовой пояс)"
  952. },
  953. "limitWeeklyUsd": {
  954. "label": "Недельный лимит расходов (USD)",
  955. "placeholder": "Оставьте пустым для неограниченного",
  956. "description": "Максимальный расход в неделю",
  957. "descriptionWithUserLimit": "Максимальный расход в неделю (Лимит пользователя: {limit})"
  958. },
  959. "limitMonthlyUsd": {
  960. "label": "Месячный лимит расходов (USD)",
  961. "placeholder": "Оставьте пустым для неограниченного",
  962. "description": "Максимальный расход в месяц",
  963. "descriptionWithUserLimit": "Максимальный расход в месяц (Лимит пользователя: {limit})"
  964. },
  965. "limitTotalUsd": {
  966. "label": "Общий лимит расходов (USD)",
  967. "placeholder": "Оставьте пустым для неограниченного",
  968. "description": "Максимальная сумма расходов (без сброса)",
  969. "descriptionWithUserLimit": "Не может превышать общий лимит пользователя ({limit})"
  970. },
  971. "limitConcurrentSessions": {
  972. "label": "Лимит параллельных сеансов",
  973. "placeholder": "0 означает неограниченно",
  974. "description": "Количество одновременных разговоров",
  975. "descriptionWithUserLimit": "Максимум сеансов (Лимит пользователя: {limit})"
  976. },
  977. "providerGroup": {
  978. "label": "Группа провайдеров",
  979. "placeholder": "Введите теги групп провайдеров и нажмите Enter",
  980. "description": "Группы провайдеров для этого ключа (по умолчанию: default).",
  981. "defaultDescription": "default включает провайдеров без groupTag.",
  982. "descriptionWithUserGroup": "Группы провайдеров для этого ключа (группы пользователя: {group}; по умолчанию: default)."
  983. },
  984. "cacheTtl": {
  985. "label": "Переопределение Cache TTL",
  986. "description": "Принудительно установить Anthropic prompt cache TTL для запросов с cache_control.",
  987. "options": {
  988. "inherit": "Не переопределять (следовать провайдеру/клиенту)",
  989. "5m": "5m",
  990. "1h": "1h"
  991. }
  992. },
  993. "successTitle": "Ключ успешно создан",
  994. "successDescription": "Ваш API-ключ был успешно создан.",
  995. "generatedKey": {
  996. "label": "Сгенерированный ключ",
  997. "hint": "Вы можете управлять этим ключом в списке ключей (включить/выключить, лимиты и т. д.), но полный ключ показывается только один раз. Скопируйте и сохраните его сейчас."
  998. },
  999. "errors": {
  1000. "userIdMissing": "ID пользователя не существует",
  1001. "createFailed": "Не удалось создать, попробуйте позже",
  1002. "noKeyReturned": "Создан успешно, но ключ не был возвращен"
  1003. }
  1004. },
  1005. "userForm": {
  1006. "title": {
  1007. "add": "Добавить пользователя",
  1008. "edit": "Редактировать пользователя"
  1009. },
  1010. "description": {
  1011. "add": "Создать нового пользователя. Система автоматически сгенерирует ключ по умолчанию.",
  1012. "edit": "Изменить основную информацию пользователя."
  1013. },
  1014. "submitText": {
  1015. "add": "Создать пользователя",
  1016. "edit": "Сохранить изменения"
  1017. },
  1018. "loadingText": {
  1019. "add": "Создание...",
  1020. "edit": "Сохранение..."
  1021. },
  1022. "username": {
  1023. "label": "Имя пользователя",
  1024. "placeholder": "Введите имя пользователя"
  1025. },
  1026. "note": {
  1027. "label": "Примечание",
  1028. "placeholder": "Введите примечание (необязательно)",
  1029. "description": "Используется для описания назначения пользователя или примечаний"
  1030. },
  1031. "providerGroup": {
  1032. "label": "Группа поставщиков",
  1033. "placeholder": "например, default или premium,economy",
  1034. "description": "Группы провайдеров пользователя (по умолчанию: default). Провайдеры без groupTag относятся к default."
  1035. },
  1036. "tags": {
  1037. "label": "Теги пользователя",
  1038. "placeholder": "Введите тег (Enter для добавления)",
  1039. "description": "Добавьте теги для классификации и фильтрации (максимум 20 тегов, до 32 символов каждый)"
  1040. },
  1041. "rpm": {
  1042. "label": "Лимит RPM",
  1043. "placeholder": "Лимит запросов в минуту",
  1044. "description": "По умолчанию: {default}, диапазон: 1-10000"
  1045. },
  1046. "dailyQuota": {
  1047. "label": "Дневная квота",
  1048. "placeholder": "Лимит дневного расхода",
  1049. "helperText": "Установите 0 для неограниченного доступа",
  1050. "description": "По умолчанию: ${default}, диапазон: $0.01-$1000"
  1051. },
  1052. "limit5hUsd": {
  1053. "label": "Лимит на 5 часов (USD)",
  1054. "placeholder": "Оставьте пустым для неограниченного",
  1055. "description": "Максимальный расход за 5 часов"
  1056. },
  1057. "limitWeeklyUsd": {
  1058. "label": "Недельный лимит (USD)",
  1059. "placeholder": "Оставьте пустым для неограниченного",
  1060. "description": "Максимальный недельный расход"
  1061. },
  1062. "limitMonthlyUsd": {
  1063. "label": "Месячный лимит (USD)",
  1064. "placeholder": "Оставьте пустым для неограниченного",
  1065. "description": "Максимальный месячный расход"
  1066. },
  1067. "limitConcurrentSessions": {
  1068. "label": "Лимит одновременных сессий",
  1069. "placeholder": "0 означает неограниченно",
  1070. "description": "Количество одновременных разговоров"
  1071. },
  1072. "isEnabled": {
  1073. "label": "Активировать пользователя",
  1074. "description": "Отключенные пользователи не смогут использовать API"
  1075. },
  1076. "expiresAt": {
  1077. "label": "Срок действия",
  1078. "placeholder": "Оставьте пустым для бессрочного",
  1079. "description": "Пользователь будет автоматически отключен после истечения срока",
  1080. "pastWarning": "Выбранная дата в прошлом. После сохранения пользователь сразу станет просроченным и будет отключен."
  1081. },
  1082. "allowedClients": {
  1083. "label": "Разрешённые клиенты",
  1084. "description": "Ограничьте, какие CLI/IDE клиенты могут использовать эту учётную запись. Пусто = без ограничений.",
  1085. "customLabel": "Пользовательские шаблоны клиентов",
  1086. "customPlaceholder": "Введите шаблон (например, 'my-ide', 'codex-*')"
  1087. },
  1088. "allowedModels": {
  1089. "label": "Разрешённые модели",
  1090. "placeholder": "Введите название модели (Enter для добавления)",
  1091. "description": "Ограничить пользователя определёнными моделями ИИ. Оставьте пустым без ограничений (макс. 50 моделей, 64 символа)"
  1092. }
  1093. },
  1094. "deleteKeyConfirm": {
  1095. "title": "Подтвердить удаление ключа",
  1096. "description": "Вы уверены, что хотите удалить ключ \"{name}\"?\n{maskedKey}\nЭто действие нельзя отменить. Все приложения, использующие этот ключ, потеряют доступ.",
  1097. "cancel": "Отмена",
  1098. "confirm": "Подтвердить удаление",
  1099. "confirmLoading": "Удаление...",
  1100. "errors": {
  1101. "deleteFailed": "Не удалось удалить",
  1102. "retryError": "Не удалось удалить, попробуйте позже"
  1103. }
  1104. },
  1105. "keyActions": {
  1106. "edit": "Редактировать",
  1107. "delete": "Удалить",
  1108. "editAriaLabel": "Редактировать ключ",
  1109. "deleteAriaLabel": "Удалить ключ"
  1110. },
  1111. "userActions": {
  1112. "edit": "Редактировать пользователя",
  1113. "delete": "Удалить пользователя",
  1114. "editAriaLabel": "Редактировать пользователя",
  1115. "deleteAriaLabel": "Удалить пользователя"
  1116. },
  1117. "availability": {
  1118. "title": "Мониторинг доступности провайдеров",
  1119. "description": "Мониторинг доступности и показателей производительности провайдеров в реальном времени",
  1120. "nav": "Мониторинг доступности",
  1121. "tabs": {
  1122. "provider": "Доступность провайдеров",
  1123. "endpoint": "Здоровье эндпоинтов"
  1124. },
  1125. "overview": {
  1126. "systemAvailability": "Доступность системы",
  1127. "avgLatency": "Средняя задержка",
  1128. "errorRate": "Коэффициент ошибок",
  1129. "activeProbes": "Активные проверки",
  1130. "load": "Нагрузка"
  1131. },
  1132. "timeRange": {
  1133. "label": "Временной диапазон",
  1134. "15min": "15 мин",
  1135. "1h": "1 час",
  1136. "6h": "6 часов",
  1137. "24h": "24 часа",
  1138. "7d": "7 дней",
  1139. "last15min": "Последние 15 минут",
  1140. "last1h": "Последний час",
  1141. "last6h": "Последние 6 часов",
  1142. "last24h": "Последние 24 часа",
  1143. "last7d": "7д",
  1144. "custom": "Настраиваемый"
  1145. },
  1146. "laneChart": {
  1147. "title": "Хронология доступности провайдеров",
  1148. "noData": "Нет данных",
  1149. "requests": "{count} запросов",
  1150. "availability": "{value}% доступно",
  1151. "noRequests": "Нет запросов",
  1152. "denseData": "Плотные",
  1153. "sparseData": "Разреженные",
  1154. "latency": "Задержка"
  1155. },
  1156. "latencyChart": {
  1157. "title": "Распределение задержки",
  1158. "p50": "P50",
  1159. "p95": "P95",
  1160. "p99": "P99",
  1161. "noData": "Нет данных о задержке"
  1162. },
  1163. "latencyCurve": {
  1164. "title": "Тренд задержки",
  1165. "noData": "Нет данных о задержке",
  1166. "avg": "Средн.",
  1167. "min": "Мин.",
  1168. "max": "Макс.",
  1169. "latency": "Задержка"
  1170. },
  1171. "terminal": {
  1172. "title": "Журнал проверок",
  1173. "live": "LIVE",
  1174. "download": "Скачать журнал",
  1175. "noLogs": "Нет журналов проверок",
  1176. "manual": "Ручная",
  1177. "auto": "Авто",
  1178. "filterPlaceholder": "Фильтр журналов..."
  1179. },
  1180. "probeGrid": {
  1181. "title": "Статус эндпоинтов",
  1182. "noEndpoints": "Эндпоинты не настроены",
  1183. "lastProbe": "Последняя проверка",
  1184. "status": {
  1185. "unknown": "Неизвестно",
  1186. "healthy": "Здоров",
  1187. "unhealthy": "Нездоров"
  1188. }
  1189. },
  1190. "endpoint": {
  1191. "selectVendor": "Выберите вендора",
  1192. "selectType": "Выберите тип"
  1193. },
  1194. "confidence": {
  1195. "low": "Низкая",
  1196. "medium": "Средняя",
  1197. "high": "Высокая",
  1198. "lowTooltip": "Менее {count} запросов. Данные могут быть нерепрезентативными.",
  1199. "mediumTooltip": "Умеренный объём запросов. Данные достаточно надёжны.",
  1200. "highTooltip": "Высокий объём запросов. Данные надёжны."
  1201. },
  1202. "actions": {
  1203. "refresh": "Обновить",
  1204. "refreshing": "Обновление...",
  1205. "autoRefresh": "Автообновление",
  1206. "stopAutoRefresh": "Остановить автообновление",
  1207. "viewDetails": "Подробнее",
  1208. "testProvider": "Тестировать провайдера"
  1209. },
  1210. "status": {
  1211. "green": "Здоров",
  1212. "red": "Недоступен",
  1213. "unknown": "Неизвестно"
  1214. },
  1215. "statusDescription": {
  1216. "green": "Сервис работает нормально, запросы успешны",
  1217. "red": "Сервис недоступен или ошибка",
  1218. "unknown": "Данные отсутствуют"
  1219. },
  1220. "metrics": {
  1221. "systemAvailability": "Доступность системы",
  1222. "totalRequests": "Всего запросов",
  1223. "successRate": "Успешность",
  1224. "avgLatency": "Средняя задержка",
  1225. "p50Latency": "P50 задержка",
  1226. "p95Latency": "P95 задержка",
  1227. "p99Latency": "P99 задержка",
  1228. "lastRequest": "Последний запрос",
  1229. "requestCount": "Кол-во запросов"
  1230. },
  1231. "filters": {
  1232. "provider": "Провайдер",
  1233. "allProviders": "Все провайдеры",
  1234. "includeDisabled": "Включить отключённые"
  1235. },
  1236. "sort": {
  1237. "label": "Сортировка",
  1238. "availability": "Доступность",
  1239. "name": "Название",
  1240. "requests": "Запросы"
  1241. },
  1242. "columns": {
  1243. "provider": "Провайдер",
  1244. "type": "Тип",
  1245. "status": "Статус",
  1246. "availability": "Доступность",
  1247. "requests": "Запросы",
  1248. "successRate": "Успешность",
  1249. "avgLatency": "Средняя задержка",
  1250. "lastRequest": "Последний запрос",
  1251. "actions": "Действия"
  1252. },
  1253. "chart": {
  1254. "title": "Тренд доступности",
  1255. "description": "Изменение доступности во времени",
  1256. "availabilityScore": "Оценка доступности",
  1257. "requestVolume": "Объём запросов",
  1258. "latencyTrend": "Тренд задержки",
  1259. "noData": "Нет данных"
  1260. },
  1261. "details": {
  1262. "title": "Детали провайдера",
  1263. "overview": "Обзор",
  1264. "timeBuckets": "Временные интервалы",
  1265. "greenCount": "Успешные запросы",
  1266. "redCount": "Неудачные запросы"
  1267. },
  1268. "states": {
  1269. "loading": "Загрузка...",
  1270. "error": "Ошибка загрузки",
  1271. "noProviders": "Нет провайдеров",
  1272. "noData": "Нет данных о доступности",
  1273. "fetchFailed": "Не удалось получить данные о доступности"
  1274. },
  1275. "legend": {
  1276. "green": "Отлично (доступность 95%+)",
  1277. "lime": "Хорошо (доступность 80-95%)",
  1278. "orange": "Внимание (доступность 50-80%)",
  1279. "red": "Недоступен (доступность <50%)",
  1280. "noData": "Нет данных"
  1281. },
  1282. "summary": {
  1283. "title": "Сводка доступности",
  1284. "healthyProviders": "Здоровые провайдеры",
  1285. "unhealthyProviders": "Недоступные провайдеры",
  1286. "unknownProviders": "Нет данных",
  1287. "totalProviders": "Всего провайдеров"
  1288. },
  1289. "heatmap": {
  1290. "bucketSize": "Размер интервала",
  1291. "minutes": "мин",
  1292. "requests": "запросов",
  1293. "noData": "Нет данных",
  1294. "noRequests": "Нет запросов"
  1295. },
  1296. "probeHistory": {
  1297. "title": "История проверок эндпоинтов",
  1298. "description": "Просмотр журналов проверок и запуск ручной проверки для конкретного эндпоинта",
  1299. "selectVendor": "Выберите вендора",
  1300. "selectType": "Выберите тип провайдера",
  1301. "selectEndpoint": "Выберите эндпоинт",
  1302. "noEndpoints": "Эндпоинты не найдены",
  1303. "probeNow": "Проверить",
  1304. "probing": "Проверяем...",
  1305. "columns": {
  1306. "time": "Время",
  1307. "method": "Метод",
  1308. "status": "Статус",
  1309. "latency": "Задержка",
  1310. "error": "Ошибка"
  1311. },
  1312. "success": "Успех",
  1313. "manual": "Ручная проверка",
  1314. "auto": "Автоматическая проверка",
  1315. "probeSuccess": "Проверка успешна",
  1316. "probeFailed": "Проверка не удалась"
  1317. },
  1318. "toast": {
  1319. "refreshSuccess": "Данные о доступности обновлены",
  1320. "refreshFailed": "Обновление не удалось, попробуйте снова"
  1321. }
  1322. },
  1323. "rateLimits": {
  1324. "title": "Статистика событий лимитов",
  1325. "description": "Просмотр и анализ статистики событий лимитов",
  1326. "loading": "Загрузка...",
  1327. "error": "Ошибка загрузки",
  1328. "totalEvents": "Всего событий",
  1329. "avgUsage": "Среднее использование",
  1330. "affectedUsers": "Затронутые пользователи",
  1331. "noData": "Нет данных",
  1332. "noDataHint": "Нет событий лимитов в выбранном диапазоне времени",
  1333. "filters": {
  1334. "startTime": "Начало",
  1335. "endTime": "Конец",
  1336. "user": "Пользователь",
  1337. "provider": "Поставщик",
  1338. "limitType": "Тип лимита",
  1339. "allUsers": "Все пользователи",
  1340. "allProviders": "Все провайдеры",
  1341. "allLimitTypes": "Все типы",
  1342. "apply": "Применить фильтры",
  1343. "reset": "Сбросить",
  1344. "loading": "Загрузка...",
  1345. "limitTypes": {
  1346. "rpm": "Лимит RPM",
  1347. "usd_5h": "Лимит расходов за 5ч",
  1348. "usd_weekly": "Недельный лимит расходов",
  1349. "usd_monthly": "Месячный лимит расходов",
  1350. "concurrent_sessions": "Лимит одновременных сессий",
  1351. "daily_quota": "Дневной лимит квоты"
  1352. }
  1353. },
  1354. "chart": {
  1355. "title": "Хронология событий лимитов",
  1356. "description": "Почасовой тренд событий лимитов",
  1357. "total": "Всего",
  1358. "events": "Событий"
  1359. },
  1360. "breakdown": {
  1361. "title": "Распределение по типам лимитов",
  1362. "description": "Доля событий по типам лимитов",
  1363. "total": "Всего",
  1364. "count": "Событий",
  1365. "percentage": "Доля",
  1366. "noData": "Нет данных",
  1367. "types": {
  1368. "rpm": "RPM",
  1369. "usd_5h": "Расходы 5ч",
  1370. "usd_weekly": "Недельные расходы",
  1371. "usd_monthly": "Месячные расходы",
  1372. "concurrent_sessions": "Одновременные сессии",
  1373. "daily_quota": "Дневная квота"
  1374. }
  1375. },
  1376. "topUsers": {
  1377. "title": "Топ затронутых пользователей",
  1378. "description": "Пользователи, чаще всего попадавшие под лимиты",
  1379. "total": "Всего",
  1380. "rank": "Место",
  1381. "username": "Имя пользователя",
  1382. "eventCount": "Событий",
  1383. "percentage": "Доля",
  1384. "loading": "Загрузка...",
  1385. "noData": "Нет данных"
  1386. }
  1387. },
  1388. "users": {
  1389. "title": "Управление пользователями",
  1390. "description": "Показано {count} пользователей",
  1391. "toolbar": {
  1392. "searchPlaceholder": "Поиск по имени, заметкам, тегам, ключам...",
  1393. "groupFilter": "Фильтр по группе",
  1394. "allGroups": "Все группы",
  1395. "tagFilter": "Фильтр по тегу",
  1396. "allTags": "Все теги",
  1397. "keyGroupFilter": "Группа ключей",
  1398. "allKeyGroups": "Все группы ключей",
  1399. "sortBy": "Сортировка",
  1400. "sortOrder": "Порядок",
  1401. "sortByName": "Имя",
  1402. "sortByTags": "Теги",
  1403. "sortByExpiresAt": "Срок действия",
  1404. "sortByRpm": "Лимит RPM",
  1405. "sortByLimit5h": "Лимит 5 ч",
  1406. "sortByLimitDaily": "Дневной лимит",
  1407. "sortByLimitWeekly": "Недельный лимит",
  1408. "sortByLimitMonthly": "Месячный лимит",
  1409. "sortByCreatedAt": "Дата создания",
  1410. "ascending": "По возрастанию",
  1411. "descending": "По убыванию",
  1412. "statusFilter": "Статус",
  1413. "allStatus": "Все статусы",
  1414. "statusActive": "Активен",
  1415. "statusExpired": "Истек",
  1416. "statusExpiringSoon": "Скоро истечет",
  1417. "statusEnabled": "Включен",
  1418. "statusDisabled": "Отключен",
  1419. "createUser": "Создать пользователя",
  1420. "createKey": "Создать ключ"
  1421. },
  1422. "dialog": {
  1423. "userProviderGroup": "Ваши группы провайдеров",
  1424. "userProviderGroupHint": "Новые ключи могут использовать только ваши существующие группы провайдеров"
  1425. }
  1426. },
  1427. "userManagement": {
  1428. "table": {
  1429. "columns": {
  1430. "username": "Имя пользователя",
  1431. "note": "Примечание",
  1432. "expiresAt": "Дата истечения",
  1433. "expiresAtHint": "Нажмите для быстрого продления",
  1434. "limitRpm": "RPM",
  1435. "limit5h": "Лимит 5 ч",
  1436. "limitDaily": "Дневной лимит",
  1437. "limitWeekly": "Недельный лимит",
  1438. "limitMonthly": "Месячный лимит",
  1439. "limitTotal": "Общий лимит",
  1440. "limitSessions": "Одновременные сессии"
  1441. },
  1442. "keyRow": {
  1443. "name": "Название ключа",
  1444. "key": "Ключ",
  1445. "group": "Группа",
  1446. "todayUsage": "Запросы сегодня",
  1447. "todayCost": "Расход сегодня",
  1448. "todayTokens": "Токены сегодня",
  1449. "lastUsed": "Последнее использование",
  1450. "actions": "Действия",
  1451. "quotaButton": "Просмотр использования квоты",
  1452. "fields": {
  1453. "callsLabel": "Запросы",
  1454. "tokensLabel": "Токены",
  1455. "costLabel": "Расход"
  1456. }
  1457. },
  1458. "expand": "Развернуть",
  1459. "collapse": "Свернуть",
  1460. "refresh": "Обновить",
  1461. "noKeys": "Нет ключей",
  1462. "defaultGroup": "default",
  1463. "userStatus": {
  1464. "disabled": "Отключен"
  1465. },
  1466. "actions": {
  1467. "addKey": "Добавить ключ"
  1468. }
  1469. },
  1470. "keyFullDisplay": {
  1471. "title": "Полный ключ",
  1472. "copySuccess": "Ключ скопирован в буфер обмена",
  1473. "copyFailed": "Не удалось скопировать",
  1474. "show": "Показать ключ",
  1475. "hide": "Скрыть ключ",
  1476. "copied": "Скопировано",
  1477. "copy": "Скопировать ключ"
  1478. },
  1479. "keyStatsDialog": {
  1480. "title": "Статистика моделей за сегодня",
  1481. "columns": {
  1482. "model": "Модель",
  1483. "calls": "Вызовы",
  1484. "tokens": "Токены",
  1485. "cost": "Стоимость"
  1486. },
  1487. "modal": {
  1488. "requests": "Запросов",
  1489. "totalTokens": "Всего токенов",
  1490. "cost": "Стоимость",
  1491. "inputTokens": "Входные токены",
  1492. "outputTokens": "Выходные токены",
  1493. "cacheWrite": "Запись кэша",
  1494. "cacheRead": "Чтение кэша",
  1495. "cacheHitRate": "Попадание кэша",
  1496. "cacheTokens": "Токены кэша",
  1497. "performanceHigh": "Высокий",
  1498. "performanceMedium": "Средний",
  1499. "performanceLow": "Низкий"
  1500. },
  1501. "noData": "Нет записей использования за сегодня",
  1502. "totalCalls": "Всего вызовов",
  1503. "totalCost": "Общий расход"
  1504. },
  1505. "keyQuotaUsageDialog": {
  1506. "title": "Использование квоты ключа",
  1507. "fetchFailed": "Не удалось получить данные квоты",
  1508. "noLimit": "Без лимита",
  1509. "modeFixed": "Фиксированное время",
  1510. "modeRolling": "Скользящие 24ч",
  1511. "retry": "Повторить",
  1512. "labels": {
  1513. "limit5h": "5 часов",
  1514. "limitDaily": "Ежедневно",
  1515. "limitWeekly": "Еженедельно",
  1516. "limitMonthly": "Месячный лимит",
  1517. "limitTotal": "Всего",
  1518. "limitSessions": "Одновременно"
  1519. }
  1520. },
  1521. "quickRenew": {
  1522. "title": "Быстрое продление",
  1523. "description": "Установить новую дату истечения для пользователя {userName}",
  1524. "currentExpiry": "Текущий срок",
  1525. "neverExpires": "Бессрочно",
  1526. "expired": "Истёк",
  1527. "quickExtensionLabel": "Быстрое продление",
  1528. "quickExtensionHint": "Продлить от текущего срока (или от сейчас, если истёк)",
  1529. "customDateLabel": "Указать дату",
  1530. "customDateHint": "Напрямую указать дату истечения",
  1531. "quickOptions": {
  1532. "7days": "7 дней",
  1533. "30days": "30 дней",
  1534. "90days": "90 дней",
  1535. "1year": "1 год"
  1536. },
  1537. "customDate": "Произвольная дата",
  1538. "enableOnRenew": "Также включить пользователя",
  1539. "enableKeyOnRenew": "Также включить ключ",
  1540. "cancel": "Отмена",
  1541. "confirm": "Подтвердить продление",
  1542. "confirming": "Продление...",
  1543. "success": "Продление успешно",
  1544. "failed": "Ошибка продления"
  1545. },
  1546. "dialog": {
  1547. "createKeyTitle": "Создать ключ",
  1548. "editKeyTitle": "Редактировать ключ"
  1549. },
  1550. "editDialog": {
  1551. "title": "Редактировать пользователя",
  1552. "description": "Редактирование данных пользователя",
  1553. "userSection": "Настройки пользователя",
  1554. "keysSection": "Настройки ключей",
  1555. "scrollToKey": "Прокрутить к ключу",
  1556. "saveFailed": "Не удалось сохранить пользователя",
  1557. "keySaveFailed": "Не удалось сохранить ключ",
  1558. "keyDeleteFailed": "Не удалось удалить ключ",
  1559. "saveSuccess": "Изменения сохранены",
  1560. "atLeastOneKeyEnabled": "Необходимо оставить хотя бы один активный ключ",
  1561. "operationFailed": "Операция не удалась",
  1562. "userDisabled": "Пользователь отключен",
  1563. "userEnabled": "Пользователь активирован",
  1564. "deleteFailed": "Не удалось удалить пользователя",
  1565. "userDeleted": "Пользователь удален",
  1566. "saving": "Сохранение...",
  1567. "resetSection": {
  1568. "title": "Параметры сброса"
  1569. },
  1570. "resetLimits": {
  1571. "title": "Сброс лимитов",
  1572. "description": "Сбросить накопленные счетчики расходов для всех лимитов. Логи запросов и статистика сохраняются.",
  1573. "button": "Сбросить лимиты",
  1574. "confirmTitle": "Сбросить только лимиты?",
  1575. "confirmDescription": "Все накопленные счетчики расходов (5ч, дневной, недельный, месячный, общий) будут обнулены. Логи запросов и статистика использования сохранятся.",
  1576. "confirm": "Да, сбросить лимиты",
  1577. "loading": "Сброс...",
  1578. "error": "Не удалось сбросить лимиты",
  1579. "success": "Все лимиты сброшены",
  1580. "lastResetAt": "Последний сброс: {date}"
  1581. },
  1582. "resetData": {
  1583. "title": "Сброс статистики",
  1584. "description": "Удалить все логи запросов и данные использования для этого пользователя. Это действие необратимо.",
  1585. "error": "Не удалось сбросить данные",
  1586. "button": "Сбросить статистику",
  1587. "confirmTitle": "Сбросить всю статистику?",
  1588. "confirmDescription": "Это навсегда удалит все логи запросов и статистику использования для этого пользователя. Это действие нельзя отменить.",
  1589. "confirm": "Да, сбросить все",
  1590. "loading": "Сброс...",
  1591. "success": "Вся статистика сброшена"
  1592. }
  1593. },
  1594. "batchEdit": {
  1595. "enterMode": "Массовое редактирование",
  1596. "exitMode": "Выйти",
  1597. "selectAll": "Выбрать все",
  1598. "selectedCount": "Выбрано {users} пользователей, {keys} ключей",
  1599. "editSelected": "Редактировать выбранное",
  1600. "dialog": {
  1601. "title": "Массовое редактирование",
  1602. "description": "Повлияет на {users} пользователей и {keys} ключей",
  1603. "cancel": "Отмена",
  1604. "next": "Далее",
  1605. "noFieldEnabled": "Включите хотя бы одно поле для замены",
  1606. "noUpdate": "Нет обновлений для выполнения",
  1607. "noSelection": "Сначала выберите пользователей или ключи для массового редактирования."
  1608. },
  1609. "confirm": {
  1610. "title": "Подтвердить массовое обновление",
  1611. "description": "Будут обновлены {users} пользователей и {keys} ключей. Это действие нельзя отменить.",
  1612. "userFields": "Поля пользователя",
  1613. "keyFields": "Поля ключа",
  1614. "goBack": "Вернуться и изменить",
  1615. "update": "Подтвердить обновление",
  1616. "updating": "Обновление..."
  1617. },
  1618. "toast": {
  1619. "usersUpdated": "Обновлено {count} пользователей",
  1620. "keysUpdated": "Обновлено {count} ключей",
  1621. "usersFailed": "Не удалось обновить пользователей: {error}",
  1622. "keysFailed": "Не удалось обновить ключи: {error}",
  1623. "batchFailed": "Массовое обновление не удалось"
  1624. },
  1625. "validation": {
  1626. "invalidNumber": "Введите корректное число",
  1627. "negativeNumber": "Значение не может быть отрицательным"
  1628. },
  1629. "aria": {
  1630. "selectUser": "Выбрать пользователя",
  1631. "selectKey": "Выбрать ключ"
  1632. },
  1633. "user": {
  1634. "title": "Настройки пользователя",
  1635. "affected": "Повлияет на {count} пользователей",
  1636. "enableFieldAria": "Включить поле: {title}",
  1637. "fields": {
  1638. "note": "Заметка",
  1639. "tags": "Теги",
  1640. "rpm": "Лимит RPM",
  1641. "limit5h": "Лимит за 5 часов (USD)",
  1642. "limitDaily": "Дневной лимит (USD)",
  1643. "limitWeekly": "Недельный лимит (USD)",
  1644. "limitMonthly": "Месячный лимит (USD)"
  1645. },
  1646. "placeholders": {
  1647. "emptyToClear": "Оставьте пустым, чтобы очистить",
  1648. "tagsPlaceholder": "Нажмите Enter, чтобы добавить, можно разделять запятыми",
  1649. "emptyNoLimit": "Оставьте пустым для безлимита"
  1650. }
  1651. },
  1652. "key": {
  1653. "title": "Настройки ключа",
  1654. "affected": "Повлияет на {count} ключей",
  1655. "fields": {
  1656. "providerGroup": "Группа (providerGroup)",
  1657. "limit5h": "Лимит за 5 часов (USD)",
  1658. "limitDaily": "Дневной лимит (USD)",
  1659. "limitWeekly": "Недельный лимит (USD)",
  1660. "limitMonthly": "Месячный лимит (USD)",
  1661. "canLoginWebUi": "Независимая страница использования",
  1662. "keyEnabled": "Статус ключа"
  1663. },
  1664. "placeholders": {
  1665. "groupPlaceholder": "Оставьте пустым, чтобы очистить; несколько значений через запятую",
  1666. "emptyNoLimit": "Оставьте пустым для безлимита"
  1667. },
  1668. "targetValue": "Целевое значение"
  1669. }
  1670. },
  1671. "createDialog": {
  1672. "title": "Создать пользователя",
  1673. "description": "Создание нового пользователя и настройка API-ключей",
  1674. "saveFailed": "Не удалось создать пользователя",
  1675. "keyCreateFailed": "Не удалось создать ключ",
  1676. "rollbackFailed": "Не удалось выполнить откат. Возможно, пользователь был создан без ключа. Удалите пользователя вручную (userId: {userId}) и повторите попытку.",
  1677. "createSuccess": "Пользователь создан",
  1678. "successTitle": "Успешно создано",
  1679. "successDescription": "Пользователь и ключ успешно созданы",
  1680. "generatedKey": "Сгенерированный ключ",
  1681. "keyHint": "Вы можете управлять этим ключом на странице управления пользователями (включить/выключить, лимиты и т. д.), но полный ключ показывается только один раз. Скопируйте и сохраните его сейчас.",
  1682. "keysSection": "Ключи",
  1683. "addKey": "Добавить ключ",
  1684. "removeKey": "Удалить ключ",
  1685. "cannotDeleteLastKey": "Нельзя удалить последний ключ",
  1686. "confirmRemoveKeyTitle": "Удалить ключ",
  1687. "confirmRemoveKeyDescription": "Вы уверены, что хотите удалить ключ \"{name}\"?",
  1688. "creating": "Создание...",
  1689. "create": "Создать"
  1690. },
  1691. "limitRules": {
  1692. "addRule": "Добавить правило лимита",
  1693. "title": "Добавить правило лимита",
  1694. "description": "Выберите тип лимита и установите значение",
  1695. "cancel": "Отмена",
  1696. "confirm": "Сохранить",
  1697. "fields": {
  1698. "type": {
  1699. "label": "Тип лимита",
  1700. "placeholder": "Выберите"
  1701. },
  1702. "value": {
  1703. "label": "Значение",
  1704. "placeholder": "Введите"
  1705. }
  1706. },
  1707. "daily": {
  1708. "mode": {
  1709. "label": "Режим дневного сброса",
  1710. "fixed": "Сброс в фиксированное время",
  1711. "rolling": "Скользящее окно (24ч)",
  1712. "helperRolling": "Скользящее окно 24 часа от первого запроса"
  1713. },
  1714. "time": {
  1715. "label": "Время сброса",
  1716. "placeholder": "ЧЧ:мм"
  1717. }
  1718. },
  1719. "limitTypes": {
  1720. "limitRpm": "Лимит RPM",
  1721. "limit5h": "Лимит за 5 часов",
  1722. "limitDaily": "Дневной лимит",
  1723. "limitWeekly": "Недельный лимит",
  1724. "limitMonthly": "Месячный лимит",
  1725. "limitTotal": "Общий лимит",
  1726. "limitSessions": "Одновременные сессии"
  1727. },
  1728. "ruleTypes": {
  1729. "limitRpm": "Лимит RPM",
  1730. "limit5h": "Лимит за 5 часов",
  1731. "limitDaily": "Дневной лимит",
  1732. "limitWeekly": "Недельный лимит",
  1733. "limitMonthly": "Месячный лимит",
  1734. "limitTotal": "Общий лимит",
  1735. "limitSessions": "Одновременные сессии"
  1736. },
  1737. "errors": {
  1738. "missingType": "Пожалуйста, выберите тип лимита",
  1739. "invalidValue": "Пожалуйста, введите корректное значение",
  1740. "invalidTime": "Пожалуйста, введите корректное время (ЧЧ:мм)"
  1741. },
  1742. "overwriteHint": "Этот тип уже существует, сохранение перезапишет существующее значение",
  1743. "dailyMode": {
  1744. "fixed": "Сброс по фиксированному времени",
  1745. "rolling": "Скользящее окно (24ч)"
  1746. },
  1747. "quickValues": {
  1748. "10": "$10",
  1749. "50": "$50",
  1750. "100": "$100",
  1751. "500": "$500",
  1752. "unlimited": "Без ограничений"
  1753. },
  1754. "alreadySet": "Уже настроено",
  1755. "confirmAdd": "Добавить"
  1756. },
  1757. "quickExpire": {
  1758. "oneWeek": "Через неделю",
  1759. "oneMonth": "Через месяц",
  1760. "threeMonths": "Через 3 месяца",
  1761. "oneYear": "Через год"
  1762. },
  1763. "providerGroupSelect": {
  1764. "providersSuffix": "провайдеров",
  1765. "loadFailed": "Не удалось загрузить группы провайдеров"
  1766. },
  1767. "providerGroup": {
  1768. "label": "Группа провайдеров",
  1769. "placeholder": "Выберите группу провайдеров",
  1770. "noRestriction": "Без ограничений (все провайдеры)",
  1771. "providerCount": "{count} провайдеров"
  1772. },
  1773. "dangerZone": {
  1774. "title": "Опасная зона",
  1775. "description": "Следующие действия необратимы, действуйте с осторожностью",
  1776. "enable": {
  1777. "title": "Включить пользователя",
  1778. "description": "После включения этот пользователь и его ключи возобновят нормальную работу",
  1779. "trigger": "Включить",
  1780. "confirm": "Подтвердить включение",
  1781. "confirmDescription": "Вы уверены, что хотите включить пользователя \"{userName}\"?",
  1782. "loading": "Обработка..."
  1783. },
  1784. "disable": {
  1785. "title": "Отключить пользователя",
  1786. "description": "После отключения этот пользователь и его ключи больше не будут работать",
  1787. "trigger": "Отключить",
  1788. "confirm": "Подтвердить отключение",
  1789. "confirmDescription": "Вы уверены, что хотите отключить пользователя \"{userName}\"?",
  1790. "loading": "Обработка..."
  1791. },
  1792. "delete": {
  1793. "title": "Удалить пользователя",
  1794. "description": "Это удалит все связанные данные для этого пользователя, это действие необратимо",
  1795. "trigger": "Удалить",
  1796. "confirm": "Подтвердить удаление",
  1797. "confirmDescription": "Это действие удалит все связанные данные пользователя \"{userName}\" и не может быть отменено.",
  1798. "confirmLabel": "Вторичное подтверждение",
  1799. "confirmHint": "Пожалуйста, введите \"{userName}\" для подтверждения удаления",
  1800. "loading": "Удаление..."
  1801. },
  1802. "actions": {
  1803. "cancel": "Отмена"
  1804. },
  1805. "errors": {
  1806. "enableFailed": "Не удалось включить пользователя, попробуйте позже",
  1807. "disableFailed": "Не удалось отключить пользователя, попробуйте позже",
  1808. "deleteFailed": "Не удалось удалить пользователя, попробуйте позже"
  1809. }
  1810. },
  1811. "limitIndicator": {
  1812. "notSet": "Не задано",
  1813. "unlimited": "Без ограничений"
  1814. },
  1815. "keySettings": {
  1816. "balanceQueryPage": {
  1817. "label": "Включить отдельную страницу проверки баланса",
  1818. "description": "Разрешить пользователю просматривать баланс на отдельной странице",
  1819. "descriptionEnabled": "При включении этот ключ будет использовать независимую страницу личного использования при входе. Однако он не может изменять группу провайдеров собственного ключа.",
  1820. "descriptionDisabled": "При отключении пользователь не сможет получить доступ к странице личного использования. Вместо этого будет использоваться ограниченный Web UI."
  1821. },
  1822. "cacheTtlOverride": {
  1823. "label": "Переопределение Cache TTL",
  1824. "inherit": "Не переопределять (следовать провайдеру/клиенту)",
  1825. "5m": "5 минут",
  1826. "1h": "1 час"
  1827. }
  1828. },
  1829. "pagination": {
  1830. "previous": "Предыдущая",
  1831. "next": "Следующая",
  1832. "page": "Страница {current}",
  1833. "of": "из {total}"
  1834. },
  1835. "toolbar": {
  1836. "expandAll": "Развернуть все",
  1837. "collapseAll": "Свернуть все"
  1838. },
  1839. "keyStatus": {
  1840. "enabled": "Включён",
  1841. "disabled": "Отключён",
  1842. "active": "Активен",
  1843. "expired": "Истёк",
  1844. "expiringSoon": "Скоро истечёт",
  1845. "keyEnabled": "Ключ включён",
  1846. "keyDisabled": "Ключ отключён",
  1847. "toggleKeyStatus": "Переключить статус ключа",
  1848. "clickToDisableKey": "Нажмите, чтобы отключить ключ",
  1849. "clickToEnableKey": "Нажмите, чтобы включить ключ",
  1850. "operationFailed": "Операция не удалась",
  1851. "clickToQuickRenew": "Нажмите для быстрого продления"
  1852. },
  1853. "userStatus": {
  1854. "enabled": "Включён",
  1855. "disabled": "Отключён",
  1856. "active": "Активен",
  1857. "expired": "Истёк",
  1858. "expiringSoon": "Скоро истечёт",
  1859. "userEnabled": "Пользователь включён",
  1860. "userDisabled": "Пользователь отключён",
  1861. "toggleUserStatus": "Переключить статус пользователя",
  1862. "clickToDisableUser": "Нажмите, чтобы отключить пользователя",
  1863. "clickToEnableUser": "Нажмите, чтобы включить пользователя",
  1864. "operationFailed": "Операция не удалась",
  1865. "deleteFailed": "Не удалось удалить",
  1866. "deleteSuccess": "Удаление успешно",
  1867. "daysLeft": "{days, plural, =0 {Истекает сегодня} =1 {Остался 1 день} few {Осталось # дня} many {Осталось # дней} other {Осталось # дней}}"
  1868. },
  1869. "userEditSection": {
  1870. "sections": {
  1871. "basicInfo": "Основная информация",
  1872. "expireTime": "Срок действия",
  1873. "limitRules": "Правила лимитов",
  1874. "accessRestrictions": "Ограничения доступа"
  1875. },
  1876. "fields": {
  1877. "username": {
  1878. "label": "Имя пользователя",
  1879. "placeholder": "Введите имя пользователя"
  1880. },
  1881. "description": {
  1882. "label": "Заметка",
  1883. "placeholder": "Введите заметку (необязательно)",
  1884. "description": "Используется для описания назначения пользователя или примечаний"
  1885. },
  1886. "tags": {
  1887. "label": "Теги пользователя",
  1888. "placeholder": "Введите тег (Enter для добавления)"
  1889. },
  1890. "providerGroup": {
  1891. "label": "Группа провайдеров",
  1892. "placeholder": "default"
  1893. },
  1894. "allowedClients": {
  1895. "label": "Ограничения клиентов",
  1896. "description": "Ограничьте, какие CLI/IDE клиенты могут использовать эту учетную запись. Пусто = без ограничений.",
  1897. "customLabel": "Пользовательские шаблоны клиентов",
  1898. "customPlaceholder": "Введите шаблон (например, 'my-ide', 'codex-*')",
  1899. "customHelp": "Без '*': поиск подстроки без учёта регистра ('-' и '_' игнорируются). С '*': glob-шаблон от начала UA (используйте *foo* для поиска в любом месте; без учёта регистра, символы буквальные)."
  1900. },
  1901. "blockedClients": {
  1902. "label": "Заблокированные клиенты",
  1903. "description": "Клиенты, соответствующие этим шаблонам, будут отклонены, даже если они соответствуют разрешённым.",
  1904. "customLabel": "Пользовательский шаблон блокировки",
  1905. "customPlaceholder": "Введите шаблон (например, 'my-ide', 'codex-*')",
  1906. "customHelp": "Без '*': поиск подстроки без учёта регистра ('-' и '_' игнорируются). С '*': glob-шаблон от начала UA (используйте *foo* для поиска в любом месте; без учёта регистра, символы буквальные)."
  1907. },
  1908. "allowedModels": {
  1909. "label": "Ограничения моделей",
  1910. "placeholder": "Введите название модели или выберите из списка",
  1911. "description": "Ограничить AI модели для пользователя. Пусто = без ограничений."
  1912. },
  1913. "enableStatus": {
  1914. "label": "Статус включения",
  1915. "enabledDescription": "Сейчас включён. При отключении пользователь и его ключи станут недоступны.",
  1916. "disabledDescription": "Сейчас отключён. При включении пользователь и его ключи станут доступны.",
  1917. "confirmDisable": "Подтвердить отключение",
  1918. "confirmEnable": "Подтвердить включение",
  1919. "confirmEnableTitle": "Подтвердить включение пользователя",
  1920. "confirmDisableTitle": "Подтвердить отключение пользователя",
  1921. "confirmEnableDescription": "Включение позволит пользователю и его ключам работать в обычном режиме.",
  1922. "confirmDisableDescription": "Отключение сделает пользователя и его ключи недоступными.",
  1923. "cancel": "Отмена",
  1924. "processing": "Обработка..."
  1925. }
  1926. },
  1927. "actions": {
  1928. "allow": "Разрешить",
  1929. "block": "Блокировать"
  1930. },
  1931. "presetClients": {
  1932. "claude-cli": "Claude Code CLI",
  1933. "gemini-cli": "Gemini CLI",
  1934. "factory-cli": "Droid CLI",
  1935. "codex-cli": "Codex CLI",
  1936. "claude-code": "Claude Code (все)",
  1937. "claude-code-cli": "Claude Code CLI (точное обнаружение)",
  1938. "claude-code-cli-sdk": "Claude Code CLI SDK",
  1939. "claude-code-vscode": "Claude Code VSCode",
  1940. "claude-code-sdk-ts": "Claude Code SDK (TypeScript)",
  1941. "claude-code-sdk-py": "Claude Code SDK (Python)",
  1942. "claude-code-gh-action": "Claude Code GitHub Action"
  1943. },
  1944. "subClients": {
  1945. "all": "Все",
  1946. "cli": "CLI",
  1947. "vscode": "VS Code",
  1948. "sdk-ts": "SDK (TypeScript)",
  1949. "sdk-py": "SDK (Python)",
  1950. "cli-sdk": "CLI SDK",
  1951. "gh-action": "GitHub Action",
  1952. "codex-cli-core": "CLI / TUI",
  1953. "desktop": "Desktop",
  1954. "exec": "Exec"
  1955. },
  1956. "nSelected": "Выбрано: {count}"
  1957. },
  1958. "keyEditSection": {
  1959. "sections": {
  1960. "basicInfo": "Основная информация",
  1961. "expireTime": "Срок действия",
  1962. "limitRules": "Правила лимитов",
  1963. "specialFeatures": "Специальные функции"
  1964. },
  1965. "fields": {
  1966. "keyName": {
  1967. "label": "Название ключа",
  1968. "placeholder": "Введите название ключа"
  1969. },
  1970. "enableStatus": {
  1971. "label": "Статус включения",
  1972. "description": "Отключённые ключи не могут использоваться",
  1973. "cannotDisableTooltip": "Невозможно отключить последний активный ключ"
  1974. },
  1975. "balanceQueryPage": {
  1976. "label": "Независимая страница использования",
  1977. "description": "При включении этот ключ может использовать независимую страницу личного использования",
  1978. "descriptionEnabled": "При включении этот ключ будет использовать независимую страницу личного использования при входе. Однако он не может изменять группу провайдеров собственного ключа.",
  1979. "descriptionDisabled": "При отключении пользователь не сможет получить доступ к странице личного использования. Вместо этого будет использоваться ограниченный Web UI."
  1980. },
  1981. "providerGroup": {
  1982. "label": "Группа провайдеров",
  1983. "placeholder": "По умолчанию: default",
  1984. "selectHint": "Выберите группы провайдеров, доступные для этого ключа",
  1985. "editHint": "Группа провайдеров существующего ключа не может быть изменена",
  1986. "allGroups": "Использовать все группы",
  1987. "noGroupHint": "default включает провайдеров без groupTag."
  1988. },
  1989. "cacheTtl": {
  1990. "label": "Переопределение Cache TTL",
  1991. "description": "Принудительно установить Anthropic prompt cache TTL для запросов с cache_control.",
  1992. "options": {
  1993. "inherit": "Не переопределять (следовать провайдеру/клиенту)",
  1994. "5m": "5m",
  1995. "1h": "1h"
  1996. }
  1997. }
  1998. },
  1999. "limitRules": {
  2000. "title": "Добавить правило лимита",
  2001. "actions": {
  2002. "add": "Добавить правило",
  2003. "remove": "Удалить"
  2004. },
  2005. "daily": {
  2006. "mode": {
  2007. "fixed": "Сброс в фиксированное время",
  2008. "rolling": "Скользящее окно (24ч)"
  2009. }
  2010. },
  2011. "overwriteHint": "Этот тип уже существует, сохранение перезапишет существующее значение"
  2012. },
  2013. "accessRestrictions": {
  2014. "title": "Ограничения доступа",
  2015. "models": "Разрешённые модели",
  2016. "clients": "Разрешённые клиенты",
  2017. "noRestrictions": "Без ограничений",
  2018. "inheritedFromUser": "Унаследовано от настроек пользователя"
  2019. }
  2020. }
  2021. },
  2022. "webhookMigration": {
  2023. "title": "Обновление системы Webhook",
  2024. "description": "Мы запустили новую систему уведомлений Webhook с поддержкой многоцелевой доставки, независимой настройки и улучшенной надежности.",
  2025. "step1": {
  2026. "title": "Обнаружена устаревшая конфигурация Webhook",
  2027. "description": "Система обнаружила, что вы используете устаревшую конфигурацию Webhook. Новая система предлагает более мощные функции, рекомендуем выполнить миграцию."
  2028. },
  2029. "step2": {
  2030. "title": "Выберите тип платформы",
  2031. "description": "Следующие URL-адреса Webhook не удалось автоматически идентифицировать. Пожалуйста, выберите платформу вручную:"
  2032. },
  2033. "platformOptions": {
  2034. "wechat": "WeChat Work",
  2035. "feishu": "Feishu",
  2036. "dingtalk": "DingTalk",
  2037. "telegram": "Telegram",
  2038. "custom": "Пользовательский"
  2039. },
  2040. "migrateButton": "Начать миграцию",
  2041. "skipButton": "Позже",
  2042. "nextButton": "Далее",
  2043. "goToSettingsButton": "Перейти к настройкам",
  2044. "migrating": "Миграция...",
  2045. "success": "Миграция завершена",
  2046. "successDescription": "Ваша конфигурация Webhook успешно перенесена в новую систему.",
  2047. "error": "Ошибка миграции",
  2048. "errorGeneric": "Не удалось выполнить миграцию. Пожалуйста, попробуйте позже.",
  2049. "detectedWebhooks": "Обнаруженные Webhook",
  2050. "notificationTypes": {
  2051. "circuit_breaker": "Оповещение о размыкателе цепи",
  2052. "daily_leaderboard": "Ежедневный рейтинг",
  2053. "cost_alert": "Оповещение о стоимости"
  2054. },
  2055. "urlLabel": "URL Webhook",
  2056. "platformLabel": "Тип платформы",
  2057. "autoDetected": "Автоматически определено",
  2058. "selectPlatform": "Выберите платформу",
  2059. "successStats": "Создано {targets} целей, {bindings} привязок"
  2060. }
  2061. }