chahinebrini 685782b538 fix(coach): dynamische Sprache (Text-Detection + App-Locale-Fallback)
LLM-Prompt (message.post + sos-stream):
- LANG_INSTRUCTIONS Map raus, ersetzt durch dynamische Instruktion
  'Reply in {detectedFromUser} ... fallback: {appLang}'
- Lyra matcht jetzt die Sprache der letzten User-Message (per
  detectLang Unicode-Detection); App-Locale ist nur noch Fallback
- Instruktion doppelt eingehängt (Anfang + Ende des System-Prompts)
  gegen recency bias bei langen deutschen Prompts

TTS (speak dispatcher + speak-cartesia + speak-elevenlabs):
- Kein 'de'-Default mehr für language. detectLang(text, locale) leitet
  Sprache primär aus dem Antwort-Text ab (Arabic/Cyrillic/CJK/Turkish-
  Letters), Locale als Fallback
- Cartesia + ElevenLabs: language/language_code nur senden wenn
  ableitbar, sonst Provider auto-detect statt erzwungenem 'de'
- speak-cartesia: sonic-2 → sonic-3 (Multi-Lang, war beim Dispatcher-
  Fix gestern vergessen worden)
- Google: en-US neutraler Fallback statt de-DE-Bias

Neu: server/utils/detect-lang.ts
2026-05-31 00:12:40 +02:00

41 lines
1.8 KiB
Swift

import Foundation
/// Zentrale Auflösung der system-binaries die der Binder anstößt.
enum Paths {
/// libimobiledevice meist via Homebrew installiert.
static let ideviceinfoCandidates = [
"/opt/homebrew/bin/ideviceinfo",
"/usr/local/bin/ideviceinfo",
]
/// Apple Configurator (heißt seit 2026 ohne 2") liefert cfgutil mit.
static let cfgutilCandidates = [
"/Applications/Apple Configurator.app/Contents/MacOS/cfgutil",
"/Applications/Apple Configurator 2.app/Contents/MacOS/cfgutil",
]
static var cfgutilPath: String? {
firstExecutable(in: cfgutilCandidates)
}
/// supervise-magic Go-binary aus dem Monorepo. Pfad relativ zur App-Location:
/// app läuft typischerweise aus DerivedData/Build/Products oder ähnlich, daher
/// suchen wir mehrere plausible Locations relativ + absolut.
static let superviseMagicCandidates: [String] = {
let env = ProcessInfo.processInfo.environment["REBREAK_SUPERVISE_MAGIC_BIN"]
var candidates: [String] = []
if let env, !env.isEmpty { candidates.append(env) }
// Repo-Layout: rebreak-monorepo/apps/rebreak-binder-mac/...
// supervise-magic liegt in rebreak-monorepo/ops/mdm/supervise-magic/bin/
let home = FileManager.default.homeDirectoryForCurrentUser.path
candidates.append("\(home)/mono/rebreak-monorepo/ops/mdm/supervise-magic/bin/rebreak-supervise-magic")
candidates.append("/usr/local/bin/rebreak-supervise-magic")
candidates.append("/opt/homebrew/bin/rebreak-supervise-magic")
return candidates
}()
static func firstExecutable(in candidates: [String]) -> String? {
candidates.first(where: { FileManager.default.isExecutableFile(atPath: $0) })
}
}