nothumanallowed 13.5.145 → 13.5.147

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": "13.5.145",
3
+ "version": "13.5.147",
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": {
@@ -4979,6 +4979,8 @@ ${completedHeadings ? `## SECTIONS ALREADY WRITTEN (headings only):\n${completed
4979
4979
  html = html.replace(/<meta[^>]+X-Frame-Options[^>]*>/gi, '');
4980
4980
  // Remove Content-Security-Policy meta http-equiv (server sets it via helmet with sandbox-safe values)
4981
4981
  html = html.replace(/<meta[^>]+http-equiv=["']Content-Security-Policy["'][^>]*>/gi, '');
4982
+ // Remove upgrade-insecure-requests directive if present in any remaining CSP meta
4983
+ html = html.replace(/upgrade-insecure-requests\s*;?\s*/gi, '');
4982
4984
  // Remove frame-ancestors none/self directives from any remaining CSP meta
4983
4985
  html = html.replace(/<meta[^>]+content=["'][^"']*frame-ancestors[^"']*["'][^>]*>/gi, '');
4984
4986
  if (html.length !== before) {
@@ -5242,9 +5244,15 @@ module.exports = { validateEmail, sanitizeText, validatePassword, validateUserna
5242
5244
  [/require\(['"]\.\/config\/redis['"]\)/g, "require('../services/cache')"],
5243
5245
  [/require\(['"]\.\.\/services\/redis['"]\)/g, "require('../services/cache')"],
5244
5246
  [/require\(['"]\.\/services\/redis['"]\)/g, "require('../services/cache')"],
5245
- // email utils: LLM puts utils/email but file is in services/email
5247
+ // email utils: LLM puts utils/email or services/emailService but file is services/email
5246
5248
  [/require\(['"]\.\.\/utils\/email['"]\)/g, "require('../services/email')"],
5247
5249
  [/require\(['"]\.\/utils\/email['"]\)/g, "require('./services/email')"],
5250
+ [/require\(['"]\.\.\/services\/emailService['"]\)/g, "require('../services/email')"],
5251
+ [/require\(['"]\.\/services\/emailService['"]\)/g, "require('./services/email')"],
5252
+ [/require\(['"]\.\.\/services\/mailer['"]\)/g, "require('../services/email')"],
5253
+ [/require\(['"]\.\/services\/mailer['"]\)/g, "require('./services/email')"],
5254
+ [/require\(['"]\.\.\/utils\/mailer['"]\)/g, "require('../services/email')"],
5255
+ [/require\(['"]\.\/utils\/mailer['"]\)/g, "require('./services/email')"],
5248
5256
  // config module: LLM generates require('../../config') or require('../config')
5249
5257
  [/require\(['"]\.\.\/\.\.\/config['"]\)/g, "{env:process.env}"],
5250
5258
  [/require\(['"]\.\.\/config['"]\)/g, "{env:process.env}"],
@@ -5276,6 +5284,8 @@ module.exports = { validateEmail, sanitizeText, validatePassword, validateUserna
5276
5284
  // nodemailer: LLM calls createTransporter (wrong) instead of createTransport (correct)
5277
5285
  [/nodemailer\.createTransporter\s*\(/g, "nodemailer.createTransport("],
5278
5286
  [/\{createTransporter\s*:/g, "{createTransport:"],
5287
+ // helmet: upgradeInsecureRequests forces HTTPS on local sandbox — always disable it
5288
+ [/upgradeInsecureRequests\s*:\s*(?:true|\{\}|undefined)/g, "upgradeInsecureRequests: false"],
5279
5289
  ];
5280
5290
  function patchJsFiles(dir, rootDir) {
5281
5291
  if (!fs.existsSync(dir)) return;
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 = '13.5.145';
8
+ export const VERSION = '13.5.147';
9
9
  export const BASE_URL = 'https://nothumanallowed.com/cli';
10
10
  export const API_BASE = 'https://nothumanallowed.com/api/v1';
11
11