Compare commits

...

2 Commits

Author SHA1 Message Date
ThePendulum 133846378b 1.27.1 2023-05-06 01:11:32 +02:00
ThePendulum 2e923f2dcb Fixed YAML index file parser failing on duplicate keys. 2023-05-06 01:11:29 +02:00
5 changed files with 13 additions and 8 deletions

4
package-lock.json generated
View File

@ -1,12 +1,12 @@
{
"name": "ripunzel",
"version": "1.27.0",
"version": "1.27.1",
"lockfileVersion": 2,
"requires": true,
"packages": {
"": {
"name": "ripunzel",
"version": "1.27.0",
"version": "1.27.1",
"license": "ISC",
"dependencies": {
"array.prototype.flatten": "^1.2.1",

View File

@ -1,6 +1,6 @@
{
"name": "ripunzel",
"version": "1.27.0",
"version": "1.27.1",
"description": "Web content archiving tool, with versatile filename patterns and extensive options for reddit user profiles.",
"main": "app.js",
"scripts": {

View File

@ -1,7 +1,7 @@
'use strict';
function curateComments(comments) {
return comments.map(comment => ({
return comments.map((comment) => ({
id: comment.id,
url: `https://reddit.com${comment.permalink}`,
author: comment.author.name,
@ -31,7 +31,7 @@ async function getFullPost(postId, reddit) {
.fetch();
}
async function self(host, originalPost, reddit) {
async function self(host, originalPost, { reddit }) {
const post = await getFullPost(originalPost.id, reddit) || originalPost;
const curatedComments = curateComments(post.comments);

View File

@ -41,7 +41,12 @@ async function writeBufferToFile(target, buffer, item) {
async function save(requestedFilepath, bufferOrBuffers, item) {
const pathElements = getPathElements(requestedFilepath);
const buffers = [].concat(bufferOrBuffers); // allow for single stream argument
const buffers = [].concat(bufferOrBuffers).filter(Boolean); // allow for single stream argument
if (buffers.length === 0) {
logger.warn(`Received undefined buffer (${item.url})`);
return null;
}
await fs.ensureDir(pathElements.dir);

View File

@ -13,9 +13,9 @@ async function getIndex(user) {
try {
const indexFile = await fs.readFile(indexFilePath, 'utf8');
return yaml.safeLoad(indexFile);
return yaml.safeLoad(indexFile, { json: true }); // allow duplicate keys
} catch (error) {
logger.info(`No index file found for '${user.name}' at '${indexFilePath}'`);
logger.info(`No index file found for '${user.name}' at '${indexFilePath}': ${error.message}`);
return { profile: { image: null, description: null }, posts: [] };
}