]> git.r.bdr.sh - rbdr/blog/blobdiff - lib/generators/rss.js
Update version, ditch changelog
[rbdr/blog] / lib / generators / rss.js
index a1fcb0801ed7c3a2db8551f62f6d9644889a1df9..ec45dc8f8e289363eeb8e5c9d27285aec1c4ba38 100644 (file)
@@ -1,6 +1,6 @@
 'use strict';
 
 'use strict';
 
-const { template } = require('dot');
+const { template, templateSettings } = require('dot');
 const { encodeXML } = require('entities');
 const { readFile, writeFile } = require('fs/promises');
 const { join } = require('path');
 const { encodeXML } = require('entities');
 const { readFile, writeFile } = require('fs/promises');
 const { join } = require('path');
@@ -9,7 +9,12 @@ const { debuglog } = require('util');
 const internals = {
   debuglog: debuglog('blog'),
 
 const internals = {
   debuglog: debuglog('blog'),
 
-  kFeedName: 'feed.xml'
+  kFeedName: 'feed.xml',
+
+  extractTitle(postText) {
+
+    return postText.trim().split('\n')[0].replace('#', '').trim();
+  }
 };
 
 /**
 };
 
 /**
@@ -33,10 +38,12 @@ module.exports = async function RSSGenerator(source, target, posts) {
   posts = posts.map((post) => ({
     ...post,
     createdOn: (new Date(post.createdOn)).toUTCString(),
   posts = posts.map((post) => ({
     ...post,
     createdOn: (new Date(post.createdOn)).toUTCString(),
+    title: internals.extractTitle(post.raw),
     html: encodeXML(post.html)
   }));
     html: encodeXML(post.html)
   }));
-  const feedXml = template(feedTemplate)({ posts });
+  const feedXml = template(feedTemplate, {
+    ...templateSettings,
+    strip: false
+  })({ posts });
   await writeFile(feedTarget, feedXml);
 };
   await writeFile(feedTarget, feedXml);
 };
-
-