ZIP extraction error handling (#4002)

* Improve error handling in extractFileFromZipBuffer function

* Add warning logging to NovelAI image upscaling
This commit is contained in:
Cohee
2025-05-16 19:57:33 +03:00
committed by GitHub
parent 1651fa1ed7
commit c218c1baea
2 changed files with 51 additions and 27 deletions

View File

@@ -394,7 +394,8 @@ router.post('/generate-image', async (request, response) => {
});
if (!upscaleResult.ok) {
throw new Error('NovelAI returned an error.');
const text = await upscaleResult.text();
throw new Error('NovelAI returned an error.', { cause: text });
}
const upscaledArchiveBuffer = await upscaleResult.arrayBuffer();
@@ -408,7 +409,7 @@ router.post('/generate-image', async (request, response) => {
return response.send(upscaledBase64);
} catch (error) {
console.warn('NovelAI generated an image, but upscaling failed. Returning original image.');
console.warn('NovelAI generated an image, but upscaling failed. Returning original image.', error);
return response.send(originalBase64);
}
} catch (error) {

View File

@@ -207,16 +207,23 @@ export function formatBytes(bytes) {
* @returns {Promise<Buffer|null>} Buffer containing the extracted file. Null if the file was not found.
*/
export async function extractFileFromZipBuffer(archiveBuffer, fileExtension) {
return await new Promise((resolve, reject) => yauzl.fromBuffer(Buffer.from(archiveBuffer), { lazyEntries: true }, (err, zipfile) => {
if (err) reject(err);
return await new Promise((resolve) => {
try {
yauzl.fromBuffer(Buffer.from(archiveBuffer), { lazyEntries: true }, (err, zipfile) => {
if (err) {
console.warn(`Error opening ZIP file: ${err.message}`);
return resolve(null);
}
zipfile.readEntry();
zipfile.on('entry', (entry) => {
if (entry.fileName.endsWith(fileExtension) && !entry.fileName.startsWith('__MACOSX')) {
console.info(`Extracting ${entry.fileName}`);
zipfile.openReadStream(entry, (err, readStream) => {
if (err) {
reject(err);
console.warn(`Error opening read stream: ${err.message}`);
return zipfile.readEntry();
} else {
const chunks = [];
readStream.on('data', (chunk) => {
@@ -228,14 +235,30 @@ export async function extractFileFromZipBuffer(archiveBuffer, fileExtension) {
resolve(buffer);
zipfile.readEntry(); // Continue to the next entry
});
readStream.on('error', (err) => {
console.warn(`Error reading stream: ${err.message}`);
zipfile.readEntry();
});
}
});
} else {
zipfile.readEntry();
}
});
zipfile.on('error', (err) => {
console.warn('ZIP processing error', err);
resolve(null);
});
zipfile.on('end', () => resolve(null));
}));
});
} catch (error) {
console.warn('Failed to process ZIP buffer', error);
resolve(null);
}
});
}
/**