dashboard.json 68 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958
  1. {
  2. "actions": {
  3. "copy": "Copy",
  4. "download": "Download",
  5. "copied": "Copied"
  6. },
  7. "title": {
  8. "costRanking": "Cost Leaderboard",
  9. "costRankingDescription": "View user cost rankings, data updates every 5 minutes",
  10. "usageLogs": "Usage Logs",
  11. "usageLogsDescription": "View API call logs and usage statistics",
  12. "clients": "Clients",
  13. "userAndKeyManagement": "User and Key Management",
  14. "requestMessages": "Request Messages",
  15. "activeSessions": "Active Sessions (Last 5 Minutes)",
  16. "sessionMonitoring": "Session Monitoring",
  17. "sessionMonitoringDescription": "Real-time display of active and inactive sessions (auto-refresh every 3 seconds)",
  18. "inactiveSessions": "Inactive Sessions (Over 5 Minutes, View Only)",
  19. "quotasManagement": "Quotas",
  20. "quotasManagementDescription": "View and manage quotas at all levels",
  21. "usersQuotas": "User Quota Statistics",
  22. "keysQuotas": "Key Quota Statistics",
  23. "providersQuotas": "Provider Quota Statistics",
  24. "filterCriteria": "Filter Criteria",
  25. "filterCriteriaDescription": "Narrow down logs by time, user, provider, and more"
  26. },
  27. "description": {
  28. "viewApiCallLogs": "View API call logs and usage statistics",
  29. "dashboard": "View system statistics and monitoring information",
  30. "quotas": "View and manage quotas at all levels",
  31. "clientInfo": "User-Agent request header",
  32. "requestMessagesDescription": "Message content sent by the client",
  33. "responseBodyDescription": "Complete server response (5-minute TTL)"
  34. },
  35. "overview": {
  36. "title": "Overview",
  37. "totalRequests": "Total Requests",
  38. "totalCost": "Total Cost",
  39. "totalUsers": "Total Users",
  40. "totalProviders": "Total Providers",
  41. "activeUsers": "Active Users",
  42. "activeSessions": "Active Sessions",
  43. "errorRate": "Error Rate",
  44. "avgResponseTime": "Average Response Time"
  45. },
  46. "stats": {
  47. "title": "Statistics",
  48. "requests": "Requests",
  49. "cost": "Cost",
  50. "tokens": "Tokens",
  51. "period": {
  52. "hour": "Last Hour",
  53. "day": "Today",
  54. "week": "This Week",
  55. "month": "This Month"
  56. }
  57. },
  58. "logs": {
  59. "title": "Usage Logs",
  60. "description": "View and analyze API call records",
  61. "filters": {
  62. "user": "User",
  63. "provider": "Provider",
  64. "sessionId": "Session ID",
  65. "searchUser": "Search users...",
  66. "searchProvider": "Search providers...",
  67. "searchSessionId": "Search session IDs...",
  68. "noUserFound": "No matching users found",
  69. "noProviderFound": "No matching providers found",
  70. "noSessionFound": "No matching session IDs found",
  71. "model": "Model",
  72. "endpoint": "Endpoint",
  73. "status": "Status",
  74. "timeRange": "Time Range",
  75. "dateRange": "Date Range",
  76. "startTime": "Start Time",
  77. "endTime": "End Time",
  78. "allUsers": "All Users",
  79. "allKeys": "All Keys",
  80. "selectUserFirst": "Please select a user first",
  81. "allProviders": "All Providers",
  82. "allModels": "All Models",
  83. "allEndpoints": "All Endpoints",
  84. "allStatusCodes": "All Status Codes",
  85. "apiKey": "API Key",
  86. "statusCode": "Status Code",
  87. "minRetryCount": "Retry Count ≥",
  88. "minRetryCountPlaceholder": "Enter minimum retries",
  89. "apply": "Apply Filter",
  90. "reset": "Reset",
  91. "last7days": "7d",
  92. "last30days": "30d",
  93. "customRange": "Custom Range",
  94. "export": "Export",
  95. "exporting": "Exporting...",
  96. "exportSuccess": "Export completed successfully",
  97. "exportError": "Export failed",
  98. "quickFilters": {
  99. "today": "Today",
  100. "thisWeek": "This Week",
  101. "errorsOnly": "Errors Only",
  102. "showRetries": "With Retries"
  103. },
  104. "activeFilters": {
  105. "title": "Active Filters",
  106. "remove": "Remove filter",
  107. "clearAll": "Clear all"
  108. },
  109. "groups": {
  110. "time": "Time Range",
  111. "timeDesc": "Filter by date and time",
  112. "identity": "Identity",
  113. "identityDesc": "Filter by user and key",
  114. "request": "Request",
  115. "requestDesc": "Filter by provider, model, endpoint",
  116. "status": "Status",
  117. "statusDesc": "Filter by status code and retry"
  118. }
  119. },
  120. "columns": {
  121. "time": "Time",
  122. "user": "User",
  123. "key": "Key",
  124. "sessionId": "Session ID",
  125. "provider": "Provider",
  126. "model": "Billing Model",
  127. "endpoint": "Endpoint",
  128. "inputTokens": "Input",
  129. "outputTokens": "Output",
  130. "tokens": "Tokens",
  131. "cacheWrite": "Cache Write",
  132. "cacheRead": "Cache Read",
  133. "cache": "Cache",
  134. "cost": "Cost",
  135. "duration": "Duration",
  136. "performance": "Perf",
  137. "status": "Status"
  138. },
  139. "stats": {
  140. "title": "Statistics Summary",
  141. "description": "Aggregated statistics for the current filters",
  142. "totalRequests": "Total Requests",
  143. "totalAmount": "Total Consumption",
  144. "totalTokens": "Total Tokens",
  145. "cacheTokens": "Cached Tokens",
  146. "input": "Input",
  147. "output": "Output",
  148. "write": "Write",
  149. "read": "Read",
  150. "loading": "Loading..."
  151. },
  152. "table": {
  153. "noData": "No Data",
  154. "pagination": "Total {total} records, Page {page} / {totalPages}",
  155. "prevPage": "Previous Page",
  156. "nextPage": "Next Page",
  157. "blocked": "Blocked",
  158. "nonBilling": "Non-Billing",
  159. "skipped": "Skipped",
  160. "specialSettings": "Special",
  161. "times": "times",
  162. "loadedCount": "Loaded {count} records",
  163. "loadingMore": "Loading more...",
  164. "noMoreData": "All records loaded",
  165. "scrollToTop": "Back to top",
  166. "hideProviderColumn": "Hide Provider Column",
  167. "showProviderColumn": "Show Provider Column",
  168. "columnVisibility": "Column Visibility"
  169. },
  170. "actions": {
  171. "refresh": "Refresh",
  172. "refreshing": "Refreshing...",
  173. "stopAutoRefresh": "Stop Auto-Refresh",
  174. "startAutoRefresh": "Start Auto-Refresh",
  175. "view": "View",
  176. "fullscreen": "Fullscreen",
  177. "exitFullscreen": "Exit Fullscreen"
  178. },
  179. "error": {
  180. "loadFailed": "Load Failed",
  181. "loadKeysFailed": "Failed to load keys"
  182. },
  183. "details": {
  184. "title": "Request Details",
  185. "statusTitle": "Status: {status}",
  186. "inProgress": "In Progress",
  187. "unknown": "Unknown",
  188. "success": "Request completed successfully",
  189. "error": "Request failed, here are the detailed error messages and provider decision chain",
  190. "processing": "Request is in progress, not yet completed",
  191. "tabs": {
  192. "summary": "Summary",
  193. "logicTrace": "Logic Trace",
  194. "performance": "Performance",
  195. "metadata": "Metadata"
  196. },
  197. "summary": {
  198. "keyMetrics": "Key Metrics",
  199. "totalCost": "Total Cost",
  200. "totalTokens": "Total Tokens",
  201. "duration": "Duration",
  202. "outputRate": "Output Rate",
  203. "viewFullError": "View full error",
  204. "viewSession": "View Session"
  205. },
  206. "specialSettings": {
  207. "title": "Special settings"
  208. },
  209. "skipped": {
  210. "title": "Skipped",
  211. "reason": "Reason",
  212. "warmup": "Warmup Fast Response (CCH)",
  213. "desc": "This request was identified as a Warmup probe and was answered directly by CCH without forwarding to upstream providers; it is not billed, not rate-limited, and excluded from statistics."
  214. },
  215. "blocked": {
  216. "title": "Blocking Information",
  217. "type": "Blocking Type",
  218. "sensitiveWord": "Sensitive Word Blocking",
  219. "word": "Sensitive Word",
  220. "matchType": "Match Type",
  221. "matchTypeContains": "Contains Match",
  222. "matchTypeExact": "Exact Match",
  223. "matchTypeRegex": "Regular Expression",
  224. "matchedText": "Matched Content"
  225. },
  226. "sessionId": "Session ID",
  227. "messagesCount": "Message Count",
  228. "messagesLabel": "Messages",
  229. "messagesUnit": "items",
  230. "clientInfo": "Client Info",
  231. "modelRedirect": {
  232. "title": "Model Redirection",
  233. "requestModel": "Requested Model",
  234. "actualModel": "Actual Call",
  235. "billing": "Billing Description",
  236. "billingDescription": "The system prioritizes billing based on the price of the requested model ({original}). If the model is not found in the price list, the price of the actually called model ({current}) is used.",
  237. "billingModel": "Billing Model",
  238. "actualModelTooltip": "Actual Model: {model}",
  239. "originalModelTooltip": "Original Model: {model}",
  240. "billingDescription_original": "Current billing mode: Using original model before redirection ({original}) for billing",
  241. "billingDescription_redirected": "Current billing mode: Using actual model after redirection ({current}) for billing",
  242. "billingOriginal": "billing: original",
  243. "billingRedirected": "billing: redirected"
  244. },
  245. "errorMessage": "Error Message",
  246. "fake200ForwardedNotice": "Note: For streaming requests, this failure may be detected only after the stream ends; the response content may already have been forwarded to the client.",
  247. "fake200DetectedReason": "Detected reason: {reason}",
  248. "fake200Reasons": {
  249. "emptyBody": "Empty response body",
  250. "htmlBody": "HTML document returned (likely an error page)",
  251. "jsonErrorNonEmpty": "JSON has a non-empty `error` field",
  252. "jsonErrorMessageNonEmpty": "JSON has a non-empty `error.message`",
  253. "jsonMessageKeywordMatch": "JSON `message` contains the word \"error\" (heuristic)",
  254. "unknown": "Response body indicates an error"
  255. },
  256. "statusCodeInferredBadge": "Inferred",
  257. "statusCodeInferredTooltip": "This status code is inferred from response body content (e.g., fake 200) and may differ from the upstream HTTP status.",
  258. "statusCodeInferredSuffix": "(inferred)",
  259. "filteredProviders": "Filtered Providers",
  260. "providerChain": {
  261. "title": "Provider Decision Chain Timeline",
  262. "totalDuration": "Total Duration: {duration}ms"
  263. },
  264. "noError": {
  265. "processing": "Request is being processed, awaiting response...",
  266. "success": "Request successful, no error message",
  267. "default": "No detailed error message available"
  268. },
  269. "clickStatusCode": "Click status code to view full timeline",
  270. "viewDetails": "View Details",
  271. "reasons": {
  272. "rateLimited": "Provider Cost Limit",
  273. "circuitOpen": "Circuit Breaker Open"
  274. },
  275. "billingDetails": {
  276. "title": "Billing Details",
  277. "input": "Input",
  278. "output": "Output",
  279. "cacheWrite5m": "Cache Write (5m)",
  280. "cacheWrite1h": "Cache Write (1h)",
  281. "cacheRead": "Cache Read",
  282. "cacheTtl": "Cache TTL",
  283. "cacheTtlSwapped": "Billing TTL (swapped)",
  284. "multiplier": "Provider Multiplier",
  285. "totalCost": "Total Cost",
  286. "context1m": "1M Context",
  287. "context1mPricing": "Input 2x >200k, Output 1.5x >200k"
  288. },
  289. "performance": {
  290. "title": "Performance",
  291. "ttfb": "TTFB",
  292. "duration": "Total Duration",
  293. "outputRate": "Output Rate"
  294. },
  295. "performanceTab": {
  296. "noPerformanceData": "No performance data available",
  297. "ttfbGauge": "Time to First Byte",
  298. "outputRateGauge": "Output Rate",
  299. "latencyBreakdown": "Latency Breakdown",
  300. "generationTime": "Generation Time",
  301. "assessment": {
  302. "excellent": "Excellent",
  303. "good": "Good",
  304. "warning": "Warning",
  305. "poor": "Poor"
  306. },
  307. "thresholds": {
  308. "ttfbGood": "TTFB < 1s",
  309. "ttfbWarning": "TTFB 1-2s",
  310. "ttfbPoor": "TTFB > 3s"
  311. }
  312. },
  313. "metadata": {
  314. "noMetadata": "No metadata available",
  315. "sessionInfo": "Session Info",
  316. "clientInfo": "Client Info",
  317. "billingInfo": "Billing Info",
  318. "technicalTimeline": "Technical Timeline",
  319. "copyTimeline": "Copy Timeline"
  320. },
  321. "logicTrace": {
  322. "title": "Decision Chain",
  323. "noDecisionData": "No decision data available",
  324. "providersCount": "{count} providers",
  325. "healthyCount": "{count} healthy",
  326. "initialSelection": "Initial Selection",
  327. "healthCheck": "Health Check",
  328. "prioritySelection": "Priority Selection",
  329. "attemptProvider": "Attempt: {provider}",
  330. "retryAttempt": "Retry #{number}",
  331. "httpStatus": "HTTP {code}{inferredSuffix}",
  332. "sessionReuse": "Session Reuse",
  333. "sessionReuseDesc": "Reusing provider from session cache",
  334. "sessionReuseTitle": "Session Binding",
  335. "sessionReuseSelection": "Session Reuse Selection",
  336. "sessionReuseSelectionDesc": "Provider selected from session cache",
  337. "sessionInfo": "Session Information",
  338. "sessionIdLabel": "Session ID",
  339. "requestSequence": "Request Sequence",
  340. "sessionAge": "Session Age",
  341. "reusedProvider": "Reused Provider",
  342. "executeRequest": "Execute Request",
  343. "cacheOptimizationHint": "Session reuse optimizes performance by maintaining provider affinity within the same conversation, reducing selection overhead and improving cache hit rates.",
  344. "originDecisionTitle": "Original Selection Decision",
  345. "originDecisionDesc": "How this provider was initially chosen for this session",
  346. "originDecisionLoading": "Loading original decision...",
  347. "originDecisionUnavailable": "Original decision record unavailable",
  348. "originDecisionExpand": "View original selection"
  349. }
  350. },
  351. "providerChain": {
  352. "decisionChain": "Provider Decision Chain",
  353. "clickItemForDetails": "Click a step to view details"
  354. },
  355. "modelRedirect": {
  356. "redirected": "Redirected",
  357. "targetModel": "Target Model"
  358. },
  359. "statusCodes": {
  360. "not200": "Non-200 (errors/blocked)",
  361. "200": "200 (Success)",
  362. "400": "400 (Bad Request)",
  363. "401": "401 (Unauthorized)",
  364. "429": "429 (Rate Limited)",
  365. "500": "500 (Server Error)"
  366. },
  367. "billingDetails": {
  368. "input": "Input",
  369. "output": "Output",
  370. "cacheWrite5m": "Cache Write (5m)",
  371. "cacheWrite1h": "Cache Write (1h)",
  372. "cacheRead": "Cache Read",
  373. "cacheTtl": "Cache TTL",
  374. "cacheTtlSwapped": "Billing TTL (swapped)",
  375. "multiplier": "Provider Multiplier",
  376. "totalCost": "Total Cost",
  377. "context1m": "1M Context",
  378. "context1mPricing": "Input 2x >200k, Output 1.5x >200k"
  379. }
  380. },
  381. "leaderboard": {
  382. "title": "Cost Leaderboard",
  383. "description": "View cost statistics rankings for users and keys",
  384. "todayTitle": "Today's Leaderboard",
  385. "viewAll": "View All",
  386. "userRankings": "User Rankings",
  387. "providerRankings": "Provider Rankings",
  388. "modelRankings": "Model Rankings",
  389. "noData": "No data for today",
  390. "requests": "requests",
  391. "tokens": "tokens",
  392. "tabs": {
  393. "users": "User Rankings",
  394. "keys": "Key Rankings",
  395. "userRanking": "User Rankings",
  396. "providerRanking": "Provider Rankings",
  397. "providerCacheHitRateRanking": "Provider Cache Hit Rate",
  398. "modelRanking": "Model Rankings",
  399. "dailyRanking": "Today",
  400. "weeklyRanking": "This Week",
  401. "monthlyRanking": "This Month",
  402. "allTimeRanking": "All Time"
  403. },
  404. "dateRange": {
  405. "to": "to",
  406. "prevPeriod": "Previous period",
  407. "nextPeriod": "Next period",
  408. "customRange": "Custom date range"
  409. },
  410. "columns": {
  411. "rank": "Rank",
  412. "name": "Name",
  413. "totalCost": "Total Cost",
  414. "totalRequests": "Total Requests",
  415. "avgCost": "Average Cost",
  416. "lastActive": "Last Active",
  417. "user": "User",
  418. "requests": "Requests",
  419. "tokens": "Tokens",
  420. "consumedAmount": "Consumed Amount",
  421. "provider": "Provider",
  422. "model": "Model",
  423. "cost": "Cost",
  424. "cacheHitRequests": "Cache-eligible Requests",
  425. "cacheHitRate": "Cache Hit Rate",
  426. "cacheReadTokens": "Cache Read Tokens",
  427. "totalTokens": "Total Tokens",
  428. "cacheCreationConsumedAmount": "Cache Creation Spend",
  429. "totalConsumedAmount": "Total Spend",
  430. "successRate": "Success Rate",
  431. "avgResponseTime": "Avg Response Time",
  432. "avgTtfbMs": "Avg TTFB",
  433. "avgTokensPerSecond": "Avg tok/s",
  434. "avgCostPerRequest": "Avg Cost/Req",
  435. "avgCostPerMillionTokens": "Avg Cost/1M Tokens"
  436. },
  437. "expandModelStats": "Expand model details",
  438. "collapseModelStats": "Collapse model details",
  439. "states": {
  440. "loading": "Loading...",
  441. "noData": "No data available",
  442. "todayNoData": "No data available for today",
  443. "weekNoData": "No data available for this week",
  444. "monthNoData": "No data available for this month",
  445. "fetchFailed": "Failed to fetch leaderboard data"
  446. },
  447. "permission": {
  448. "title": "Permission Required",
  449. "restricted": "Access Restricted",
  450. "description": "The leaderboard feature requires administrators to enable the \"Allow Global Usage View\" permission.",
  451. "adminAction": "Enable this permission.",
  452. "userAction": "Please contact an administrator to enable this permission.",
  453. "systemSettings": "System Settings"
  454. },
  455. "filters": {
  456. "userTagsPlaceholder": "Filter by user tags...",
  457. "userGroupsPlaceholder": "Filter by user groups..."
  458. }
  459. },
  460. "sessions": {
  461. "title": "Active Sessions",
  462. "description": "Monitor current active API sessions in real-time",
  463. "monitoring": "Session Monitoring",
  464. "monitoringDescription": "Real-time display of active and inactive sessions (auto-refresh every 3 seconds)",
  465. "activeSessions": "Active Sessions (Last 5 Minutes)",
  466. "inactiveSessions": "Inactive Sessions (Over 5 Minutes, View Only)",
  467. "columns": {
  468. "sessionId": "Session ID",
  469. "user": "User",
  470. "key": "Key",
  471. "provider": "Provider",
  472. "model": "Model",
  473. "startTime": "Start Time",
  474. "lastActivity": "Last Activity",
  475. "requestCount": "Requests",
  476. "totalInput": "Total Input",
  477. "totalOutput": "Total Output",
  478. "totalCost": "Total Cost",
  479. "totalDuration": "Total Duration",
  480. "status": "Status",
  481. "actions": "Actions"
  482. },
  483. "table": {
  484. "count": "Total {count} {type} Sessions",
  485. "active": "Active",
  486. "inactive": "Inactive",
  487. "notCountedInConcurrency": "(Not counted in concurrency)",
  488. "refreshing": "Refreshing...",
  489. "noActiveSessions": "No active sessions"
  490. },
  491. "pagination": {
  492. "total": "total"
  493. },
  494. "details": {
  495. "title": "Session Messages",
  496. "messages": "Messages",
  497. "info": "Session Info",
  498. "timeline": "Timeline",
  499. "overview": "Session Overview",
  500. "overviewDescription": "Aggregated statistics",
  501. "providersAndModels": "Providers & Models",
  502. "providersAndModelsDescription": "Providers and models used",
  503. "tokenUsage": "Token Usage (Total)",
  504. "tokenUsageDescription": "Cumulative statistics for all requests",
  505. "costInfo": "Cost Information (Total)",
  506. "costInfoDescription": "Cumulative cost for all requests",
  507. "totalRequests": "Total Requests",
  508. "firstRequest": "First Request",
  509. "lastRequest": "Last Request",
  510. "totalDuration": "Total Duration",
  511. "totalInput": "Total Input",
  512. "totalOutput": "Total Output",
  513. "cacheCreation": "Cache Creation",
  514. "cacheTtlMixed": "Mixed",
  515. "cacheRead": "Cache Read",
  516. "total": "Total",
  517. "totalFee": "Total Fee",
  518. "providers": "Providers",
  519. "models": "Models",
  520. "noDetailedData": "No detailed data available",
  521. "storageTip": "No detailed data found. Possible reasons: Redis is disabled/unavailable (REDIS_URL + ENABLE_RATE_LIMIT=true), the data expired (SESSION_TTL, default 300s), or response body storage is disabled (STORE_SESSION_RESPONSE_BODY=false, affects response body only). To store unredacted messages, set STORE_SESSION_MESSAGES=true.",
  522. "clientInfo": "Client Info",
  523. "requestHeaders": "Request Headers",
  524. "requestBody": "Request Body",
  525. "requestMessages": "Request Messages",
  526. "specialSettings": "Special",
  527. "requestMessagesDescription": "Message content sent by the client",
  528. "responseHeaders": "Response Headers",
  529. "responseBody": "Response Body",
  530. "responseBodyDescription": "Complete server response (5-minute TTL)",
  531. "noHeaders": "No data",
  532. "noData": "No Data",
  533. "prevRequest": "Previous",
  534. "nextRequest": "Next"
  535. },
  536. "actions": {
  537. "back": "Back",
  538. "view": "View",
  539. "copy": "Copy",
  540. "download": "Download",
  541. "copyMessages": "Copy Request (Headers + Body)",
  542. "downloadMessages": "Download Request (Headers + Body)",
  543. "copied": "Copied",
  544. "copyResponse": "Copy Response",
  545. "terminate": "Terminate",
  546. "terminateTitle": "Terminate Session",
  547. "terminateDescription": "Are you sure you want to terminate this session? After termination, the provider binding for this session will be cleared, and the next request will reselect a provider.",
  548. "sessionIdLabel": "Session ID: {sessionId}",
  549. "cancel": "Cancel",
  550. "confirmTerminate": "Confirm Termination",
  551. "terminating": "Terminating...",
  552. "terminateSuccess": "Session terminated successfully",
  553. "terminateFailed": "Failed to terminate session",
  554. "terminateSelected": "Terminate Selected",
  555. "selectedCount": "{count} selected",
  556. "selectAll": "Select All",
  557. "selectSessionLabel": "Select session",
  558. "multiSelect": "Multi Select",
  559. "cancelMultiSelect": "Cancel",
  560. "terminateSessionTitle": "Terminate Session",
  561. "terminateSessionDescription": "Are you sure you want to terminate this session? This action cannot be undone.",
  562. "batchTerminateSuccess": "Terminated {count} session(s)",
  563. "batchTerminatePartial": "Unauthorized: {unauthorized} · Missing: {missing}",
  564. "batchTerminateAllowedFailed": "Failed to terminate {count} authorized session(s)",
  565. "batchTerminateNone": "No sessions were terminated",
  566. "noSelection": "Please select at least one session"
  567. },
  568. "codeDisplay": {
  569. "raw": "Raw",
  570. "pretty": "Pretty",
  571. "searchPlaceholder": "Search",
  572. "expand": "Expand",
  573. "collapse": "Collapse",
  574. "themeAuto": "Auto",
  575. "themeLight": "Light",
  576. "themeDark": "Dark",
  577. "noMatches": "No matches",
  578. "onlyMatches": "Only matches",
  579. "showAll": "Show all",
  580. "prevPage": "Prev",
  581. "nextPage": "Next",
  582. "pageInfo": "Page {page} / {total}",
  583. "sseEvent": "Event",
  584. "sseData": "Data",
  585. "hardLimit": {
  586. "title": "Content too large",
  587. "size": "Size: {sizeMB} MB ({sizeBytes} bytes)",
  588. "maximum": "Maximum allowed: {maxSizeMB} MB or {maxLines} lines",
  589. "hint": "Please download the file to view the full content.",
  590. "download": "Download"
  591. }
  592. },
  593. "status": {
  594. "loading": "Loading...",
  595. "loadError": "Load failed",
  596. "fetchFailed": "Fetch Failed",
  597. "unknownError": "Unknown Error",
  598. "storageNotEnabled": "Not Stored",
  599. "storageNotEnabledHint": "Tip: Check REDIS_URL and ENABLE_RATE_LIMIT=true (session details cache). To store unredacted messages, set STORE_SESSION_MESSAGES=true."
  600. },
  601. "errors": {
  602. "copyFailed": "Copy Failed"
  603. },
  604. "requestList": {
  605. "title": "Requests",
  606. "noRequests": "No requests found",
  607. "fetchFailed": "Failed to fetch requests",
  608. "unknownError": "Unknown error occurred",
  609. "prev": "Prev",
  610. "next": "Next",
  611. "orderAsc": "Switch to ascending order (oldest first)",
  612. "orderDesc": "Switch to descending order (newest first)"
  613. },
  614. "back": "Back",
  615. "loadingError": "Loading failed"
  616. },
  617. "quotas": {
  618. "title": "Quota Management",
  619. "description": "Manage user, key, and provider usage quotas",
  620. "tabs": {
  621. "overview": "Overview",
  622. "users": "User Quotas",
  623. "keys": "Key Quotas",
  624. "providers": "Provider Quotas"
  625. },
  626. "columns": {
  627. "name": "Name",
  628. "limit": "Limit",
  629. "used": "Used",
  630. "remaining": "Remaining",
  631. "resetTime": "Reset Time",
  632. "status": "Status"
  633. },
  634. "labels": {
  635. "byName": "By Name",
  636. "byUsageRate": "By Usage Rate",
  637. "all": "All",
  638. "warning": "Near Limit (>60%)",
  639. "exceeded": "Exceeded (≥100%)"
  640. },
  641. "users": {
  642. "title": "User Quota Statistics",
  643. "totalUsers": "Total {count} users"
  644. },
  645. "keys": {
  646. "title": "Key Quota Statistics",
  647. "totalKeysInfo": "Total {userCount} users, {keyCount} keys",
  648. "setKeyQuota": "Set Key Quota",
  649. "setUserQuota": "Set User Quota",
  650. "onlyKeyQuota": "Key Quota Only",
  651. "onlyUserQuota": "User Quota Only",
  652. "success": "User quota set successfully"
  653. },
  654. "providers": {
  655. "title": "Provider Quota Statistics",
  656. "totalProviders": "Total {count} providers"
  657. }
  658. },
  659. "labels": {
  660. "byName": "By Name",
  661. "byUsageRate": "By Usage Rate"
  662. },
  663. "nav": {
  664. "mobileMenuTitle": "Navigation Menu",
  665. "dashboard": "Dashboard",
  666. "usageLogs": "Usage Logs",
  667. "leaderboard": "Leaderboard",
  668. "availability": "Availability",
  669. "myQuota": "My Quota",
  670. "quotasManagement": "Quotas",
  671. "userManagement": "Users",
  672. "providers": "Providers",
  673. "documentation": "Docs",
  674. "systemSettings": "Settings",
  675. "feedback": "Feedback",
  676. "login": "Login",
  677. "logout": "Logout"
  678. },
  679. "statistics": {
  680. "title": "Usage Statistics",
  681. "cost": "Consumption Amount",
  682. "calls": "API Calls",
  683. "totalCost": "Total Consumption Amount",
  684. "totalCalls": "Total API Calls",
  685. "timeRange": {
  686. "today": "Today",
  687. "todayDescription": "Today's usage",
  688. "7days": "Last 7 Days",
  689. "7daysDescription": "Usage for the last 7 days",
  690. "30days": "Last 30 Days",
  691. "30daysDescription": "Usage for the last 30 days",
  692. "thisMonth": "This Month",
  693. "thisMonthDescription": "Usage for this month",
  694. "default": "Usage"
  695. },
  696. "mode": {
  697. "keys": "Only display usage statistics for your keys",
  698. "mixed": "Display your key details and aggregated data from other users",
  699. "users": "Display usage statistics for all users"
  700. },
  701. "legend": {
  702. "selectAll": "Select All",
  703. "deselectAll": "Clear",
  704. "selected": "Selected"
  705. },
  706. "chartMode": {
  707. "label": "Display Mode",
  708. "overlay": "Overlay",
  709. "stacked": "Stacked"
  710. },
  711. "states": {
  712. "noData": "No statistics data available",
  713. "fetchFailed": "Failed to fetch statistics"
  714. },
  715. "othersAggregate": "Other Users"
  716. },
  717. "errors": {
  718. "fetchSystemSettingsFailed": "Failed to fetch system settings",
  719. "fetchFailed": "Fetch failed",
  720. "fetchSessionListFailed": "Failed to fetch session list"
  721. },
  722. "keyList": {
  723. "columns": {
  724. "name": "Name",
  725. "key": "Key",
  726. "todayCalls": "Today's Calls",
  727. "todayCost": "Today's Cost",
  728. "lastUsed": "Last Used",
  729. "actions": "Actions"
  730. },
  731. "detailsButton": "Details",
  732. "modelStats": "Model Statistics",
  733. "modelStatsColumns": {
  734. "model": "Model",
  735. "calls": "Calls",
  736. "cost": "Cost"
  737. },
  738. "limitUsage": "Limit Usage",
  739. "copyKeyTooltip": "Copy full key",
  740. "showKeyTooltip": "Show full key",
  741. "hideKeyTooltip": "Hide key",
  742. "copyFailed": "Copy failed:",
  743. "timesUnit": "times",
  744. "provider": "Provider",
  745. "neverUsed": "Never used",
  746. "viewLogsTooltip": "View detailed logs",
  747. "logsButton": "Logs",
  748. "emptyState": {
  749. "title": "No Keys",
  750. "description": "Click the \"Add Key\" button in the top right corner to add a key"
  751. }
  752. },
  753. "userList": {
  754. "title": "User List",
  755. "badge": "{count} Keys",
  756. "activeKeys": "Active Keys",
  757. "totalKeys": "Total Keys",
  758. "expiresAt": "Expiration",
  759. "status": {
  760. "active": "Active",
  761. "expiringSoon": "Expiring Soon",
  762. "expired": "Expired",
  763. "disabled": "Disabled"
  764. },
  765. "actions": {
  766. "renew": "Renew",
  767. "renew30d": "Renew for 30 days",
  768. "renew90d": "Renew for 90 days",
  769. "renew1y": "Renew for 1 year",
  770. "renewCustom": "Custom...",
  771. "customRenewTitle": "Custom Renewal",
  772. "customRenewDescription": "Set a new expiration date for user {userName}",
  773. "expirationDate": "Expiration Date",
  774. "enableOnRenew": "Enable user on renewal",
  775. "cancel": "Cancel",
  776. "confirm": "Confirm",
  777. "customPrompt": "Enter a new expiry date (YYYY-MM-DD). Leave empty to cancel.",
  778. "invalidDate": "Please enter a valid date",
  779. "enable": "Enable",
  780. "disable": "Disable",
  781. "success": "Operation succeeded",
  782. "failed": "Operation failed, please try again"
  783. },
  784. "emptyState": {
  785. "title": "No Users",
  786. "description": "You haven't created any users yet. Users are the foundation for managing API keys and usage quotas. Create your first user to get started!",
  787. "action": "Create Your First User"
  788. },
  789. "addUser": "Add User"
  790. },
  791. "keyListHeader": {
  792. "todayUsage": "Today's Usage",
  793. "allowedModels": {
  794. "label": "Allowed Models",
  795. "noRestrictions": "Allowed Models: No restrictions"
  796. },
  797. "expiresAt": "Expires",
  798. "proxyStatus": {
  799. "loading": "Loading proxy status",
  800. "fetchFailed": "Failed to fetch proxy status",
  801. "noStatus": "No proxy status",
  802. "activeRequests": "Active Requests",
  803. "lastRequest": "Last Request",
  804. "noRecord": "No record",
  805. "timeAgo": {
  806. "justNow": "Just now",
  807. "secondsAgo": "{count}s ago",
  808. "minutesAgo": "{count} min ago",
  809. "hoursAgo": "{count}h ago",
  810. "daysAgo": "{count}d ago"
  811. }
  812. },
  813. "addKey": "Add Key",
  814. "keyCreatedDialog": {
  815. "title": "Key Created Successfully",
  816. "description": "Your API key has been created successfully. Please copy and save it securely, as it will only be displayed once.",
  817. "apiKeyLabel": "API Key",
  818. "warningText": "Please copy and save before closing. You will not be able to view this key again after closing.",
  819. "httpWarningText": "HTTP access detected. Browser restrictions prevent clipboard access. Click the eye icon to reveal the key and copy manually.",
  820. "copyTooltip": "Copy to clipboard",
  821. "showTooltip": "Show full key",
  822. "hideTooltip": "Hide key",
  823. "closeButton": "Close"
  824. },
  825. "allowedClients": {
  826. "label": "Clients allowed",
  827. "noRestrictions": "Clients allowed: no restrictions"
  828. }
  829. },
  830. "keyLimitUsage": {
  831. "loading": "Loading...",
  832. "error": "Fetch failed",
  833. "networkError": "Network error",
  834. "cost5h": "5-Hour Cost",
  835. "costDaily": "Daily Cost",
  836. "costWeekly": "Weekly Cost",
  837. "costMonthly": "Monthly Cost",
  838. "costTotal": "Total Cost",
  839. "concurrentSessions": "Concurrent Sessions",
  840. "noLimit": "No quota limits"
  841. },
  842. "addKeyForm": {
  843. "title": "Add Key",
  844. "description": "Create a new API key for the current user. The key value will be auto-generated.",
  845. "submitText": "Create Key",
  846. "loadingText": "Creating...",
  847. "keyName": {
  848. "label": "Key Name",
  849. "placeholder": "Enter key name"
  850. },
  851. "expiresAt": {
  852. "label": "Expiration Time",
  853. "placeholder": "Select expiration time",
  854. "description": "Leave blank for never expires"
  855. },
  856. "canLoginWebUi": {
  857. "label": "Allow Web UI Login",
  858. "description": "When disabled, this key can only be used for API calls and cannot login to the admin panel"
  859. },
  860. "limit5hUsd": {
  861. "label": "5-Hour Cost Limit (USD)",
  862. "placeholder": "Leave blank for unlimited",
  863. "description": "Maximum cost within 5 hours",
  864. "descriptionWithUserLimit": "Maximum cost within 5 hours (User limit: {limit})"
  865. },
  866. "limitDailyUsd": {
  867. "label": "Daily Cost Limit (USD)",
  868. "placeholder": "Leave blank for unlimited",
  869. "description": "Maximum cost per day"
  870. },
  871. "dailyResetMode": {
  872. "label": "Daily Reset Mode",
  873. "options": {
  874. "fixed": "Fixed Time Reset",
  875. "rolling": "Rolling Window (24h)"
  876. },
  877. "desc": {
  878. "fixed": "Reset quota at a specific time each day",
  879. "rolling": "24-hour rolling window from first request"
  880. }
  881. },
  882. "dailyResetTime": {
  883. "label": "Daily Reset Time",
  884. "placeholder": "HH:mm",
  885. "description": "When the daily limit resets (uses system timezone)"
  886. },
  887. "limitWeeklyUsd": {
  888. "label": "Weekly Cost Limit (USD)",
  889. "placeholder": "Leave blank for unlimited",
  890. "description": "Maximum cost per week",
  891. "descriptionWithUserLimit": "Maximum cost per week (User limit: {limit})"
  892. },
  893. "limitMonthlyUsd": {
  894. "label": "Monthly Cost Limit (USD)",
  895. "placeholder": "Leave blank for unlimited",
  896. "description": "Maximum cost per month",
  897. "descriptionWithUserLimit": "Maximum cost per month (User limit: {limit})"
  898. },
  899. "limitTotalUsd": {
  900. "label": "Total Cost Limit (USD)",
  901. "placeholder": "Leave blank for unlimited",
  902. "description": "Maximum cumulative spending (no reset)",
  903. "descriptionWithUserLimit": "Cannot exceed user total limit ({limit})"
  904. },
  905. "limitConcurrentSessions": {
  906. "label": "Concurrent Session Limit",
  907. "placeholder": "0 means unlimited",
  908. "description": "Number of simultaneous conversations",
  909. "descriptionWithUserLimit": "Maximum sessions (User limit: {limit})"
  910. },
  911. "providerGroup": {
  912. "label": "Provider Group",
  913. "placeholder": "Enter provider group tags, press Enter to add",
  914. "description": "Provider groups for this key (default: default).",
  915. "defaultDescription": "default includes providers without groupTag.",
  916. "descriptionWithUserGroup": "Provider groups for this key (user groups: {group}; default: default)."
  917. },
  918. "cacheTtl": {
  919. "label": "Cache TTL Override",
  920. "description": "Force Anthropic prompt cache TTL for requests containing cache_control.",
  921. "options": {
  922. "inherit": "No override (follow provider/client)",
  923. "5m": "5m",
  924. "1h": "1h"
  925. }
  926. },
  927. "successTitle": "Key Created Successfully",
  928. "successDescription": "Your API key has been created successfully.",
  929. "generatedKey": {
  930. "label": "Generated Key",
  931. "hint": "You can manage this key in the key list (enable/disable, quotas, etc.), but the full key is only shown once. Copy it now."
  932. },
  933. "errors": {
  934. "userIdMissing": "User ID does not exist",
  935. "createFailed": "Failed to create, please try again later",
  936. "noKeyReturned": "Created successfully but key was not returned"
  937. }
  938. },
  939. "userForm": {
  940. "title": {
  941. "add": "Add User",
  942. "edit": "Edit User"
  943. },
  944. "description": {
  945. "add": "Create a new user. The system will automatically generate a default key.",
  946. "edit": "Modify user's basic information."
  947. },
  948. "submitText": {
  949. "add": "Create User",
  950. "edit": "Save Changes"
  951. },
  952. "loadingText": {
  953. "add": "Creating...",
  954. "edit": "Saving..."
  955. },
  956. "username": {
  957. "label": "Username",
  958. "placeholder": "Enter username"
  959. },
  960. "note": {
  961. "label": "Note",
  962. "placeholder": "Enter note (optional)",
  963. "description": "Used to describe the user's purpose or notes"
  964. },
  965. "providerGroup": {
  966. "label": "Provider Group",
  967. "placeholder": "e.g., default or premium,economy",
  968. "description": "User provider groups (default: default). Providers without groupTag belong to default."
  969. },
  970. "tags": {
  971. "label": "User Tags",
  972. "placeholder": "Enter tag (press Enter to add)",
  973. "description": "Add tags for categorization and filtering (max 20 tags, 32 characters each)"
  974. },
  975. "rpm": {
  976. "label": "RPM Limit",
  977. "placeholder": "Requests per minute limit",
  978. "description": "Default: {default}, Range: 1-10000"
  979. },
  980. "dailyQuota": {
  981. "label": "Daily Quota",
  982. "placeholder": "Daily consumption quota limit",
  983. "helperText": "Set to 0 for unlimited",
  984. "description": "Default: ${default}, Range: $0.01-$1000"
  985. },
  986. "limit5hUsd": {
  987. "label": "5-Hour Quota (USD)",
  988. "placeholder": "Leave empty for unlimited",
  989. "description": "Maximum spending in 5 hours"
  990. },
  991. "limitWeeklyUsd": {
  992. "label": "Weekly Quota (USD)",
  993. "placeholder": "Leave empty for unlimited",
  994. "description": "Maximum weekly spending"
  995. },
  996. "limitMonthlyUsd": {
  997. "label": "Monthly Quota (USD)",
  998. "placeholder": "Leave empty for unlimited",
  999. "description": "Maximum monthly spending"
  1000. },
  1001. "limitTotalUsd": {
  1002. "label": "Total Quota (USD)",
  1003. "placeholder": "Leave empty for unlimited",
  1004. "description": "Maximum lifetime spending"
  1005. },
  1006. "limitConcurrentSessions": {
  1007. "label": "Concurrent Sessions Limit",
  1008. "placeholder": "0 means unlimited",
  1009. "description": "Number of simultaneous conversations"
  1010. },
  1011. "isEnabled": {
  1012. "label": "Enable User",
  1013. "description": "Disabled users cannot access the API"
  1014. },
  1015. "expiresAt": {
  1016. "label": "Expiration Date",
  1017. "placeholder": "Leave empty for never expires",
  1018. "description": "User will be automatically disabled after expiration",
  1019. "pastWarning": "Selected date is in the past. The user will expire and be disabled immediately after saving."
  1020. },
  1021. "allowedClients": {
  1022. "label": "Allowed Clients",
  1023. "description": "Restrict which CLI/IDE clients can use this account. Leave empty for no restrictions.",
  1024. "customLabel": "Custom Client Patterns",
  1025. "customPlaceholder": "Enter custom pattern (e.g., 'xcode', 'my-ide')"
  1026. },
  1027. "allowedModels": {
  1028. "label": "Allowed Models",
  1029. "placeholder": "Enter model name (press Enter to add)",
  1030. "description": "Restrict this user to specific AI models. Leave empty for no restrictions (max 50 models, 64 chars each)"
  1031. }
  1032. },
  1033. "deleteKeyConfirm": {
  1034. "title": "Confirm Delete Key",
  1035. "description": "Are you sure you want to delete key \"{name}\"?\n{maskedKey}\nThis action cannot be undone. All applications using this key will lose access.",
  1036. "cancel": "Cancel",
  1037. "confirm": "Confirm Delete",
  1038. "confirmLoading": "Deleting...",
  1039. "errors": {
  1040. "deleteFailed": "Delete failed",
  1041. "retryError": "Delete failed, please try again later"
  1042. }
  1043. },
  1044. "keyActions": {
  1045. "edit": "Edit",
  1046. "delete": "Delete",
  1047. "editAriaLabel": "Edit key",
  1048. "deleteAriaLabel": "Delete key"
  1049. },
  1050. "userActions": {
  1051. "edit": "Edit user",
  1052. "delete": "Delete user",
  1053. "editAriaLabel": "Edit user",
  1054. "deleteAriaLabel": "Delete user"
  1055. },
  1056. "availability": {
  1057. "title": "Provider Availability Monitor",
  1058. "description": "Real-time monitoring of provider availability and performance metrics",
  1059. "nav": "Availability Monitor",
  1060. "tabs": {
  1061. "provider": "Provider Availability",
  1062. "endpoint": "Endpoint Health"
  1063. },
  1064. "overview": {
  1065. "systemAvailability": "System Availability",
  1066. "avgLatency": "Avg Latency",
  1067. "errorRate": "Error Rate",
  1068. "activeProbes": "Active Probes",
  1069. "load": "Load"
  1070. },
  1071. "status": {
  1072. "green": "Healthy",
  1073. "red": "Unhealthy",
  1074. "unknown": "Unknown"
  1075. },
  1076. "statusDescription": {
  1077. "green": "Service is healthy, requests successful",
  1078. "red": "Service unavailable or error",
  1079. "unknown": "No data available"
  1080. },
  1081. "metrics": {
  1082. "systemAvailability": "System Availability",
  1083. "totalRequests": "Total Requests",
  1084. "successRate": "Success Rate",
  1085. "avgLatency": "Avg Latency",
  1086. "p50Latency": "P50 Latency",
  1087. "p95Latency": "P95 Latency",
  1088. "p99Latency": "P99 Latency",
  1089. "lastRequest": "Last Request",
  1090. "requestCount": "Request Count"
  1091. },
  1092. "timeRange": {
  1093. "label": "Time Range",
  1094. "15min": "15 min",
  1095. "1h": "1 hour",
  1096. "6h": "6 hours",
  1097. "24h": "24 hours",
  1098. "7d": "7 days",
  1099. "last15min": "Last 15 minutes",
  1100. "last1h": "Last 1 hour",
  1101. "last6h": "Last 6 hours",
  1102. "last24h": "Last 24 hours",
  1103. "last7d": "Last 7 days",
  1104. "custom": "Custom"
  1105. },
  1106. "filters": {
  1107. "provider": "Provider",
  1108. "allProviders": "All Providers",
  1109. "includeDisabled": "Include Disabled"
  1110. },
  1111. "sort": {
  1112. "label": "Sort By",
  1113. "availability": "Availability",
  1114. "name": "Name",
  1115. "requests": "Requests"
  1116. },
  1117. "columns": {
  1118. "provider": "Provider",
  1119. "type": "Type",
  1120. "status": "Status",
  1121. "availability": "Availability",
  1122. "requests": "Requests",
  1123. "successRate": "Success Rate",
  1124. "avgLatency": "Avg Latency",
  1125. "lastRequest": "Last Request",
  1126. "actions": "Actions"
  1127. },
  1128. "chart": {
  1129. "title": "Availability Trend",
  1130. "description": "Availability changes over time periods",
  1131. "availabilityScore": "Availability Score",
  1132. "requestVolume": "Request Volume",
  1133. "latencyTrend": "Latency Trend",
  1134. "noData": "No Data"
  1135. },
  1136. "details": {
  1137. "title": "Provider Details",
  1138. "overview": "Overview",
  1139. "timeBuckets": "Time Buckets",
  1140. "greenCount": "Successful Requests",
  1141. "redCount": "Failed Requests"
  1142. },
  1143. "actions": {
  1144. "refresh": "Refresh",
  1145. "refreshing": "Refreshing...",
  1146. "autoRefresh": "Auto Refresh",
  1147. "stopAutoRefresh": "Stop Auto Refresh",
  1148. "viewDetails": "View Details",
  1149. "testProvider": "Test Provider",
  1150. "retry": "Retry",
  1151. "probeNow": "Probe Now",
  1152. "probing": "Probing...",
  1153. "probeAll": "Probe All",
  1154. "probeSuccess": "Probe successful",
  1155. "probeFailed": "Probe failed"
  1156. },
  1157. "states": {
  1158. "loading": "Loading...",
  1159. "error": "Load Failed",
  1160. "noProviders": "No Providers",
  1161. "noData": "No availability data",
  1162. "fetchFailed": "Failed to fetch availability data"
  1163. },
  1164. "legend": {
  1165. "green": "Excellent (95%+ availability)",
  1166. "lime": "Good (80-95% availability)",
  1167. "orange": "Warning (50-80% availability)",
  1168. "red": "Unhealthy (<50% availability)",
  1169. "noData": "No Data"
  1170. },
  1171. "summary": {
  1172. "title": "Availability Summary",
  1173. "healthyProviders": "Healthy Providers",
  1174. "unhealthyProviders": "Unhealthy Providers",
  1175. "unknownProviders": "No Data",
  1176. "totalProviders": "Total Providers"
  1177. },
  1178. "heatmap": {
  1179. "bucketSize": "Bucket Size",
  1180. "minutes": "min",
  1181. "requests": "requests",
  1182. "noData": "No Data",
  1183. "noRequests": "No Requests"
  1184. },
  1185. "probeHistory": {
  1186. "title": "Endpoint Probe History",
  1187. "description": "View probe logs and manually trigger probes for specific endpoints",
  1188. "selectVendor": "Select Vendor",
  1189. "selectType": "Select Provider Type",
  1190. "selectEndpoint": "Select Endpoint",
  1191. "noEndpoints": "No endpoints found",
  1192. "probeNow": "Probe Now",
  1193. "probing": "Probing...",
  1194. "columns": {
  1195. "time": "Time",
  1196. "method": "Method",
  1197. "status": "Status",
  1198. "latency": "Latency",
  1199. "error": "Error"
  1200. },
  1201. "success": "Success",
  1202. "manual": "Manual Probe",
  1203. "auto": "Auto Probe",
  1204. "probeSuccess": "Probe successful",
  1205. "probeFailed": "Probe failed"
  1206. },
  1207. "laneChart": {
  1208. "title": "Provider Availability Timeline",
  1209. "noData": "No data available",
  1210. "requests": "{count} requests",
  1211. "availability": "{value}% available",
  1212. "noRequests": "No requests",
  1213. "denseData": "Dense",
  1214. "sparseData": "Sparse",
  1215. "latency": "Latency"
  1216. },
  1217. "latencyChart": {
  1218. "title": "Latency Distribution",
  1219. "p50": "P50",
  1220. "p95": "P95",
  1221. "p99": "P99",
  1222. "noData": "No latency data available"
  1223. },
  1224. "latencyCurve": {
  1225. "title": "Latency Trend",
  1226. "noData": "No latency data available",
  1227. "avg": "Avg",
  1228. "min": "Min",
  1229. "max": "Max",
  1230. "latency": "Latency"
  1231. },
  1232. "terminal": {
  1233. "title": "Probe Logs",
  1234. "live": "LIVE",
  1235. "download": "Download logs",
  1236. "noLogs": "No probe logs available",
  1237. "manual": "MANUAL",
  1238. "auto": "AUTO",
  1239. "filterPlaceholder": "Filter logs..."
  1240. },
  1241. "probeGrid": {
  1242. "title": "Endpoint Status",
  1243. "noEndpoints": "No endpoints configured",
  1244. "lastProbe": "Last probe",
  1245. "status": {
  1246. "unknown": "Unknown",
  1247. "healthy": "Healthy",
  1248. "unhealthy": "Unhealthy"
  1249. }
  1250. },
  1251. "endpoint": {
  1252. "selectVendor": "Select vendor",
  1253. "selectType": "Select type"
  1254. },
  1255. "confidence": {
  1256. "low": "Low",
  1257. "medium": "Medium",
  1258. "high": "High",
  1259. "lowTooltip": "Less than {count} requests. Data may not be representative.",
  1260. "mediumTooltip": "Moderate request volume. Data is reasonably reliable.",
  1261. "highTooltip": "High request volume. Data is reliable."
  1262. },
  1263. "toast": {
  1264. "refreshSuccess": "Availability data refreshed",
  1265. "refreshFailed": "Refresh failed, please retry"
  1266. }
  1267. },
  1268. "rateLimits": {
  1269. "title": "Rate Limit Event Statistics",
  1270. "description": "View and analyze statistics for rate limit events",
  1271. "loading": "Loading...",
  1272. "error": "Load Failed",
  1273. "totalEvents": "Total Events",
  1274. "avgUsage": "Avg Usage",
  1275. "affectedUsers": "Affected Users",
  1276. "noData": "No Data",
  1277. "noDataHint": "No rate limit events in the selected time range",
  1278. "filters": {
  1279. "startTime": "Start Time",
  1280. "endTime": "End Time",
  1281. "user": "User",
  1282. "provider": "Provider",
  1283. "limitType": "Limit Type",
  1284. "allUsers": "All Users",
  1285. "allProviders": "All Providers",
  1286. "allLimitTypes": "All Types",
  1287. "apply": "Apply Filters",
  1288. "reset": "Reset",
  1289. "loading": "Loading...",
  1290. "limitTypes": {
  1291. "rpm": "RPM Limit",
  1292. "usd_5h": "5h Spend Limit",
  1293. "usd_weekly": "Weekly Spend Limit",
  1294. "usd_monthly": "Monthly Spend Limit",
  1295. "concurrent_sessions": "Concurrent Session Limit",
  1296. "daily_quota": "Daily Quota Limit"
  1297. }
  1298. },
  1299. "chart": {
  1300. "title": "Rate Limit Timeline",
  1301. "description": "Hourly trend of rate limit events",
  1302. "total": "Total",
  1303. "events": "Events"
  1304. },
  1305. "breakdown": {
  1306. "title": "Rate Limit Type Breakdown",
  1307. "description": "Share of events by rate limit type",
  1308. "total": "Total",
  1309. "count": "Events",
  1310. "percentage": "Percentage",
  1311. "noData": "No Data",
  1312. "types": {
  1313. "rpm": "RPM",
  1314. "usd_5h": "5h Spend",
  1315. "usd_weekly": "Weekly Spend",
  1316. "usd_monthly": "Monthly Spend",
  1317. "concurrent_sessions": "Concurrent Sessions",
  1318. "daily_quota": "Daily Quota"
  1319. }
  1320. },
  1321. "topUsers": {
  1322. "title": "Top Affected Users",
  1323. "description": "Users who triggered rate limits most frequently",
  1324. "total": "Total",
  1325. "rank": "Rank",
  1326. "username": "Username",
  1327. "eventCount": "Events",
  1328. "percentage": "Percentage",
  1329. "loading": "Loading...",
  1330. "noData": "No Data"
  1331. }
  1332. },
  1333. "users": {
  1334. "title": "User Management",
  1335. "description": "Showing {count} users",
  1336. "toolbar": {
  1337. "searchPlaceholder": "Search name, note, tags, keys...",
  1338. "groupFilter": "Filter by Group",
  1339. "allGroups": "All Groups",
  1340. "tagFilter": "Filter by Tag",
  1341. "allTags": "All Tags",
  1342. "keyGroupFilter": "Key Group",
  1343. "allKeyGroups": "All Key Groups",
  1344. "sortBy": "Sort by",
  1345. "sortOrder": "Sort order",
  1346. "sortByName": "Name",
  1347. "sortByTags": "Tags",
  1348. "sortByExpiresAt": "Expires at",
  1349. "sortByRpm": "RPM Limit",
  1350. "sortByLimit5h": "5h limit",
  1351. "sortByLimitDaily": "Daily limit",
  1352. "sortByLimitWeekly": "Weekly limit",
  1353. "sortByLimitMonthly": "Monthly limit",
  1354. "sortByCreatedAt": "Created at",
  1355. "ascending": "Ascending",
  1356. "descending": "Descending",
  1357. "statusFilter": "Status",
  1358. "allStatus": "All statuses",
  1359. "statusActive": "Active",
  1360. "statusExpired": "Expired",
  1361. "statusExpiringSoon": "Expiring soon",
  1362. "statusEnabled": "Enabled",
  1363. "statusDisabled": "Disabled",
  1364. "createUser": "Create User",
  1365. "createKey": "Create Key"
  1366. },
  1367. "dialog": {
  1368. "userProviderGroup": "Your Provider Groups",
  1369. "userProviderGroupHint": "New keys can only use your existing provider groups."
  1370. }
  1371. },
  1372. "userManagement": {
  1373. "table": {
  1374. "columns": {
  1375. "username": "Username",
  1376. "note": "Note",
  1377. "expiresAt": "Expires at",
  1378. "expiresAtHint": "Click to quick renew",
  1379. "limitRpm": "RPM",
  1380. "limit5h": "5h limit",
  1381. "limitDaily": "Daily limit",
  1382. "limitWeekly": "Weekly limit",
  1383. "limitMonthly": "Monthly limit",
  1384. "limitTotal": "Total limit",
  1385. "limitSessions": "Concurrent sessions"
  1386. },
  1387. "keyRow": {
  1388. "name": "Key name",
  1389. "key": "Key",
  1390. "group": "Group",
  1391. "todayUsage": "Requests today",
  1392. "todayCost": "Today's cost",
  1393. "todayTokens": "Tokens today",
  1394. "lastUsed": "Last used",
  1395. "actions": "Actions",
  1396. "quotaButton": "View Quota Usage",
  1397. "fields": {
  1398. "callsLabel": "Requests",
  1399. "tokensLabel": "Tokens",
  1400. "costLabel": "Cost"
  1401. }
  1402. },
  1403. "expand": "Expand",
  1404. "collapse": "Collapse",
  1405. "refresh": "Refresh",
  1406. "noKeys": "No keys",
  1407. "defaultGroup": "default",
  1408. "userStatus": {
  1409. "disabled": "Disabled"
  1410. },
  1411. "actions": {
  1412. "addKey": "Add Key"
  1413. }
  1414. },
  1415. "keyFullDisplay": {
  1416. "title": "Full Key",
  1417. "copySuccess": "Key copied to clipboard",
  1418. "copyFailed": "Copy failed",
  1419. "show": "Show key",
  1420. "hide": "Hide key",
  1421. "copied": "Copied",
  1422. "copy": "Copy key"
  1423. },
  1424. "keyStatsDialog": {
  1425. "title": "Today's Model Statistics",
  1426. "columns": {
  1427. "model": "Model",
  1428. "calls": "Calls",
  1429. "tokens": "Tokens",
  1430. "cost": "Cost"
  1431. },
  1432. "modal": {
  1433. "requests": "Requests",
  1434. "totalTokens": "Total Tokens",
  1435. "cost": "Cost",
  1436. "inputTokens": "Input Tokens",
  1437. "outputTokens": "Output Tokens",
  1438. "cacheWrite": "Cache Write",
  1439. "cacheRead": "Cache Read",
  1440. "cacheHitRate": "Cache Hit Rate",
  1441. "cacheTokens": "Cache Tokens",
  1442. "performanceHigh": "High",
  1443. "performanceMedium": "Medium",
  1444. "performanceLow": "Low"
  1445. },
  1446. "noData": "No usage records today",
  1447. "totalCalls": "Total Calls",
  1448. "totalCost": "Total Cost"
  1449. },
  1450. "keyQuotaUsageDialog": {
  1451. "title": "Key Quota Usage",
  1452. "fetchFailed": "Failed to fetch quota usage",
  1453. "noLimit": "No limit",
  1454. "modeFixed": "Fixed time",
  1455. "modeRolling": "Rolling 24h",
  1456. "retry": "Retry",
  1457. "labels": {
  1458. "limit5h": "5 Hours",
  1459. "limitDaily": "Daily",
  1460. "limitWeekly": "Weekly",
  1461. "limitMonthly": "Monthly",
  1462. "limitTotal": "Total",
  1463. "limitSessions": "Concurrent"
  1464. }
  1465. },
  1466. "quickRenew": {
  1467. "title": "Quick Renew",
  1468. "description": "Set a new expiration date for user {userName}",
  1469. "currentExpiry": "Current Expiration",
  1470. "neverExpires": "Never expires",
  1471. "expired": "Expired",
  1472. "quickExtensionLabel": "Quick Extension",
  1473. "quickExtensionHint": "Extend from current expiry (or from now if expired)",
  1474. "customDateLabel": "Set Expiry Date",
  1475. "customDateHint": "Directly specify an expiry date",
  1476. "quickOptions": {
  1477. "7days": "7 Days",
  1478. "30days": "30 Days",
  1479. "90days": "90 Days",
  1480. "1year": "1 Year"
  1481. },
  1482. "customDate": "Custom Date",
  1483. "enableOnRenew": "Also enable user",
  1484. "enableKeyOnRenew": "Also enable key",
  1485. "cancel": "Cancel",
  1486. "confirm": "Confirm Renewal",
  1487. "confirming": "Renewing...",
  1488. "success": "Renewal successful",
  1489. "failed": "Renewal failed"
  1490. },
  1491. "dialog": {
  1492. "createKeyTitle": "Create Key",
  1493. "editKeyTitle": "Edit Key"
  1494. },
  1495. "editDialog": {
  1496. "title": "Edit user",
  1497. "description": "Edit user information",
  1498. "userSection": "User settings",
  1499. "keysSection": "Key settings",
  1500. "scrollToKey": "Scroll to key",
  1501. "saveFailed": "Failed to save user",
  1502. "keySaveFailed": "Failed to save key",
  1503. "keyDeleteFailed": "Failed to delete key",
  1504. "saveSuccess": "Changes saved successfully",
  1505. "atLeastOneKeyEnabled": "At least one key must be enabled",
  1506. "operationFailed": "Operation failed",
  1507. "userDisabled": "User has been disabled",
  1508. "userEnabled": "User has been enabled",
  1509. "deleteFailed": "Failed to delete user",
  1510. "userDeleted": "User has been deleted",
  1511. "saving": "Saving...",
  1512. "resetData": {
  1513. "title": "Reset Statistics",
  1514. "description": "Delete all request logs and usage data for this user. This action is irreversible.",
  1515. "error": "Failed to reset data",
  1516. "button": "Reset Statistics",
  1517. "confirmTitle": "Reset All Statistics?",
  1518. "confirmDescription": "This will permanently delete all request logs and usage statistics for this user. This action cannot be undone.",
  1519. "confirm": "Yes, Reset All",
  1520. "loading": "Resetting...",
  1521. "success": "All statistics have been reset"
  1522. }
  1523. },
  1524. "batchEdit": {
  1525. "enterMode": "Batch Edit",
  1526. "exitMode": "Exit",
  1527. "selectAll": "Select All",
  1528. "selectedCount": "Selected {users} users, {keys} keys",
  1529. "editSelected": "Edit Selected",
  1530. "dialog": {
  1531. "title": "Batch Edit",
  1532. "description": "Will affect {users} users and {keys} keys",
  1533. "cancel": "Cancel",
  1534. "next": "Next",
  1535. "noFieldEnabled": "Please enable at least one field to override",
  1536. "noUpdate": "No updates to execute",
  1537. "noSelection": "Please select users or keys to batch edit first."
  1538. },
  1539. "confirm": {
  1540. "title": "Confirm Batch Update",
  1541. "description": "This will update {users} users and {keys} keys. This action cannot be undone.",
  1542. "userFields": "User Fields",
  1543. "keyFields": "Key Fields",
  1544. "goBack": "Go Back",
  1545. "update": "Confirm Update",
  1546. "updating": "Updating..."
  1547. },
  1548. "toast": {
  1549. "usersUpdated": "Updated {count} users",
  1550. "keysUpdated": "Updated {count} keys",
  1551. "usersFailed": "User update failed: {error}",
  1552. "keysFailed": "Key update failed: {error}",
  1553. "batchFailed": "Batch update failed"
  1554. },
  1555. "validation": {
  1556. "invalidNumber": "Please enter a valid number",
  1557. "negativeNumber": "Value cannot be negative"
  1558. },
  1559. "aria": {
  1560. "selectUser": "Select user",
  1561. "selectKey": "Select key"
  1562. },
  1563. "user": {
  1564. "title": "User Settings",
  1565. "affected": "Will affect {count} users",
  1566. "enableFieldAria": "Enable field: {title}",
  1567. "fields": {
  1568. "note": "Note",
  1569. "tags": "Tags",
  1570. "rpm": "RPM Limit",
  1571. "limit5h": "5h Limit (USD)",
  1572. "limitDaily": "Daily Limit (USD)",
  1573. "limitWeekly": "Weekly Limit (USD)",
  1574. "limitMonthly": "Monthly Limit (USD)"
  1575. },
  1576. "placeholders": {
  1577. "emptyToClear": "Leave empty to clear",
  1578. "tagsPlaceholder": "Press enter to add, comma-separated",
  1579. "emptyNoLimit": "Leave empty for no limit"
  1580. }
  1581. },
  1582. "key": {
  1583. "title": "Key Settings",
  1584. "affected": "Will affect {count} keys",
  1585. "fields": {
  1586. "providerGroup": "Group (providerGroup)",
  1587. "limit5h": "5h Limit (USD)",
  1588. "limitDaily": "Daily Limit (USD)",
  1589. "limitWeekly": "Weekly Limit (USD)",
  1590. "limitMonthly": "Monthly Limit (USD)",
  1591. "canLoginWebUi": "Independent Personal Usage Page",
  1592. "keyEnabled": "Key Enabled Status"
  1593. },
  1594. "placeholders": {
  1595. "groupPlaceholder": "Leave empty to clear, comma-separated for multiple",
  1596. "emptyNoLimit": "Leave empty for no limit"
  1597. },
  1598. "targetValue": "Target Value"
  1599. }
  1600. },
  1601. "createDialog": {
  1602. "title": "Create user",
  1603. "description": "Create a new user and configure API keys",
  1604. "saveFailed": "Failed to create user",
  1605. "keyCreateFailed": "Failed to create key",
  1606. "rollbackFailed": "Rollback failed. The user may have been created without a key. Please delete the user manually (userId: {userId}) and try again.",
  1607. "createSuccess": "User created successfully",
  1608. "successTitle": "Created Successfully",
  1609. "successDescription": "User and key have been created",
  1610. "generatedKey": "Generated Key",
  1611. "keyHint": "You can manage this key from the user management page (enable/disable, quotas, etc.), but the full key is only shown once. Copy it now.",
  1612. "keysSection": "Keys",
  1613. "addKey": "Add key",
  1614. "removeKey": "Remove key",
  1615. "cannotDeleteLastKey": "Cannot delete the last key",
  1616. "confirmRemoveKeyTitle": "Remove key",
  1617. "confirmRemoveKeyDescription": "Are you sure you want to remove the key \"{name}\"?",
  1618. "creating": "Creating...",
  1619. "create": "Create"
  1620. },
  1621. "limitRules": {
  1622. "addRule": "Add limit rule",
  1623. "title": "Add Limit Rule",
  1624. "description": "Select limit type and set value",
  1625. "cancel": "Cancel",
  1626. "confirm": "Save",
  1627. "fields": {
  1628. "type": {
  1629. "label": "Limit Type",
  1630. "placeholder": "Select"
  1631. },
  1632. "value": {
  1633. "label": "Value",
  1634. "placeholder": "Enter"
  1635. }
  1636. },
  1637. "daily": {
  1638. "mode": {
  1639. "label": "Daily Reset Mode",
  1640. "fixed": "Fixed time reset",
  1641. "rolling": "Rolling window (24h)",
  1642. "helperRolling": "Rolling 24-hour window from first request"
  1643. },
  1644. "time": {
  1645. "label": "Reset Time",
  1646. "placeholder": "HH:mm"
  1647. }
  1648. },
  1649. "limitTypes": {
  1650. "limitRpm": "RPM Limit",
  1651. "limit5h": "5-Hour Limit",
  1652. "limitDaily": "Daily Limit",
  1653. "limitWeekly": "Weekly Limit",
  1654. "limitMonthly": "Monthly Limit",
  1655. "limitTotal": "Total Limit",
  1656. "limitSessions": "Concurrent Sessions"
  1657. },
  1658. "ruleTypes": {
  1659. "limitRpm": "RPM limit",
  1660. "limit5h": "5-hour limit",
  1661. "limitDaily": "Daily limit",
  1662. "limitWeekly": "Weekly limit",
  1663. "limitMonthly": "Monthly limit",
  1664. "limitTotal": "Total limit",
  1665. "limitSessions": "Concurrent sessions"
  1666. },
  1667. "errors": {
  1668. "missingType": "Please select a limit type",
  1669. "invalidValue": "Please enter a valid value",
  1670. "invalidTime": "Please enter a valid time (HH:mm)"
  1671. },
  1672. "overwriteHint": "This type already exists, saving will overwrite the existing value",
  1673. "dailyMode": {
  1674. "fixed": "Fixed reset time",
  1675. "rolling": "Rolling window (24h)"
  1676. },
  1677. "quickValues": {
  1678. "unlimited": "Unlimited",
  1679. "10": "$10",
  1680. "50": "$50",
  1681. "100": "$100",
  1682. "500": "$500"
  1683. },
  1684. "alreadySet": "Configured",
  1685. "confirmAdd": "Add"
  1686. },
  1687. "quickExpire": {
  1688. "oneWeek": "In 1 week",
  1689. "oneMonth": "In 1 month",
  1690. "threeMonths": "In 3 months",
  1691. "oneYear": "In 1 year"
  1692. },
  1693. "providerGroupSelect": {
  1694. "providersSuffix": "providers",
  1695. "loadFailed": "Failed to load provider groups"
  1696. },
  1697. "providerGroup": {
  1698. "label": "Provider group",
  1699. "placeholder": "Select provider group",
  1700. "noRestriction": "No restriction (all providers)",
  1701. "providerCount": "{count} providers"
  1702. },
  1703. "dangerZone": {
  1704. "title": "Danger Zone",
  1705. "description": "The following actions are irreversible, proceed with caution",
  1706. "enable": {
  1707. "title": "Enable User",
  1708. "description": "After enabling, this user and their keys will resume normal operation",
  1709. "trigger": "Enable",
  1710. "confirm": "Confirm Enable",
  1711. "confirmDescription": "Are you sure you want to enable user \"{userName}\"?",
  1712. "loading": "Processing..."
  1713. },
  1714. "disable": {
  1715. "title": "Disable User",
  1716. "description": "After disabling, this user and their keys will no longer be usable",
  1717. "trigger": "Disable",
  1718. "confirm": "Confirm Disable",
  1719. "confirmDescription": "Are you sure you want to disable user \"{userName}\"?",
  1720. "loading": "Processing..."
  1721. },
  1722. "delete": {
  1723. "title": "Delete User",
  1724. "description": "This will delete all associated data for this user, this action cannot be undone",
  1725. "trigger": "Delete",
  1726. "confirm": "Confirm Delete",
  1727. "confirmDescription": "This action will delete all associated data for user \"{userName}\" and cannot be undone.",
  1728. "confirmLabel": "Secondary Confirmation",
  1729. "confirmHint": "Please type \"{userName}\" to confirm deletion",
  1730. "loading": "Deleting..."
  1731. },
  1732. "actions": {
  1733. "cancel": "Cancel"
  1734. },
  1735. "errors": {
  1736. "enableFailed": "Failed to enable user, please try again later",
  1737. "disableFailed": "Failed to disable user, please try again later",
  1738. "deleteFailed": "Failed to delete user, please try again later"
  1739. }
  1740. },
  1741. "limitIndicator": {
  1742. "notSet": "Not set",
  1743. "unlimited": "Unlimited"
  1744. },
  1745. "keySettings": {
  1746. "balanceQueryPage": {
  1747. "label": "Enable dedicated balance page",
  1748. "description": "Allow users to view their balance via a dedicated page",
  1749. "descriptionEnabled": "When enabled, this key will access an independent personal usage page upon login. However, it cannot modify its own key's provider group.",
  1750. "descriptionDisabled": "When disabled, the user cannot access the personal usage page UI. Instead, they will use the restricted Web UI."
  1751. },
  1752. "cacheTtlOverride": {
  1753. "label": "Cache TTL override",
  1754. "inherit": "No override (follow provider/client)",
  1755. "5m": "5 minutes",
  1756. "1h": "1 hour"
  1757. }
  1758. },
  1759. "pagination": {
  1760. "previous": "Previous",
  1761. "next": "Next",
  1762. "page": "Page {current}",
  1763. "of": "of {total}"
  1764. },
  1765. "toolbar": {
  1766. "expandAll": "Expand all",
  1767. "collapseAll": "Collapse all"
  1768. },
  1769. "keyStatus": {
  1770. "enabled": "Enabled",
  1771. "disabled": "Disabled",
  1772. "active": "Active",
  1773. "expired": "Expired",
  1774. "expiringSoon": "Expiring Soon",
  1775. "keyEnabled": "Key enabled",
  1776. "keyDisabled": "Key disabled",
  1777. "toggleKeyStatus": "Toggle key status",
  1778. "clickToDisableKey": "Click to disable key",
  1779. "clickToEnableKey": "Click to enable key",
  1780. "operationFailed": "Operation failed",
  1781. "clickToQuickRenew": "Click to quick renew"
  1782. },
  1783. "userStatus": {
  1784. "enabled": "Enabled",
  1785. "disabled": "Disabled",
  1786. "active": "Active",
  1787. "expired": "Expired",
  1788. "expiringSoon": "Expiring Soon",
  1789. "userEnabled": "User enabled",
  1790. "userDisabled": "User disabled",
  1791. "toggleUserStatus": "Toggle user status",
  1792. "clickToDisableUser": "Click to disable user",
  1793. "clickToEnableUser": "Click to enable user",
  1794. "operationFailed": "Operation failed",
  1795. "deleteFailed": "Delete failed",
  1796. "deleteSuccess": "Delete successful",
  1797. "daysLeft": "{days, plural, =0 {Expires today} =1 {1 day left} other {# days left}}"
  1798. },
  1799. "userEditSection": {
  1800. "sections": {
  1801. "basicInfo": "Basic Information",
  1802. "expireTime": "Expiration Time",
  1803. "limitRules": "Limit Rules",
  1804. "accessRestrictions": "Access Restrictions"
  1805. },
  1806. "fields": {
  1807. "username": {
  1808. "label": "Username",
  1809. "placeholder": "Enter username"
  1810. },
  1811. "description": {
  1812. "label": "Note",
  1813. "placeholder": "Enter note (optional)"
  1814. },
  1815. "tags": {
  1816. "label": "User Tags",
  1817. "placeholder": "Enter tag (press Enter to add)"
  1818. },
  1819. "providerGroup": {
  1820. "label": "Provider Group",
  1821. "placeholder": "default"
  1822. },
  1823. "allowedClients": {
  1824. "label": "Client Restrictions",
  1825. "description": "Restrict which CLI/IDE clients can use this account. Empty = no restriction.",
  1826. "customLabel": "Custom Client Pattern",
  1827. "customPlaceholder": "Enter pattern (e.g., 'xcode', 'my-ide')"
  1828. },
  1829. "allowedModels": {
  1830. "label": "Model Restrictions",
  1831. "placeholder": "Enter model name or select from dropdown",
  1832. "description": "Restrict which AI models this user can access. Empty = no restriction."
  1833. },
  1834. "enableStatus": {
  1835. "label": "Enable Status",
  1836. "enabledDescription": "Currently enabled. Disabling will prevent this user and their keys from being used.",
  1837. "disabledDescription": "Currently disabled. Enabling will restore normal access for this user and their keys.",
  1838. "confirmDisable": "Confirm Disable",
  1839. "confirmEnable": "Confirm Enable",
  1840. "confirmEnableTitle": "Confirm Enable User",
  1841. "confirmDisableTitle": "Confirm Disable User",
  1842. "confirmEnableDescription": "Enabling will restore normal access for this user and their keys.",
  1843. "confirmDisableDescription": "Disabling will prevent this user and their keys from being used.",
  1844. "cancel": "Cancel",
  1845. "processing": "Processing..."
  1846. }
  1847. },
  1848. "presetClients": {
  1849. "claude-cli": "Claude Code CLI",
  1850. "gemini-cli": "Gemini CLI",
  1851. "factory-cli": "Droid CLI",
  1852. "codex-cli": "Codex CLI"
  1853. }
  1854. },
  1855. "keyEditSection": {
  1856. "sections": {
  1857. "basicInfo": "Basic Information",
  1858. "expireTime": "Expiration Time",
  1859. "limitRules": "Limit Rules",
  1860. "specialFeatures": "Special Features"
  1861. },
  1862. "fields": {
  1863. "keyName": {
  1864. "label": "Key Name",
  1865. "placeholder": "Enter key name"
  1866. },
  1867. "enableStatus": {
  1868. "label": "Enable Status",
  1869. "description": "Disabled keys cannot be used",
  1870. "cannotDisableTooltip": "Cannot disable the last enabled key"
  1871. },
  1872. "balanceQueryPage": {
  1873. "label": "Independent Personal Usage Page",
  1874. "description": "When enabled, this key can access an independent personal usage page",
  1875. "descriptionEnabled": "When enabled, this key will access an independent personal usage page upon login. However, it cannot modify its own key's provider group.",
  1876. "descriptionDisabled": "When disabled, the user cannot access the personal usage page UI. Instead, they will use the restricted Web UI."
  1877. },
  1878. "providerGroup": {
  1879. "label": "Provider Group",
  1880. "placeholder": "Default: default",
  1881. "selectHint": "Select the provider group(s) this key can use (default: default).",
  1882. "editHint": "Provider group cannot be changed for existing keys.",
  1883. "allGroups": "Use all groups",
  1884. "noGroupHint": "default includes providers without groupTag."
  1885. },
  1886. "cacheTtl": {
  1887. "label": "Cache TTL Override",
  1888. "description": "Force Anthropic prompt cache TTL for requests containing cache_control.",
  1889. "options": {
  1890. "inherit": "No override (follow provider/client)",
  1891. "5m": "5m",
  1892. "1h": "1h"
  1893. }
  1894. }
  1895. },
  1896. "limitRules": {
  1897. "title": "Add limit rule",
  1898. "actions": {
  1899. "add": "Add rule",
  1900. "remove": "Remove"
  1901. },
  1902. "daily": {
  1903. "mode": {
  1904. "fixed": "Fixed time reset",
  1905. "rolling": "Rolling window (24h)"
  1906. }
  1907. },
  1908. "overwriteHint": "This type already exists, saving will overwrite the existing value"
  1909. },
  1910. "accessRestrictions": {
  1911. "title": "Access Restrictions",
  1912. "models": "Allowed Models",
  1913. "clients": "Allowed Clients",
  1914. "noRestrictions": "No restrictions",
  1915. "inheritedFromUser": "Inherited from user settings"
  1916. }
  1917. }
  1918. },
  1919. "webhookMigration": {
  1920. "title": "Webhook System Upgrade",
  1921. "description": "We have launched a new Webhook notification system with multi-target delivery, independent configuration, and improved reliability.",
  1922. "step1": {
  1923. "title": "Legacy Webhook Configuration Detected",
  1924. "description": "The system detected that you are using legacy Webhook configuration. The new system offers more powerful features, and we recommend migrating."
  1925. },
  1926. "step2": {
  1927. "title": "Select Platform Type",
  1928. "description": "The following Webhook URLs could not be automatically identified. Please select the platform manually:"
  1929. },
  1930. "platformOptions": {
  1931. "wechat": "WeChat Work",
  1932. "feishu": "Feishu",
  1933. "dingtalk": "DingTalk",
  1934. "telegram": "Telegram",
  1935. "custom": "Custom"
  1936. },
  1937. "migrateButton": "Start Migration",
  1938. "skipButton": "Maybe Later",
  1939. "nextButton": "Next",
  1940. "goToSettingsButton": "Go to Settings",
  1941. "migrating": "Migrating...",
  1942. "success": "Migration Complete",
  1943. "successDescription": "Your Webhook configuration has been successfully migrated to the new system.",
  1944. "error": "Migration Failed",
  1945. "errorGeneric": "Migration failed. Please try again later.",
  1946. "detectedWebhooks": "Detected Webhooks",
  1947. "notificationTypes": {
  1948. "circuit_breaker": "Circuit Breaker Alert",
  1949. "daily_leaderboard": "Daily Leaderboard",
  1950. "cost_alert": "Cost Alert"
  1951. },
  1952. "urlLabel": "Webhook URL",
  1953. "platformLabel": "Platform Type",
  1954. "autoDetected": "Auto-detected",
  1955. "selectPlatform": "Select platform",
  1956. "successStats": "Created {targets} targets, {bindings} bindings"
  1957. }
  1958. }