« get me outta code hell

mtui - Music Text User Interface - user-friendly command line music player
about summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--crawlers.js22
1 files changed, 18 insertions, 4 deletions
diff --git a/crawlers.js b/crawlers.js
index 0bf5c4e..8ba70f3 100644
--- a/crawlers.js
+++ b/crawlers.js
@@ -27,12 +27,13 @@ function crawlHTTP(absURL, opts = {}, internals = {}) {
 
     maxAttempts = 5,
 
-    keepSeparateHosts = false,
+    allowedExternalHostRegex = null,
     stayInSameDirectory = true,
 
     keepAnyFileType = false,
     fileTypes = ['wav', 'ogg', 'oga', 'mp3', 'mp4', 'm4a', 'mov', 'mpga', 'mod'],
 
+    forceGroupRegex = null,
     filterRegex = null
   } = opts
 
@@ -55,12 +56,17 @@ function crawlHTTP(absURL, opts = {}, internals = {}) {
     .then(
       res => res.text().then(async text => {
         const links = getHTMLLinks(text)
+        console.log(links)
 
         const items = []
 
         for (const link of links) {
           let [ name, href ] = link
 
+          if (!href) {
+            continue
+          }
+
           // If the name (that's the content inside of <a>..</a>) ends with a
           // slash, that's probably just an artifact of a directory lister;
           // not actually part of the intended content. So we remove it!
@@ -85,12 +91,20 @@ function crawlHTTP(absURL, opts = {}, internals = {}) {
             continue
           }
 
-          if (!keepSeparateHosts && urlObj.host !== absURLObj.host) {
+          if (urlObj.host !== absURLObj.host && !(
+            allowedExternalHostRegex && new RegExp(allowedExternalHostRegex)
+              .test(urlObj.host))) {
             verboseLog("[Ignored] Inconsistent host: " + linkURL)
             continue
           }
 
-          if (stayInSameDirectory) {
+          if (stayInSameDirectory) sameDir: {
+            // Don't bother with staying in the same directory if it's on a
+            // different host.
+            if (urlObj.host !== absURLObj.host) {
+              break sameDir
+            }
+
             const relative = path.relative(absURLObj.pathname, urlObj.pathname)
             if (relative.startsWith('..') || path.isAbsolute(relative)) {
               verboseLog("[Ignored] Outside of parent directory: " + linkURL)
@@ -98,7 +112,7 @@ function crawlHTTP(absURL, opts = {}, internals = {}) {
             }
           }
 
-          if (href.endsWith('/')) {
+          if (href.endsWith('/') || (forceGroupRegex && new RegExp(forceGroupRegex).test(href))) {
             // It's a directory!
 
             verboseLog("[Dir] " + linkURL)