apache-autoindex-parse
TypeScript icon, indicating that this package has built-in type declarations

2.3.0 • Public • Published

apache-autoindex-parse

npm version npm downloads

a simple apache autoindex parser

📦 Installation

npm install apache-autoindex-parse

🚀 Usage

import { parse } from "apache-autoindex-parse";

const html = `<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">
<html>
  <head>
    <title>Index of /Public/emoji</title>
  </head>
  <body>
    <div style="padding: 0.5em">
      <!-- this is /file-header.html - it is a HeaderName for the /Public and other dirs -->

      © 1991-Present Unicode, Inc. Unicode and the Unicode Logo are registered trademarks of Unicode, Inc. in the U.S.
      and other countries. All the contents of this directory are governed by the
      <a href="https://www.unicode.org/copyright.html">Terms of Use</a>.
    </div>

    <hr />
    <table>
      <tr>
        <th valign="top"><img src="/icons/blank.gif" alt="[ICO]" /></th>
        <th><a href="?C=N;O=D;F=2">Name</a></th>
        <th><a href="?C=M;O=A;F=2">Last modified</a></th>
        <th><a href="?C=S;O=A;F=2">Size</a></th>
        <th><a href="?C=D;O=A;F=2">Description</a></th>
      </tr>
      <tr>
        <th colspan="5"><hr /></th>
      </tr>
      <tr>
        <td valign="top"><img src="/icons/back.gif" alt="[PARENTDIR]" /></td>
        <td><a href="/Public/">Parent Directory</a></td>
        <td>&nbsp;</td>
        <td align="right">-</td>
        <td>&nbsp;</td>
      </tr>
      <tr>
        <td valign="top"><img src="/icons/folder.gif" alt="[DIR]" /></td>
        <td><a href="1.0/">1.0/</a></td>
        <td align="right">2015-05-26 18:40</td>
        <td align="right">-</td>
        <td>&nbsp;</td>
      </tr>
      <tr>
        <td valign="top"><img src="/icons/text.gif" alt="[TXT]" /></td>
        <td><a href="ReadMe.txt">ReadMe.txt</a></td>
        <td align="right">2025-02-19 16:36</td>
        <td align="right">588</td>
        <td>&nbsp;</td>
      </tr>
      <tr>
        <th colspan="5"><hr /></th>
      </tr>
    </table>
  </body>
</html>`;

// Format can be either "F0", "F1" or "F2"
const format = "F2";

// If you leave the format empty, it will try and auto-infer it.
// If it can't infer it, it will default to "F0"
const entry = parse(html, format);

console.log(entry);
// [
//   {
//     type: 'directory',
//     name: '1.0',
//     path: '/1.0/',
//     lastModified: 1432658400000
//   },
//   {
//     type: 'file',
//     name: 'ReadMe.txt',
//     path: '/ReadMe.txt',
//     lastModified: 1739979360000
//   }
// ]

[!NOTE] If you want to traverse an entire apache, you can utilize the traverse function which is being exported from apache-autoindex-parse/traverse.

📄 License

Published under MIT License.

/apache-autoindex-parse/

    Package Sidebar

    Install

    npm i apache-autoindex-parse

    Weekly Downloads

    719

    Version

    2.3.0

    License

    MIT

    Unpacked Size

    797 kB

    Total Files

    19

    Last publish

    Collaborators

    • luxass