@agentprojectcontext/apx 1.15.1 → 1.15.2
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.
- package/package.json +1 -1
- package/src/cli/commands/setup.js +31 -16
- package/src/core/config.js +4 -0
- package/src/daemon/transcription.js +8 -1
package/package.json
CHANGED
|
@@ -192,9 +192,20 @@ export async function cmdSetup() {
|
|
|
192
192
|
// ── Language ────────────────────────────────────────────────────────────────
|
|
193
193
|
console.log();
|
|
194
194
|
console.log(b(" Language:"));
|
|
195
|
-
console.log(di("
|
|
195
|
+
console.log(di(" Used for audio transcription, super-agent replies, and Telegram messages."));
|
|
196
|
+
console.log(di(" Enter a 2-letter ISO 639-1 code. Common codes:"));
|
|
197
|
+
console.log(di(" es=Spanish en=English pt=Portuguese fr=French de=German"));
|
|
198
|
+
console.log(di(" it=Italian zh=Chinese ja=Japanese ko=Korean ar=Arabic"));
|
|
196
199
|
console.log();
|
|
197
|
-
|
|
200
|
+
let language = "";
|
|
201
|
+
while (!language) {
|
|
202
|
+
const raw = (await ask(" Language code [en]: ")).trim().toLowerCase() || "en";
|
|
203
|
+
if (/^[a-z]{2}$/.test(raw)) {
|
|
204
|
+
language = raw;
|
|
205
|
+
} else {
|
|
206
|
+
console.log(` ${c.yellow}Please enter exactly 2 letters (e.g. es, en, pt).${c.reset}`);
|
|
207
|
+
}
|
|
208
|
+
}
|
|
198
209
|
|
|
199
210
|
// ── Summary ─────────────────────────────────────────────────────────────────
|
|
200
211
|
console.log();
|
|
@@ -236,6 +247,8 @@ export async function cmdSetup() {
|
|
|
236
247
|
cfg.telegram.chat_id = chatId;
|
|
237
248
|
}
|
|
238
249
|
|
|
250
|
+
cfg.user = { ...(cfg.user || {}), language };
|
|
251
|
+
|
|
239
252
|
writeConfig(cfg);
|
|
240
253
|
console.log(`\n ${gr("✓")} Config saved to ${di("~/.apx/config.json")}`);
|
|
241
254
|
|
|
@@ -282,7 +295,7 @@ export async function cmdSetup() {
|
|
|
282
295
|
async function sendTelegramWakeup({ botToken, chatId, language, model }) {
|
|
283
296
|
const prompt =
|
|
284
297
|
`You are APX, an AI agent assistant that just came online for the first time. ` +
|
|
285
|
-
`Write a short, enthusiastic wake-up message in ${language}. ` +
|
|
298
|
+
`Write a short, enthusiastic wake-up message in the language with ISO 639-1 code "${language}". ` +
|
|
286
299
|
`Structure it in exactly 3 short lines: ` +
|
|
287
300
|
`1) An energetic line announcing you are online (use ⚡ emoji). ` +
|
|
288
301
|
`2) Say you don't have a name yet and ask the user what they'd like to call you. ` +
|
|
@@ -321,18 +334,20 @@ async function sendTelegramWakeup({ botToken, chatId, language, model }) {
|
|
|
321
334
|
});
|
|
322
335
|
}
|
|
323
336
|
|
|
324
|
-
// Minimal fallback messages per
|
|
337
|
+
// Minimal fallback messages per ISO 639-1 code (used only if daemon can't respond)
|
|
338
|
+
const WAKEUP_FALLBACK = {
|
|
339
|
+
es: "⚡ ¡APX está en línea y listo!\nAún no tengo nombre — ¿cómo te gustaría llamarme?\n¿Y a vos, cómo te llamo?",
|
|
340
|
+
pt: "⚡ APX está online e pronto!\nAinda não tenho nome — como você gostaria de me chamar?\nE você, como devo te chamar?",
|
|
341
|
+
fr: "⚡ APX est en ligne et prêt !\nJe n'ai pas encore de nom — comment souhaitez-vous m'appeler ?\nEt vous, comment dois-je vous appeler ?",
|
|
342
|
+
de: "⚡ APX ist online und bereit!\nIch habe noch keinen Namen — wie möchten Sie mich nennen?\nUnd Sie, wie soll ich Sie nennen?",
|
|
343
|
+
it: "⚡ APX è online e pronto!\nNon ho ancora un nome — come vorresti chiamarmi?\nE tu, come ti chiamo?",
|
|
344
|
+
zh: "⚡ APX 已上线,随时待命!\n我还没有名字——你想叫我什么?\n你希望我怎么称呼你?",
|
|
345
|
+
ja: "⚡ APXがオンラインになりました!\nまだ名前がありません — 何と呼びたいですか?\nあなたのことは何とお呼びすればよいですか?",
|
|
346
|
+
ko: "⚡ APX가 온라인 상태입니다!\n아직 이름이 없어요 — 어떻게 불러주실 건가요?\n그리고 당신은 어떻게 불러드릴까요?",
|
|
347
|
+
};
|
|
325
348
|
function languageFallback(lang) {
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
return "⚡ APX is online and ready to work.\nI do not have a name yet. What would you like to call me?\nAnd what should I call you?";
|
|
331
|
-
if (/franc|french/i.test(l))
|
|
332
|
-
return "⚡ APX is online and ready to work.\nI do not have a name yet. What would you like to call me?\nAnd what should I call you?";
|
|
333
|
-
if (/deutsch|german/i.test(l))
|
|
334
|
-
return "⚡ APX is online and ready to work.\nI do not have a name yet. What would you like to call me?\nAnd what should I call you?";
|
|
335
|
-
if (/ital/i.test(l))
|
|
336
|
-
return "⚡ APX is online and ready to work.\nI do not have a name yet. What would you like to call me?\nAnd what should I call you?";
|
|
337
|
-
return "⚡ I'm awake and ready to go! APX is online.\nI don't have a name yet — what would you like to call me?\nAnd you, what's your name or what should I call you?";
|
|
349
|
+
return (
|
|
350
|
+
WAKEUP_FALLBACK[lang.toLowerCase().slice(0, 2)] ||
|
|
351
|
+
"⚡ I'm awake and ready to go! APX is online.\nI don't have a name yet — what would you like to call me?\nAnd you, what's your name or what should I call you?"
|
|
352
|
+
);
|
|
338
353
|
}
|
package/src/core/config.js
CHANGED
|
@@ -32,6 +32,9 @@ const DEFAULT_CONFIG = {
|
|
|
32
32
|
host: "127.0.0.1",
|
|
33
33
|
log_level: "info",
|
|
34
34
|
projects: [],
|
|
35
|
+
user: {
|
|
36
|
+
language: "en", // ISO 639-1 two-letter code; used by transcription, super-agent, and wake-up message
|
|
37
|
+
},
|
|
35
38
|
telegram: {
|
|
36
39
|
enabled: false,
|
|
37
40
|
bot_token: "",
|
|
@@ -87,6 +90,7 @@ export function mergeDefaults(cfg) {
|
|
|
87
90
|
return {
|
|
88
91
|
...DEFAULT_CONFIG,
|
|
89
92
|
...cfg,
|
|
93
|
+
user: { ...DEFAULT_CONFIG.user, ...(cfg.user || {}) },
|
|
90
94
|
telegram: {
|
|
91
95
|
...DEFAULT_CONFIG.telegram,
|
|
92
96
|
...(cfg.telegram || {}),
|
|
@@ -55,9 +55,16 @@ async function getConfig() {
|
|
|
55
55
|
const cfg = readConfig() || {};
|
|
56
56
|
const t = cfg.transcription || {};
|
|
57
57
|
const openaiKey = cfg.engines?.openai?.api_key || process.env.OPENAI_API_KEY || "";
|
|
58
|
+
// Use user.language as default for transcription language if not explicitly set.
|
|
59
|
+
// Explicit transcription.local.language always wins; "auto" means fall back to user.language.
|
|
60
|
+
const userLang = cfg.user?.language || "";
|
|
61
|
+
const localBase = { ...DEFAULT_LOCAL, ...(t.local || {}) };
|
|
62
|
+
if ((!localBase.language || localBase.language === "auto") && userLang) {
|
|
63
|
+
localBase.language = userLang;
|
|
64
|
+
}
|
|
58
65
|
return {
|
|
59
66
|
provider: t.provider || "auto",
|
|
60
|
-
local:
|
|
67
|
+
local: localBase,
|
|
61
68
|
openaiKey,
|
|
62
69
|
};
|
|
63
70
|
} catch {
|