fix: repair file_handlers.ts backtick escaping; update README

file_handlers.ts had AI-generated escaped backticks (\`) and template
literal dollar signs (\${) throughout, causing TypeScript compile errors
("Invalid character", "Unterminated template literal"). Fixed all 15
affected lines.

README updated: corrected seed config path from resources/seed_config.json
to ~/seed.json (external to app bundle by design), added explanation of
why it's kept external (no re-signing needed per device), and documented
the 2-char hash prefix cache layout with consistency warning.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
Scott Idem
2026-03-11 11:50:06 -04:00
parent 7c0bb6719d
commit 2ad6bce8db
4 changed files with 87 additions and 27 deletions

View File

@@ -16,7 +16,7 @@ export function registerFileHandlers() {
const prefix = hash.substring(0, Math.max(1, Math.min(prefix_len, 8)));
const dir = path.join(expanded_root, prefix);
if (!fs.existsSync(dir)) fs.mkdirSync(dir, { recursive: true });
return path.join(dir, \`\${hash}.file\`);
return path.join(dir, `${hash}.file`);
}
ipcMain.handle('native:check-cache', async (event, { cache_root, hash, hash_prefix_length = 2, verify_hash = false }) => {
@@ -39,7 +39,7 @@ export function registerFileHandlers() {
ipcMain.handle('native:download-to-cache', async (event, { url, cache_root, hash, api_key, account_id, hash_prefix_length = 2 }) => {
const full_path = get_organized_hashed_path(cache_root, hash, hash_prefix_length);
const tmp_path = \`\${full_path}.tmp\`;
const tmp_path = `${full_path}.tmp`;
if (endpoints_in_progress.includes(url)) return { success: true, status: 'in_progress' };
@@ -52,14 +52,14 @@ export function registerFileHandlers() {
const age_ms = Date.now() - stats.mtimeMs;
// If the tmp file is older than 5 minutes, assume previous download crashed and delete it
if (age_ms > 5 * 60 * 1000) {
console.log(\`Native: Deleting stale temp file (\${Math.round(age_ms/1000)}s old)\`);
console.log(`Native: Deleting stale temp file (${Math.round(age_ms/1000)}s old)`);
fs.unlinkSync(tmp_path);
} else {
return { success: true, status: 'in_progress', detail: 'fresh_tmp_exists' };
}
}
console.log(\`Native: Hardened Download -> \${full_path}\`);
console.log(`Native: Hardened Download -> ${full_path}`);
try {
endpoints_in_progress.push(url);
@@ -85,13 +85,13 @@ export function registerFileHandlers() {
const actual_hash = crypto.createHash('sha256').update(file_buffer).digest('hex');
if (actual_hash !== hash) {
console.error(\`Native: Hash Mismatch! Expected \${hash}, got \${actual_hash}\`);
console.error(`Native: Hash Mismatch! Expected ${hash}, got ${actual_hash}`);
fs.unlinkSync(tmp_path);
return { success: false, error: 'Integrity check failed: Hash mismatch' };
}
fs.renameSync(tmp_path, full_path);
console.log(\`Native: Cache Integrity Verified. File moved to final destination.\`);
console.log(`Native: Cache Integrity Verified. File moved to final destination.`);
return { success: true, path: full_path };
} catch (error: any) {
if (fs.existsSync(tmp_path)) fs.unlinkSync(tmp_path);
@@ -107,7 +107,7 @@ export function registerFileHandlers() {
const expanded_temp = expandPath(temp_root);
const target = path.join(expanded_temp, filename);
console.log(\`Native: Launching from Cache -> \${filename}\`);
console.log(`Native: Launching from Cache -> ${filename}`);
if (!fs.existsSync(expanded_temp)) fs.mkdirSync(expanded_temp, { recursive: true });
@@ -121,9 +121,9 @@ export function registerFileHandlers() {
// 3. Optimized Launch (LibreOffice / AppleScript)
if (is_pres) {
if (os.platform() === 'linux') {
console.log(\`Native: Launching LibreOffice (--impress) for \${target}\`);
console.log(`Native: Launching LibreOffice (--impress) for ${target}`);
return new Promise((resolve) => {
exec(\`libreoffice --impress "\${target}"\`, (err) => {
exec(`libreoffice --impress "${target}"`, (err) => {
if (err) resolve({ success: false, error: err.message });
else resolve({ success: true });
});
@@ -133,30 +133,30 @@ export function registerFileHandlers() {
if (os.platform() === 'darwin') {
let script = '';
if (ext === 'key') {
script = \`
script = `
tell application "Keynote"
activate
open (POSIX file "\${target}")
open (POSIX file "${target}")
delay 1
start (front document)
end tell
\`;
`;
} else if (ext === 'pptx' || ext === 'ppt') {
script = \`
script = `
tell application "Microsoft PowerPoint"
activate
open (POSIX file "\${target}")
open (POSIX file "${target}")
delay 1
run slide show of active presentation
end tell
\`;
`;
}
if (script) {
console.log(\`Native: Launching \${ext} via AppleScript for \${target}\`);
console.log(`Native: Launching ${ext} via AppleScript for ${target}`);
return new Promise((resolve) => {
const escapedScript = script.trim().replace(/"/g, '\\\\\\"').replace(/\\n/g, ' -e "') + '"';
exec(\`osascript -e \${escapedScript}\`, (err) => {
exec(`osascript -e ${escapedScript}`, (err) => {
if (err) resolve({ success: false, error: err.message });
else resolve({ success: true });
});