nothumanallowed 14.1.0 → 14.1.1

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 CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "nothumanallowed",
3
- "version": "14.1.0",
3
+ "version": "14.1.1",
4
4
  "description": "NotHumanAllowed — 38 AI agents, 80 tools, Studio (visual agentic workflows). Email, calendar, browser automation, screen capture, canvas, cron/heartbeat, Alexandria E2E messaging, GitHub, Notion, Slack, voice chat, free AI (Liara), 28 languages. Zero-dependency CLI.",
5
5
  "type": "module",
6
6
  "bin": {
package/src/constants.mjs CHANGED
@@ -5,7 +5,7 @@ import { fileURLToPath } from 'url';
5
5
  const __filename = fileURLToPath(import.meta.url);
6
6
  const __dirname = path.dirname(__filename);
7
7
 
8
- export const VERSION = '14.1.0';
8
+ export const VERSION = '14.1.1';
9
9
  export const BASE_URL = 'https://nothumanallowed.com/cli';
10
10
  export const API_BASE = 'https://nothumanallowed.com/api/v1';
11
11
 
@@ -89,12 +89,14 @@ export function register(router) {
89
89
 
90
90
  try {
91
91
  const agentSlug = body.agent?.toLowerCase();
92
- let sysProm = 'You are a helpful AI assistant.';
92
+ const LANG_MAP = { it:'Italian', en:'English', es:'Spanish', fr:'French', de:'German', pt:'Portuguese', nl:'Dutch', pl:'Polish', ru:'Russian', zh:'Chinese', ja:'Japanese', ko:'Korean', ar:'Arabic', hi:'Hindi', tr:'Turkish', sv:'Swedish', da:'Danish', fi:'Finnish', cs:'Czech' };
93
+ const lang = LANG_MAP[(config?.language || config?.lang || 'en').slice(0,2)] || 'English';
94
+ let sysProm = `You are a helpful AI assistant. Always respond in ${lang}.`;
93
95
  if (agentSlug) {
94
96
  const af = path.join(AGENTS_DIR, `${agentSlug}.mjs`);
95
97
  if (fs.existsSync(af)) {
96
98
  const parsed = parseAgentFile(fs.readFileSync(af, 'utf-8'), agentSlug);
97
- if (parsed.systemPrompt) sysProm = parsed.systemPrompt;
99
+ if (parsed.systemPrompt) sysProm = `${parsed.systemPrompt}\n\nIMPORTANT: Always respond in ${lang}.`;
98
100
  }
99
101
  }
100
102
  await callLLMStream(config, sysProm, body.message, (tok) => sse('token', { content: tok }));
@@ -200,6 +200,13 @@ export function register(router) {
200
200
  try { const m = buildMemoryContext('chat', effectiveMsg); if (m) enrichedPrompt = enrichedPrompt + m; } catch {}
201
201
  try { const ic = await getImapAccountsContext(); if (ic) enrichedPrompt += ic; } catch {}
202
202
 
203
+ // Inject language instruction — always respects user's lang setting
204
+ const LANG_MAP = { it:'Italian', en:'English', es:'Spanish', fr:'French', de:'German', pt:'Portuguese', nl:'Dutch', pl:'Polish', ru:'Russian', zh:'Chinese', ja:'Japanese', ko:'Korean', ar:'Arabic', hi:'Hindi', tr:'Turkish', sv:'Swedish', da:'Danish', fi:'Finnish', cs:'Czech' };
205
+ const userLang = LANG_MAP[(config?.language || config?.lang || 'en').slice(0,2)] || 'English';
206
+ if (!enrichedPrompt.toLowerCase().includes('respond in') && !enrichedPrompt.toLowerCase().includes('rispondi in')) {
207
+ enrichedPrompt += `\n\nIMPORTANT: Always respond in ${userLang}.`;
208
+ }
209
+
203
210
  // Rolling context window
204
211
  const rawHistory = (body.history || []).map(h => ({
205
212
  role: h.role,
@@ -371,7 +371,7 @@ export function register(router) {
371
371
  const tasks = await listTasks(config, 'defaultList');
372
372
  sendJSON(res, 200, { tasks });
373
373
  } catch (e) {
374
- if (e.message?.includes('token') || e.message?.includes('auth') || e.message?.includes('No access token')) {
374
+ if (e.message?.includes('token') || e.message?.includes('auth') || e.message?.includes('Microsoft') || e.message?.includes('authenticated')) {
375
375
  return sendJSON(res, 200, { tasks: [], authRequired: true });
376
376
  }
377
377
  sendError(res, 500, e.message);