Custom front end modifications for directory index pages generated by Apache mod_autoindex.
This project's intended use is for WebDAV servers that don't use Apache's Alias
directive to direct visitors to the WebDAV share.
Apache's default directory index pages, which are generated by mod_autoindex, are boring and outdated. This is for good reason — no reliance on third-party libraries means fewer dependencies to keep track of — but there's something to be said about a responsive design for frequently-used pages in the modern era.
After applying a few configuration options (i.e., IndexOptions
, HeaderName
, ReadmeName
, etc.) in the Apache virtual host configuration responsible for a WebDAV share and pasting the custom theme files into the root of the share, the directory listings look something like this:
The resulting HTML page is pretty, fully responsive, and mobile-ready, and it includes functional breadcrumb navigation.
Some of the file/directory details that are normally provided by mod_autoindex are disabled in the configuration for the sake of simplicity, but the table (re-)building logic should be able to handle re-enabling the description row. Sorting functionality via queries is still supported.
To use the custom theme, a few changes must be made to an existing Apache virtual host configuration. A sample config file is provided in this repository, and it can be used as a replacement config file after following DigitalOcean's Apache WebDAV tutorial.
Assuming WebDAV is setup and enabled in an existing virtual host config, add the following within the <Directory>
block that controls the WebDAV share:
# DIRECTORY CUSTOMIZATION
<IfModule mod_autoindex.c>
# SET INDEX OPTIONS
IndexOptions IgnoreCase FancyIndexing FoldersFirst NameWidth=* SuppressDescription HTMLTable
# SET DISPLAY ORDER
IndexOrderDefault Ascending Name
# IGNORE CUSTOM FILES
IndexIgnore header.html footer.html favicon.ico .htaccess .ftpquota .DS_Store icons *.log *,v *,t .??* *~ *#
# SPECIFY HEADER FILE
HeaderName /.theme/header.html
# SPECIFY FOOTER FILE
ReadmeName /.theme/footer.html
</IfModule>
Then, simply copy the .theme directory into the root of your WebDAV share and restart apache2. The various configuration options can be changed as required and reloaded by restarting apache2.
Important note: Apache resolves absolute locations for theme files supplied in the HeaderName
and ReadmeName
directives based on your DocumentRoot
, meaning either the DocumentRoot
must match the directory being used for WebDAV or the theme files must be stored in the separate DocumentRoot
directory. If the latter configuration is used, the Alias
directive may be used as shown in the DigitalOcean tutorial references above. The sample virtual host config provided in this repository sets the DocumentRoot
to the same directory as the WebDAV share, and does not use Alias
.
Thanks to a number of folks on StackOverflow for tidbits of information regarding mod_autoindex behavior, but most importantly to Jeff Star for his incredible write-up on directory listing customizations.
Additionally, becoming familiar with the mod_autoindex configuration options is a must for modifying this project.
Finally, thanks to Pico CSS for a minimal, easy-to-use front end framework. I would have abandoned this idea if I had to use Bootstrap.