From a2cab737f827bb6840cb6d54f951f2d7231c42f8 Mon Sep 17 00:00:00 2001 From: 3np <3np@3np> Date: Tue, 6 Apr 2021 00:12:31 +0900 Subject: [PATCH] Add configuration for domain_replacements --- config.js.template | 3 +++ inc/commons.js | 17 ++++++++++++++--- inc/processJsonSubreddit.js | 2 +- inc/processJsonUser.js | 4 ++-- inc/processSearchResults.js | 2 +- inc/processSubredditsExplore.js | 2 +- 6 files changed, 22 insertions(+), 8 deletions(-) diff --git a/config.js.template b/config.js.template index 13bd153..139f23e 100644 --- a/config.js.template +++ b/config.js.template @@ -27,6 +27,9 @@ const config = { nsfw_enabled: process.env.NSFW_ENABLED !== 'true' || true, // Enable NSFW (over 18) content. If false, a warning is shown to the user before opening any NSFW post. When the NFSW content is disabled, NSFW posts are hidden from subreddits and from user page feeds. Note: Users can set this to true or false from their preferences. post_comments_sort: process.env.POST_COMMENTS_SORT || 'confidence', // "confidence" is the default sorting in Reddit. Must be one of: confidence, top, new, controversial, old, random, qa, live. reddit_app_id: process.env.REDDIT_APP_ID || 'ABfYqdDc9qPh1w', // If "use_reddit_oauth" config key is set to true, you have to obtain your Reddit app ID. For testing purposes it's okay to use this project's default app ID. Create your Reddit app here: https://old.reddit.com/prefs/apps/. Make sure to create an "installed app" type of app. + domain_replacements: process.env.DOMAIN_REPLACEMENTS + ? (JSON.parse(process.env.DOMAIN_REPLACEMENTS).map(([p, r]) => [new RegExp(p, 'gm'), r])) + : [], // Replacements for domains in outgoing links. Tuples with regular expressions to match, and replacement values. This is in addition to user-level configuration of privacyDomains. post_media_max_heights: { /** * Sets the max-height value for images and videos in posts. diff --git a/inc/commons.js b/inc/commons.js index 3e89e68..85d9304 100644 --- a/inc/commons.js +++ b/inc/commons.js @@ -55,7 +55,7 @@ module.exports = function(request, fs) { } } catch(e) { } - url = replacePrivacyDomains(url, user_preferences) + url = replaceDomains(url, user_preferences) return url } @@ -159,7 +159,7 @@ module.exports = function(request, fs) { return unescaped[m] }) - result = replacePrivacyDomains(result, user_preferences) + result = replaceDomains(result, user_preferences) return result } else { @@ -167,9 +167,20 @@ module.exports = function(request, fs) { } } - this.replacePrivacyDomains = (str, user_preferences) => { + this.replaceDomains = (str, user_preferences) => { if(typeof(str) == 'undefined' || !str) return + + if (config.domain_replacements) { + for (replacement of config.domain_replacements) { + str = str.replace(...replacement) + } + } + + return this.replaceUserDomains(str, user_preferences) + } + + this.replaceUserDomains = (str, user_preferences) => { let redditRegex = /([A-z.]+\.)?(reddit(\.com)|redd(\.it))/gm; let youtubeRegex = /([A-z.]+\.)?youtu(be\.com|\.be)/gm; diff --git a/inc/processJsonSubreddit.js b/inc/processJsonSubreddit.js index aa2a2ec..597033e 100644 --- a/inc/processJsonSubreddit.js +++ b/inc/processJsonSubreddit.js @@ -91,7 +91,7 @@ module.exports = function() { title: data.title, ups: data.ups, upvote_ratio: data.upvote_ratio, - url: replacePrivacyDomains(data.url, user_preferences), + url: replaceDomains(data.url, user_preferences), stickied: data.stickied, is_self_link: is_self_link, subreddit_front: subreddit_front, diff --git a/inc/processJsonUser.js b/inc/processJsonUser.js index cff2180..2313ed1 100644 --- a/inc/processJsonUser.js +++ b/inc/processJsonUser.js @@ -64,7 +64,7 @@ module.exports = function() { title: post.title, created: post.created_utc, ups: post.ups, - url: replacePrivacyDomains(url, user_preferences), + url: replaceDomains(url, user_preferences), thumbnail: await downloadAndSave(post.thumbnail), duration: duration, edited: post.edited, @@ -83,7 +83,7 @@ module.exports = function() { created: post.created_utc, subreddit_name_prefixed: post.subreddit_name_prefixed, ups: post.ups, - url: replacePrivacyDomains(url, user_preferences), + url: replaceDomains(url, user_preferences), edited: post.edited, body_html: unescape(post.body_html), num_comments: post.num_comments, diff --git a/inc/processSearchResults.js b/inc/processSearchResults.js index 40bd9cc..de4a186 100644 --- a/inc/processSearchResults.js +++ b/inc/processSearchResults.js @@ -70,7 +70,7 @@ module.exports = function() { link_flair_text: post.link_flair_text, ups: post.ups, images: images, - url: replacePrivacyDomains(post.url, user_preferences), + url: replaceDomains(post.url, user_preferences), edited: post.edited, selftext_html: unescape(post.body_html), num_comments: post.num_comments, diff --git a/inc/processSubredditsExplore.js b/inc/processSubredditsExplore.js index f01792f..ab3f931 100644 --- a/inc/processSubredditsExplore.js +++ b/inc/processSubredditsExplore.js @@ -36,7 +36,7 @@ module.exports = function() { display_name: data.display_name, display_name_prefixed: data.display_name_prefixed, public_description: data.public_description, - url: replacePrivacyDomains(data.url, user_preferences), + url: replaceDomains(data.url, user_preferences), subscribers: data.subscribers, over_18: data.over18, title: data.title,