zardbot-telegram 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (111) hide show
  1. package/.env.example +116 -0
  2. package/LICENSE +21 -0
  3. package/README.md +250 -0
  4. package/dist/agent/manager.js +88 -0
  5. package/dist/agent/types.js +26 -0
  6. package/dist/app/start-bot-app.js +49 -0
  7. package/dist/bot/commands/abort.js +121 -0
  8. package/dist/bot/commands/commands.js +480 -0
  9. package/dist/bot/commands/definitions.js +27 -0
  10. package/dist/bot/commands/help.js +10 -0
  11. package/dist/bot/commands/models.js +38 -0
  12. package/dist/bot/commands/new.js +70 -0
  13. package/dist/bot/commands/opencode-start.js +101 -0
  14. package/dist/bot/commands/opencode-stop.js +44 -0
  15. package/dist/bot/commands/projects.js +223 -0
  16. package/dist/bot/commands/rename.js +139 -0
  17. package/dist/bot/commands/sessions.js +351 -0
  18. package/dist/bot/commands/start.js +43 -0
  19. package/dist/bot/commands/status.js +95 -0
  20. package/dist/bot/commands/task.js +399 -0
  21. package/dist/bot/commands/tasklist.js +220 -0
  22. package/dist/bot/commands/voice.js +145 -0
  23. package/dist/bot/handlers/agent.js +118 -0
  24. package/dist/bot/handlers/context.js +100 -0
  25. package/dist/bot/handlers/document.js +65 -0
  26. package/dist/bot/handlers/inline-menu.js +119 -0
  27. package/dist/bot/handlers/model.js +143 -0
  28. package/dist/bot/handlers/permission.js +235 -0
  29. package/dist/bot/handlers/prompt.js +240 -0
  30. package/dist/bot/handlers/question.js +390 -0
  31. package/dist/bot/handlers/tts.js +89 -0
  32. package/dist/bot/handlers/variant.js +138 -0
  33. package/dist/bot/handlers/voice.js +173 -0
  34. package/dist/bot/index.js +977 -0
  35. package/dist/bot/message-patterns.js +4 -0
  36. package/dist/bot/middleware/auth.js +30 -0
  37. package/dist/bot/middleware/interaction-guard.js +95 -0
  38. package/dist/bot/middleware/unknown-command.js +22 -0
  39. package/dist/bot/streaming/response-streamer.js +286 -0
  40. package/dist/bot/streaming/tool-call-streamer.js +285 -0
  41. package/dist/bot/utils/busy-guard.js +15 -0
  42. package/dist/bot/utils/commands.js +21 -0
  43. package/dist/bot/utils/file-download.js +91 -0
  44. package/dist/bot/utils/finalize-assistant-response.js +52 -0
  45. package/dist/bot/utils/keyboard.js +69 -0
  46. package/dist/bot/utils/send-with-markdown-fallback.js +165 -0
  47. package/dist/bot/utils/telegram-text.js +28 -0
  48. package/dist/bot/utils/thinking-message.js +8 -0
  49. package/dist/cli/args.js +98 -0
  50. package/dist/cli.js +80 -0
  51. package/dist/config.js +97 -0
  52. package/dist/i18n/de.js +357 -0
  53. package/dist/i18n/en.js +357 -0
  54. package/dist/i18n/es.js +357 -0
  55. package/dist/i18n/fr.js +357 -0
  56. package/dist/i18n/index.js +109 -0
  57. package/dist/i18n/ru.js +357 -0
  58. package/dist/i18n/zh.js +357 -0
  59. package/dist/index.js +26 -0
  60. package/dist/interaction/busy.js +8 -0
  61. package/dist/interaction/cleanup.js +32 -0
  62. package/dist/interaction/guard.js +140 -0
  63. package/dist/interaction/manager.js +106 -0
  64. package/dist/interaction/types.js +1 -0
  65. package/dist/keyboard/manager.js +172 -0
  66. package/dist/keyboard/types.js +1 -0
  67. package/dist/model/capabilities.js +62 -0
  68. package/dist/model/context-limit.js +57 -0
  69. package/dist/model/manager.js +259 -0
  70. package/dist/model/types.js +24 -0
  71. package/dist/opencode/client.js +13 -0
  72. package/dist/opencode/events.js +140 -0
  73. package/dist/permission/manager.js +100 -0
  74. package/dist/permission/types.js +1 -0
  75. package/dist/pinned/format.js +29 -0
  76. package/dist/pinned/manager.js +682 -0
  77. package/dist/pinned/types.js +1 -0
  78. package/dist/process/manager.js +273 -0
  79. package/dist/process/types.js +1 -0
  80. package/dist/project/manager.js +88 -0
  81. package/dist/question/manager.js +176 -0
  82. package/dist/question/types.js +1 -0
  83. package/dist/rename/manager.js +53 -0
  84. package/dist/runtime/bootstrap.js +350 -0
  85. package/dist/runtime/mode.js +74 -0
  86. package/dist/runtime/paths.js +37 -0
  87. package/dist/scheduled-task/creation-manager.js +113 -0
  88. package/dist/scheduled-task/display.js +239 -0
  89. package/dist/scheduled-task/executor.js +87 -0
  90. package/dist/scheduled-task/foreground-state.js +32 -0
  91. package/dist/scheduled-task/next-run.js +207 -0
  92. package/dist/scheduled-task/runtime.js +368 -0
  93. package/dist/scheduled-task/schedule-parser.js +169 -0
  94. package/dist/scheduled-task/store.js +65 -0
  95. package/dist/scheduled-task/types.js +19 -0
  96. package/dist/session/cache-manager.js +455 -0
  97. package/dist/session/manager.js +10 -0
  98. package/dist/settings/manager.js +158 -0
  99. package/dist/stt/client.js +97 -0
  100. package/dist/summary/aggregator.js +1136 -0
  101. package/dist/summary/formatter.js +491 -0
  102. package/dist/summary/subagent-formatter.js +63 -0
  103. package/dist/summary/tool-message-batcher.js +90 -0
  104. package/dist/tts/client.js +130 -0
  105. package/dist/utils/error-format.js +29 -0
  106. package/dist/utils/logger.js +127 -0
  107. package/dist/utils/safe-background-task.js +33 -0
  108. package/dist/utils/telegram-rate-limit-retry.js +93 -0
  109. package/dist/variant/manager.js +103 -0
  110. package/dist/variant/types.js +1 -0
  111. package/package.json +79 -0
@@ -0,0 +1,357 @@
1
+ export const de = {
2
+ "cmd.description.status": "Server- und Sitzungsstatus",
3
+ "cmd.description.new": "Neue Sitzung erstellen",
4
+ "cmd.description.stop": "Aktuelle Aktion stoppen",
5
+ "cmd.description.sessions": "Sitzungen auflisten",
6
+ "cmd.description.projects": "Projekte auflisten",
7
+ "cmd.description.task": "Geplante Aufgabe erstellen",
8
+ "cmd.description.tasklist": "Geplante Aufgaben anzeigen",
9
+ "cmd.description.commands": "Benutzerdefinierte Befehle",
10
+ "cmd.description.voice": "TTS-Stimme auswählen",
11
+ "cmd.description.opencode_start": "OpenCode-Server starten",
12
+ "cmd.description.opencode_stop": "OpenCode-Server stoppen",
13
+ "cmd.description.help": "Hilfe",
14
+ "callback.unknown_command": "Unbekannter Befehl",
15
+ "callback.processing_error": "Verarbeitungsfehler",
16
+ "error.load_agents": "❌ Agentenliste konnte nicht geladen werden",
17
+ "error.load_models": "❌ Modellliste konnte nicht geladen werden",
18
+ "error.load_variants": "❌ Variantenliste konnte nicht geladen werden",
19
+ "error.context_button": "❌ Kontext-Button konnte nicht verarbeitet werden",
20
+ "error.generic": "🔴 Etwas ist schiefgelaufen.",
21
+ "interaction.blocked.expired": "⚠️ Diese Interaktion ist abgelaufen. Bitte starte sie erneut.",
22
+ "interaction.blocked.expected_callback": "⚠️ Bitte benutze für diesen Schritt die Inline-Buttons oder tippe auf Abbrechen.",
23
+ "interaction.blocked.expected_text": "⚠️ Bitte sende für diesen Schritt eine Textnachricht.",
24
+ "interaction.blocked.expected_command": "⚠️ Bitte sende für diesen Schritt einen Befehl.",
25
+ "interaction.blocked.command_not_allowed": "⚠️ Dieser Befehl ist in diesem Schritt nicht verfügbar.",
26
+ "interaction.blocked.finish_current": "⚠️ Schließe zuerst die aktuelle Interaktion ab (antworten oder abbrechen), dann öffne ein anderes Menü.",
27
+ "inline.blocked.expected_choice": "⚠️ Wähle eine Option über die Inline-Buttons oder tippe auf Abbrechen.",
28
+ "inline.blocked.command_not_allowed": "⚠️ Dieser Befehl ist nicht verfügbar, solange das Inline-Menü aktiv ist.",
29
+ "question.blocked.expected_answer": "⚠️ Beantworte die aktuelle Frage über Buttons, Eigene Antwort oder Abbrechen.",
30
+ "question.blocked.command_not_allowed": "⚠️ Dieser Befehl ist erst verfügbar, wenn der aktuelle Frage-Flow abgeschlossen ist.",
31
+ "inline.button.cancel": "❌ Abbrechen",
32
+ "inline.inactive_callback": "Dieses Menü ist inaktiv",
33
+ "inline.cancelled_callback": "Abgebrochen",
34
+ "common.unknown": "unbekannt",
35
+ "common.unknown_error": "unbekannter Fehler",
36
+ "start.welcome": "👋 Willkommen beim OpenCode Telegram Bot!\n\nNutze Befehle:\n/projects — Projekt auswählen\n/sessions — Sitzungsliste\n/new — neue Sitzung\n/task — geplante Aufgabe\n/tasklist — geplante Aufgaben\n/status — Status\n/help — Hilfe\n\nNutze die unteren Buttons, um Modus, Modell und Variante zu wählen.",
37
+ "help.keyboard_hint": "💡 Nutze die unteren Buttons für Modus, Modell, Variante und Kontextaktionen.",
38
+ "help.text": "📖 **Hilfe**\n\n/status - Serverstatus prüfen\n/sessions - Sitzungsliste\n/new - Neue Sitzung erstellen\n/help - Hilfe",
39
+ "bot.thinking": "💭 Denke...",
40
+ "bot.project_not_selected": "🏗 Projekt ist nicht ausgewählt.\n\nWähle zuerst ein Projekt mit /projects.",
41
+ "bot.creating_session": "🔄 Erstelle eine neue Sitzung...",
42
+ "bot.create_session_error": "🔴 Sitzung konnte nicht erstellt werden. Versuche /new oder prüfe den Serverstatus mit /status.",
43
+ "bot.session_created": "✅ Sitzung erstellt: {title}",
44
+ "bot.session_busy": "⏳ Agent führt bereits eine Aufgabe aus. Warte auf Abschluss oder nutze /abort, um den aktuellen Lauf zu unterbrechen.",
45
+ "bot.session_reset_project_mismatch": "⚠️ Die aktive Sitzung passt nicht zum ausgewählten Projekt und wurde daher zurückgesetzt. Nutze /sessions zur Auswahl oder /new, um eine neue Sitzung zu erstellen.",
46
+ "bot.prompt_send_error": "Anfrage konnte nicht an OpenCode gesendet werden.",
47
+ "bot.session_error": "🔴 OpenCode meldete einen Fehler: {message}",
48
+ "bot.session_retry": "🔁 {message}\n\nDer Provider liefert bei wiederholten Versuchen immer wieder denselben Fehler. Mit /abort abbrechen.",
49
+ "bot.unknown_command": "⚠️ Unbekannter Befehl: {command}. Nutze /help, um verfügbare Befehle zu sehen.",
50
+ "bot.photo_downloading": "⏳ Lade Foto herunter...",
51
+ "bot.photo_too_large": "⚠️ Foto ist zu groß (max. {maxSizeMb}MB)",
52
+ "bot.photo_model_no_image": "⚠️ Das aktuelle Modell unterstützt keine Bildeingabe. Sende nur Text.",
53
+ "bot.photo_download_error": "🔴 Foto konnte nicht heruntergeladen werden",
54
+ "bot.photo_no_caption": "💡 Tipp: Füge eine Bildunterschrift hinzu, um zu beschreiben, was du mit diesem Foto tun möchtest.",
55
+ "bot.file_downloading": "⏳ Lade Datei herunter...",
56
+ "bot.file_too_large": "⚠️ Datei ist zu groß (max. {maxSizeMb}MB)",
57
+ "bot.file_download_error": "🔴 Datei konnte nicht heruntergeladen werden",
58
+ "bot.model_no_pdf": "⚠️ Das aktuelle Modell unterstützt keine PDF-Eingabe. Sende nur Text.",
59
+ "bot.text_file_too_large": "⚠️ Textdatei ist zu groß (max. {maxSizeKb}KB)",
60
+ "status.header_running": "🟢 OpenCode-Server läuft",
61
+ "status.health.healthy": "OK",
62
+ "status.health.unhealthy": "Nicht OK",
63
+ "status.line.health": "Status: {health}",
64
+ "status.line.version": "Version: {version}",
65
+ "status.line.managed_yes": "Vom Bot gestartet: Ja",
66
+ "status.line.managed_no": "Vom Bot gestartet: Nein",
67
+ "status.line.pid": "PID: {pid}",
68
+ "status.line.uptime_sec": "Betriebszeit: {seconds} s",
69
+ "status.line.mode": "Modus: {mode}",
70
+ "status.line.model": "Modell: {model}",
71
+ "status.agent_not_set": "nicht gesetzt",
72
+ "status.project_selected": "Projekt: {project}",
73
+ "status.project_not_selected": "Projekt: nicht ausgewählt",
74
+ "status.project_hint": "Nutze /projects, um ein Projekt auszuwahlen",
75
+ "status.session_selected": "Aktuelle Sitzung: {title}",
76
+ "status.session_not_selected": "Aktuelle Sitzung: nicht ausgewählt",
77
+ "status.session_hint": "Nutze /sessions zur Auswahl oder /new zum Erstellen",
78
+ "status.server_unavailable": "🔴 OpenCode-Server ist nicht verfügbar\n\nNutze /opencode_start, um den Server zu starten.",
79
+ "projects.empty": "📭 Keine Projekte gefunden.\n\nÖffne ein Verzeichnis in OpenCode und erstelle mindestens eine Sitzung, dann erscheint es hier.",
80
+ "projects.select": "Projekt auswählen:",
81
+ "projects.select_with_current": "Projekt auswählen:\n\nAktuell: 🏗 {project}",
82
+ "projects.page_indicator": "Seite {current}/{total}",
83
+ "projects.prev_page": "⬅️ Zurück",
84
+ "projects.next_page": "Weiter ➡️",
85
+ "projects.fetch_error": "🔴 OpenCode-Server ist nicht verfügbar oder beim Laden der Projekte ist ein Fehler aufgetreten.",
86
+ "projects.page_load_error": "Diese Seite konnte nicht geladen werden. Bitte versuche es erneut.",
87
+ "projects.selected": "✅ Projekt ausgewählt: {project}\n\n📋 Sitzung wurde zurückgesetzt. Nutze /sessions oder /new für dieses Projekt.",
88
+ "projects.select_error": "🔴 Projekt konnte nicht ausgewählt werden.",
89
+ "sessions.project_not_selected": "🏗 Projekt ist nicht ausgewählt.\n\nWähle zuerst ein Projekt mit /projects.",
90
+ "sessions.empty": "📭 Keine Sitzungen gefunden.\n\nErstelle eine neue Sitzung mit /new.",
91
+ "sessions.select": "Sitzung auswählen:",
92
+ "sessions.select_page": "Sitzung auswählen (Seite {page}):",
93
+ "sessions.fetch_error": "🔴 OpenCode-Server ist nicht verfügbar oder beim Laden der Sitzungen ist ein Fehler aufgetreten.",
94
+ "sessions.select_project_first": "🔴 Projekt ist nicht ausgewählt. Nutze /projects.",
95
+ "sessions.page_empty_callback": "Auf dieser Seite gibt es keine Sitzungen",
96
+ "sessions.page_load_error_callback": "Diese Seite kann nicht geladen werden. Bitte versuche es erneut.",
97
+ "sessions.button.prev_page": "⬅️ Zurück",
98
+ "sessions.button.next_page": "Weiter ➡️",
99
+ "sessions.loading_context": "⏳ Lade Kontext und letzte Nachrichten...",
100
+ "sessions.selected": "✅ Sitzung ausgewählt: {title}",
101
+ "sessions.select_error": "🔴 Sitzung konnte nicht ausgewählt werden.",
102
+ "sessions.preview.empty": "Keine neuen Nachrichten.",
103
+ "sessions.preview.title": "Letzte Nachrichten:",
104
+ "sessions.preview.you": "Du:",
105
+ "sessions.preview.agent": "Agent:",
106
+ "new.project_not_selected": "🏗 Projekt ist nicht ausgewählt.\n\nWähle zuerst ein Projekt mit /projects.",
107
+ "new.created": "✅ Neue Sitzung erstellt: {title}",
108
+ "new.create_error": "🔴 OpenCode-Server ist nicht verfügbar oder beim Erstellen der Sitzung ist ein Fehler aufgetreten.",
109
+ "stop.no_active_session": "🛑 Agent wurde nicht gestartet\n\nErstelle eine Sitzung mit /new oder wähle eine über /sessions aus.",
110
+ "stop.in_progress": "🛑 Event-Stream gestoppt, sende Abbruchsignal...\n\nWarte darauf, dass der Agent stoppt.",
111
+ "stop.warn_unconfirmed": "⚠️ Event-Stream gestoppt, aber der Server hat den Abbruch nicht bestätigt.\n\nPrüfe /status und versuche /abort in ein paar Sekunden erneut.",
112
+ "stop.warn_maybe_finished": "⚠️ Event-Stream gestoppt, aber der Agent konnte bereits fertig sein.",
113
+ "stop.success": "✅ Agent-Aktion unterbrochen. Von diesem Lauf werden keine weiteren Nachrichten gesendet.",
114
+ "stop.warn_still_busy": "⚠️ Signal gesendet, aber der Agent ist noch beschäftigt.\n\nDer Event-Stream ist bereits deaktiviert, daher werden keine Zwischenmeldungen gesendet.",
115
+ "stop.warn_timeout": "⚠️ Timeout beim Abbruch.\n\nDer Event-Stream ist bereits deaktiviert, versuche /abort in ein paar Sekunden erneut.",
116
+ "stop.warn_local_only": "⚠️ Event-Stream lokal gestoppt, aber serverseitiger Abbruch ist fehlgeschlagen.",
117
+ "stop.error": "🔴 Aktion konnte nicht gestoppt werden.\n\nEvent-Stream ist gestoppt, versuche /abort erneut.",
118
+ "opencode_start.already_running_managed": "⚠️ OpenCode-Server läuft bereits\n\nPID: {pid}\nBetriebszeit: {seconds} Sekunden",
119
+ "opencode_start.already_running_external": "✅ OpenCode-Server läuft bereits als externer Prozess\n\nVersion: {version}\n\nDieser Server wurde nicht vom Bot gestartet, daher kann /opencode-stop ihn nicht stoppen.",
120
+ "opencode_start.starting": "🔄 Starte OpenCode-Server...",
121
+ "opencode_start.start_error": "🔴 OpenCode-Server konnte nicht gestartet werden\n\nFehler: {error}\n\nPrüfe, ob OpenCode CLI installiert und im PATH verfügbar ist:\nopencode --version\nnpm install -g @opencode-ai/cli",
122
+ "opencode_start.started_not_ready": "⚠️ OpenCode-Server gestartet, aber reagiert nicht\n\nPID: {pid}\n\nDer Server startet möglicherweise noch. Versuche /status in ein paar Sekunden.",
123
+ "opencode_start.success": "✅ OpenCode-Server erfolgreich gestartet\n\nPID: {pid}\nVersion: {version}",
124
+ "opencode_start.error": "🔴 Beim Starten des Servers ist ein Fehler aufgetreten.\n\nSiehe Anwendungslogs für Details.",
125
+ "opencode_stop.external_running": "⚠️ OpenCode-Server läuft als externer Prozess\n\nDieser Server wurde nicht über /opencode-start gestartet.\nStoppe ihn manuell oder nutze /status, um den Zustand zu prüfen.",
126
+ "opencode_stop.not_running": "⚠️ OpenCode-Server läuft nicht",
127
+ "opencode_stop.stopping": "🛑 Stoppe OpenCode-Server...\n\nPID: {pid}",
128
+ "opencode_stop.stop_error": "🔴 OpenCode-Server konnte nicht gestoppt werden\n\nFehler: {error}",
129
+ "opencode_stop.success": "✅ OpenCode-Server erfolgreich gestoppt",
130
+ "opencode_stop.error": "🔴 Beim Stoppen des Servers ist ein Fehler aufgetreten.\n\nSiehe Anwendungslogs für Details.",
131
+ "agent.changed_callback": "Modus geändert: {name}",
132
+ "agent.changed_message": "✅ Modus geändert zu: {name}",
133
+ "agent.change_error_callback": "Modus konnte nicht geändert werden",
134
+ "agent.menu.current": "Aktueller Modus: {name}\n\nModus auswählen:",
135
+ "agent.menu.select": "Arbeitsmodus auswählen:",
136
+ "agent.menu.empty": "⚠️ Keine verfügbaren Agenten",
137
+ "agent.menu.error": "🔴 Agentenliste konnte nicht geladen werden",
138
+ "model.changed_callback": "Modell geändert: {name}",
139
+ "model.changed_message": "✅ Modell geändert zu: {name}",
140
+ "model.change_error_callback": "Modell konnte nicht geändert werden",
141
+ "model.menu.empty": "⚠️ Keine verfügbaren Modelle",
142
+ "model.menu.select": "Modell auswählen:",
143
+ "model.menu.current": "Aktuelles Modell: {name}\n\nModell auswählen:",
144
+ "model.menu.favorites_title": "⭐ Favoriten (Füge Modelle in OpenCode CLI zu den Favoriten hinzu)",
145
+ "model.menu.favorites_empty": "— Leer.",
146
+ "model.menu.recent_title": "🕘 Zuletzt verwendet",
147
+ "model.menu.recent_empty": "— Leer.",
148
+ "model.menu.favorites_hint": "ℹ️ Füge Modelle in OpenCode CLI zu den Favoriten hinzu, damit sie oben angezeigt werden.",
149
+ "model.menu.error": "🔴 Modellliste konnte nicht geladen werden",
150
+ "variant.model_not_selected_callback": "Fehler: Modell ist nicht ausgewählt",
151
+ "variant.changed_callback": "Variante geändert: {name}",
152
+ "variant.changed_message": "✅ Variante geändert zu: {name}",
153
+ "variant.change_error_callback": "Variante konnte nicht geändert werden",
154
+ "variant.select_model_first": "⚠️ Zuerst ein Modell auswählen",
155
+ "variant.menu.empty": "⚠️ Keine verfügbaren Varianten",
156
+ "variant.menu.current": "Aktuelle Variante: {name}\n\nVariante auswählen:",
157
+ "variant.menu.error": "🔴 Variantenliste konnte nicht geladen werden",
158
+ "context.button.confirm": "✅ Ja, Kontext komprimieren",
159
+ "context.no_active_session": "⚠️ Keine aktive Sitzung. Erstelle eine Sitzung mit /new",
160
+ "context.confirm_text": '📊 Kontext-Komprimierung für Sitzung "{title}"\n\nDadurch wird die Kontextnutzung reduziert, indem alte Nachrichten aus dem Verlauf entfernt werden. Die aktuelle Aufgabe wird nicht unterbrochen.\n\nFortfahren?',
161
+ "context.callback_session_not_found": "Sitzung nicht gefunden",
162
+ "context.callback_compacting": "Komprimiere Kontext...",
163
+ "context.progress": "⏳ Komprimiere Kontext...",
164
+ "context.error": "❌ Kontext-Komprimierung fehlgeschlagen",
165
+ "context.success": "✅ Kontext erfolgreich komprimiert",
166
+ "permission.inactive_callback": "Berechtigungsanfrage ist inaktiv",
167
+ "permission.processing_error_callback": "Verarbeitungsfehler",
168
+ "permission.no_active_request_callback": "Fehler: keine aktive Anfrage",
169
+ "permission.reply.once": "Einmal erlaubt",
170
+ "permission.reply.always": "Immer erlaubt",
171
+ "permission.reply.reject": "Abgelehnt",
172
+ "permission.send_reply_error": "❌ Antwort auf Berechtigungsanfrage konnte nicht gesendet werden",
173
+ "permission.blocked.expected_reply": "⚠️ Bitte beantworte zuerst die Berechtigungsanfrage mit den Buttons oben.",
174
+ "permission.blocked.command_not_allowed": "⚠️ Dieser Befehl ist erst verfügbar, wenn du die Berechtigungsanfrage beantwortet hast.",
175
+ "permission.header": "{emoji} Berechtigungsanfrage: {name}\n\n",
176
+ "permission.button.allow": "✅ Einmal erlauben",
177
+ "permission.button.always": "🔓 Immer erlauben",
178
+ "permission.button.reject": "❌ Ablehnen",
179
+ "permission.name.bash": "Bash",
180
+ "permission.name.edit": "Bearbeiten",
181
+ "permission.name.write": "Schreiben",
182
+ "permission.name.read": "Lesen",
183
+ "permission.name.webfetch": "Web-Abruf",
184
+ "permission.name.websearch": "Web-Suche",
185
+ "permission.name.glob": "Dateisuche",
186
+ "permission.name.grep": "Inhaltssuche",
187
+ "permission.name.list": "Verzeichnis auflisten",
188
+ "permission.name.task": "Task",
189
+ "permission.name.lsp": "LSP",
190
+ "permission.name.external_directory": "Externes Verzeichnis",
191
+ "question.inactive_callback": "Umfrage ist inaktiv",
192
+ "question.processing_error_callback": "Verarbeitungsfehler",
193
+ "question.select_one_required_callback": "Wähle mindestens eine Option",
194
+ "question.enter_custom_callback": "Sende deine eigene Antwort als Nachricht",
195
+ "question.cancelled": "❌ Umfrage abgebrochen",
196
+ "question.answer_already_received": "Antwort bereits erhalten, bitte warten...",
197
+ "question.completed_no_answers": "✅ Umfrage abgeschlossen (keine Antworten)",
198
+ "question.no_active_project": "❌ Kein aktives Projekt",
199
+ "question.no_active_request": "❌ Keine aktive Anfrage",
200
+ "question.send_answers_error": "❌ Antworten konnten nicht an den Agenten gesendet werden",
201
+ "question.multi_hint": "\n(Du kannst mehrere Optionen auswählen)",
202
+ "question.button.submit": "✅ Fertig",
203
+ "question.button.custom": "🔤 Eigene Antwort",
204
+ "question.button.cancel": "❌ Abbrechen",
205
+ "question.use_custom_button_first": '⚠️ Um Text zu senden, tippe zuerst bei der aktuellen Frage auf "Eigene Antwort".',
206
+ "question.summary.title": "✅ Umfrage abgeschlossen!\n\n",
207
+ "question.summary.question": "Frage {index}:\n{question}\n\n",
208
+ "question.summary.answer": "Antwort:\n{answer}\n\n",
209
+ "keyboard.agent_mode": "{emoji} {name} Modus",
210
+ "keyboard.context": "📊 {used} / {limit} ({percent}%)",
211
+ "keyboard.context_empty": "📊 0",
212
+ "keyboard.variant": "💭 {name}",
213
+ "keyboard.variant_default": "💡 Standard",
214
+ "keyboard.updated": "⌨️ Tastatur aktualisiert",
215
+ "pinned.default_session_title": "neue Sitzung",
216
+ "pinned.unknown": "Unbekannt",
217
+ "pinned.line.project": "Projekt: {project}",
218
+ "pinned.line.model": "Modell: {model}",
219
+ "pinned.line.context": "Kontext: {used} / {limit} ({percent}%)",
220
+ "pinned.line.cost": "Kosten: {cost} ausgegeben",
221
+ "subagent.header": "Subagent {agent}: {description}",
222
+ "subagent.line.status": "Status: {status}",
223
+ "subagent.line.task": "Aufgabe: {task}",
224
+ "subagent.line.agent": "Agent: {agent}",
225
+ "subagent.working": "Arbeitet...",
226
+ "subagent.working_with_details": "Arbeitet: {details}",
227
+ "subagent.completed": "Abgeschlossen",
228
+ "subagent.failed": "Aufgabe fehlgeschlagen",
229
+ "subagent.status.pending": "ausstehend",
230
+ "subagent.status.running": "laeuft",
231
+ "subagent.status.completed": "abgeschlossen",
232
+ "subagent.status.error": "Fehler",
233
+ "pinned.files.title": "Dateien ({count}):",
234
+ "pinned.files.item": " {path}{diff}",
235
+ "pinned.files.more": " ... und {count} mehr",
236
+ "tool.todo.overflow": "*({count} weitere Aufgaben)*",
237
+ "tool.file_header.write": "Datei/Pfad schreiben: {path}\n============================================================\n\n",
238
+ "tool.file_header.edit": "Datei/Pfad bearbeiten: {path}\n============================================================\n\n",
239
+ "runtime.wizard.ask_token": "Telegram-Bot-Token eingeben (von @BotFather).\n> ",
240
+ "runtime.wizard.ask_language": "Oberflächensprache auswählen.\nGib die Sprach-Nummer aus der Liste oder den Locale-Code ein.\nDrücke Enter, um die Standardsprache beizubehalten: {defaultLocale}\n{options}\n> ",
241
+ "runtime.wizard.language_invalid": "Gib eine Sprach-Nummer aus der Liste oder einen unterstützten Locale-Code ein.\n",
242
+ "runtime.wizard.language_selected": "Ausgewählte Sprache: {language}\n",
243
+ "runtime.wizard.token_required": "Token ist erforderlich. Bitte versuche es erneut.\n",
244
+ "runtime.wizard.token_invalid": "Token sieht ungültig aus (erwartetes Format <id>:<secret>). Bitte versuche es erneut.\n",
245
+ "runtime.wizard.ask_user_id": "Gib deine Telegram User ID ein (du bekommst sie bei @userinfobot).\n> ",
246
+ "runtime.wizard.user_id_invalid": "Gib eine positive ganze Zahl ein (> 0).\n",
247
+ "runtime.wizard.ask_api_url": "OpenCode API URL eingeben (optional).\nEnter drücken für Standard: {defaultUrl}\n> ",
248
+ "runtime.wizard.ask_server_username": "OpenCode-Server-Benutzername eingeben (optional).\nEnter drücken für Standard: {defaultUsername}\n> ",
249
+ "runtime.wizard.ask_server_password": "OpenCode-Server-Passwort eingeben (optional).\nEnter drücken, um es leer zu lassen.\n> ",
250
+ "runtime.wizard.api_url_invalid": "Gib eine gültige URL (http/https) ein oder drücke Enter für Standard.\n",
251
+ "runtime.wizard.start": "OpenCode Telegram Bot Einrichtung.\n",
252
+ "runtime.wizard.saved": "Konfiguration gespeichert:\n- {envPath}\n- {settingsPath}\n",
253
+ "runtime.wizard.not_configured_starting": "Anwendung ist noch nicht konfiguriert. Starte Assistent...\n",
254
+ "runtime.wizard.tty_required": "Der interaktive Assistent erfordert ein TTY-Terminal. Führe `opencode-telegram config` in einer interaktiven Shell aus.",
255
+ "rename.no_session": "⚠️ Keine aktive Sitzung. Erstelle oder wähle zuerst eine Sitzung.",
256
+ "rename.prompt": "📝 Neuen Titel für die Sitzung eingeben:\n\nAktuell: {title}",
257
+ "rename.empty_title": "⚠️ Titel darf nicht leer sein.",
258
+ "rename.success": "✅ Sitzung umbenannt in: {title}",
259
+ "rename.error": "🔴 Sitzung konnte nicht umbenannt werden.",
260
+ "rename.cancelled": "❌ Umbenennen abgebrochen.",
261
+ "rename.inactive_callback": "Umbenennen-Anfrage ist inaktiv",
262
+ "rename.inactive": "⚠️ Umbenennen-Anfrage ist nicht aktiv. Starte /rename erneut.",
263
+ "rename.blocked.expected_name": "⚠️ Sende den neuen Sitzungsnamen als Text oder tippe in der Umbenennen-Nachricht auf Abbrechen.",
264
+ "rename.blocked.command_not_allowed": "⚠️ Dieser Befehl ist nicht verfügbar, solange beim Umbenennen auf einen neuen Namen gewartet wird.",
265
+ "rename.button.cancel": "❌ Abbrechen",
266
+ "task.prompt.schedule": "⏰ Sende den Zeitplan der Aufgabe in natürlicher Sprache.\n\nBeispiele:\n- alle 5 Minuten\n- jeden Tag um 17:00\n- morgen um 12:00",
267
+ "task.schedule_empty": "⚠️ Der Zeitplan darf nicht leer sein.",
268
+ "task.parse.in_progress": "⏳ Zeitplan wird verarbeitet...",
269
+ "task.parse_error": "🔴 Zeitplan konnte nicht erkannt werden.\n\n{message}\n\nSende den Zeitraum bitte noch einmal klarer formuliert.",
270
+ "task.schedule_preview": "✅ Zeitplan erkannt\n\nVerstanden als: {summary}\n{cronLine}Zeitzone: {timezone}\nTyp: {kind}\nNächster Lauf: {nextRunAt}",
271
+ "task.schedule_preview.cron": "Cron: {cron}",
272
+ "task.prompt.body": "📝 Sende jetzt, was der Bot nach Zeitplan tun soll.",
273
+ "task.prompt_empty": "⚠️ Der Aufgabentext darf nicht leer sein.",
274
+ "task.created": "✅ Geplante Aufgabe erstellt\n\nAufgabe: {description}\nProjekt: {project}\nModell: {model}\nZeitplan: {schedule}\n{cronLine}Nächster Lauf: {nextRunAt}",
275
+ "task.created.cron": "Cron: {cron}",
276
+ "task.button.retry_schedule": "🔁 Zeitplan neu eingeben",
277
+ "task.button.cancel": "❌ Abbrechen",
278
+ "task.retry_schedule_callback": "Zeitplaneingabe wird zurückgesetzt...",
279
+ "task.cancel_callback": "Abbruch...",
280
+ "task.cancelled": "❌ Erstellung der geplanten Aufgabe abgebrochen.",
281
+ "task.inactive_callback": "Dieser Ablauf für geplante Aufgaben ist nicht mehr aktiv",
282
+ "task.inactive": "⚠️ Die Erstellung geplanter Aufgaben ist nicht aktiv. Starte /task erneut.",
283
+ "task.blocked.expected_input": "⚠️ Schließe zuerst die aktuelle geplante Aufgabe ab: Sende Text oder nutze die Schaltfläche in der Zeitplan-Nachricht.",
284
+ "task.blocked.command_not_allowed": "⚠️ Dieser Befehl ist nicht verfügbar, solange die Erstellung einer geplanten Aufgabe aktiv ist.",
285
+ "task.limit_reached": "⚠️ Aufgabenlimit erreicht ({limit}). Lösche zuerst eine bestehende geplante Aufgabe.",
286
+ "task.schedule_too_frequent": "Der wiederkehrende Zeitplan ist zu häufig. Das minimale erlaubte Intervall ist einmal alle 5 Minuten.",
287
+ "task.kind.cron": "wiederkehrend",
288
+ "task.kind.once": "einmalig",
289
+ "task.run.success": "⏰ Geplante Aufgabe abgeschlossen: {description}",
290
+ "task.run.error": "🔴 Geplante Aufgabe fehlgeschlagen: {description}\n\nFehler: {error}",
291
+ "tasklist.empty": "📭 Noch keine geplanten Aufgaben.",
292
+ "tasklist.select": "Wähle eine geplante Aufgabe:",
293
+ "tasklist.details": "⏰ Geplante Aufgabe\n\nAufgabe: {prompt}\nProjekt: {project}\nZeitplan: {schedule}\n{cronLine}Zeitzone: {timezone}\nNächster Lauf: {nextRunAt}\nLetzter Lauf: {lastRunAt}\nAnzahl Läufe: {runCount}",
294
+ "tasklist.details.cron": "Cron: {cron}",
295
+ "tasklist.button.delete": "🗑 Löschen",
296
+ "tasklist.button.cancel": "❌ Abbrechen",
297
+ "tasklist.deleted_callback": "Gelöscht",
298
+ "tasklist.cancelled_callback": "Abgebrochen",
299
+ "tasklist.inactive_callback": "Dieses Menü für geplante Aufgaben ist inaktiv",
300
+ "tasklist.load_error": "🔴 Geplante Aufgaben konnten nicht geladen werden.",
301
+ "commands.select": "Wähle einen OpenCode-Befehl:",
302
+ "commands.empty": "📭 Für dieses Projekt sind keine OpenCode-Befehle verfügbar.",
303
+ "commands.fetch_error": "🔴 OpenCode-Befehle konnten nicht geladen werden.",
304
+ "commands.no_description": "Keine Beschreibung",
305
+ "commands.button.execute": "✅ Ausführen",
306
+ "commands.button.cancel": "❌ Abbrechen",
307
+ "commands.confirm": "Bestätige die Ausführung des Befehls {command}. Für die Ausführung mit Argumenten sende die Argumente als Nachricht.",
308
+ "commands.inactive_callback": "Dieses Befehlsmenü ist inaktiv",
309
+ "commands.cancelled_callback": "Abgebrochen",
310
+ "commands.execute_callback": "Befehl wird ausgeführt...",
311
+ "commands.executing_prefix": "⚡ Befehl wird ausgeführt:",
312
+ "commands.arguments_empty": "⚠️ Argumente dürfen nicht leer sein. Sende Text oder tippe auf Ausführen.",
313
+ "commands.execute_error": "🔴 OpenCode-Befehl konnte nicht ausgeführt werden.",
314
+ "commands.select_page": "Wähle einen OpenCode-Befehl (Seite {page}):",
315
+ "commands.button.prev_page": "⬅️ Zurück",
316
+ "commands.button.next_page": "Weiter ➡️",
317
+ "commands.page_empty_callback": "Keine Befehle auf dieser Seite",
318
+ "commands.page_load_error_callback": "Diese Seite konnte nicht geladen werden. Bitte versuche es erneut.",
319
+ "cmd.description.rename": "Aktuelle Sitzung umbenennen",
320
+ "cli.usage": "Verwendung:\n opencode-telegram [start] [--mode sources|installed]\n opencode-telegram status\n opencode-telegram stop\n opencode-telegram config\n\nHinweise:\n - Ohne Befehl wird standardmäßig `start` verwendet\n - `--mode` wird derzeit nur für `start` unterstützt",
321
+ "cli.placeholder.status": "Befehl `status` ist derzeit ein Platzhalter. Echte Statusprüfungen werden in der Service-Schicht hinzugefügt (Phase 5).",
322
+ "cli.placeholder.stop": "Befehl `stop` ist derzeit ein Platzhalter. Ein echter Stop des Hintergrundprozesses wird in der Service-Schicht hinzugefügt (Phase 5).",
323
+ "cli.placeholder.unavailable": "Befehl ist nicht verfügbar.",
324
+ "cli.error.prefix": "CLI-Fehler: {message}",
325
+ "cli.args.unknown_command": "Unbekannter Befehl: {value}",
326
+ "cli.args.mode_requires_value": "Option --mode erfordert einen Wert: sources|installed",
327
+ "cli.args.invalid_mode": "Ungültiger Wert für --mode: {value}. Erwartet sources|installed",
328
+ "cli.args.unknown_option": "Unbekannte Option: {value}",
329
+ "cli.args.mode_only_start": "Option --mode wird nur für den start-Befehl unterstützt",
330
+ "legacy.models.fetch_error": "🔴 Modellliste konnte nicht geladen werden. Prüfe den Serverstatus mit /status.",
331
+ "legacy.models.empty": "📋 Keine verfügbaren Modelle. Konfiguriere Provider in OpenCode.",
332
+ "legacy.models.header": "📋 Verfügbare Modelle:\n\n",
333
+ "legacy.models.no_provider_models": " ⚠️ Keine verfügbaren Modelle\n",
334
+ "legacy.models.env_hint": "💡 Um ein Modell in .env zu nutzen:\n",
335
+ "legacy.models.error": "🔴 Beim Laden der Modellliste ist ein Fehler aufgetreten.",
336
+ "stt.recognizing": "🎤 Erkenne Audio...",
337
+ "stt.recognized": "🎤 Erkannt:\n{text}",
338
+ "stt.not_configured": "🎤 Spracherkennung ist nicht konfiguriert.\n\nSetze STT_API_URL und STT_API_KEY in .env, um sie zu aktivieren.",
339
+ "stt.error": "🔴 Audio konnte nicht erkannt werden: {error}",
340
+ "stt.empty_result": "🎤 Keine Sprache in der Audionachricht erkannt.",
341
+ "tts.not_configured": "🔊 Sprachsynthese ist nicht konfiguriert.\n\nSetze TTS_API_URL in .env, um sie zu aktivieren.\n\nEmpfohlen: Verwende pocket-tts-server für lokales TTS.\nhttps://github.com/ai-joe-git/pocket-tts-server",
342
+ "tts.voice_changed": "🔊 Stimme geändert: {voice}",
343
+ "tts.voice_error": "🔴 Stimme konnte nicht geändert werden: {error}",
344
+ "tts.fetch_voices_error": "🔴 Stimmen konnten nicht vom TTS-Server abgerufen werden.",
345
+ "tts.synthesis_error": "🔴 Sprachsynthese fehlgeschlagen: {error}",
346
+ "tts.speaking": "🔊 Wird abgespielt...",
347
+ "tts.menu_title": "Wähle eine Stimme:",
348
+ "tts.menu_current": "Aktuelle Stimme: {voice}\n\nWähle eine Stimme:",
349
+ "tts.menu_empty": "⚠️ Keine Stimmen verfügbar. Prüfe die TTS-Server-Konfiguration.",
350
+ "tts.menu_loading": "⏳ Lade Stimmen...",
351
+ "tts.menu_error": "🔴 Stimmen konnten nicht geladen werden.",
352
+ "tts.button.off": "🔇 TTS Aus",
353
+ "tts.button.off_description": "Sprachantworten deaktivieren",
354
+ "tts.button.prev_page": "⬅️ Zurück",
355
+ "tts.button.next_page": "Weiter ➡️",
356
+ "tts.off_success": "🔇 Sprachantworten deaktiviert.",
357
+ };